aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases/adapters/postgresql
diff options
context:
space:
mode:
authorRyuta Kamizono <kamipo@gmail.com>2019-03-17 03:53:48 +0900
committerGitHub <noreply@github.com>2019-03-17 03:53:48 +0900
commit1db05065434e1b5341e6748632e310060e92b80d (patch)
tree234dd16076aa757c37c0c83f80d719b504b8d7d4 /activerecord/test/cases/adapters/postgresql
parent6486f80d3a3448579089fab1c8b7846c09cf87ec (diff)
parent97347d8c409f14b682dd9ec52ded3c869d0ba479 (diff)
downloadrails-1db05065434e1b5341e6748632e310060e92b80d.tar.gz
rails-1db05065434e1b5341e6748632e310060e92b80d.tar.bz2
rails-1db05065434e1b5341e6748632e310060e92b80d.zip
Merge pull request #35615 from kamipo/optimizer_hints
Support Optimizer Hints
Diffstat (limited to 'activerecord/test/cases/adapters/postgresql')
-rw-r--r--activerecord/test/cases/adapters/postgresql/optimizer_hints_test.rb28
1 files changed, 28 insertions, 0 deletions
diff --git a/activerecord/test/cases/adapters/postgresql/optimizer_hints_test.rb b/activerecord/test/cases/adapters/postgresql/optimizer_hints_test.rb
new file mode 100644
index 0000000000..1bfa815cac
--- /dev/null
+++ b/activerecord/test/cases/adapters/postgresql/optimizer_hints_test.rb
@@ -0,0 +1,28 @@
+# frozen_string_literal: true
+
+require "cases/helper"
+require "models/post"
+
+if supports_optimizer_hints?
+ class PostgresqlOptimzerHintsTest < ActiveRecord::PostgreSQLTestCase
+ fixtures :posts
+
+ def setup
+ enable_extension!("pg_hint_plan", ActiveRecord::Base.connection)
+ end
+
+ def test_optimizer_hints
+ assert_sql(%r{\ASELECT /\*\+ SeqScan\(posts\) \*/}) do
+ posts = Post.optimizer_hints("SeqScan(posts)")
+ posts = posts.select(:id).where(author_id: [0, 1])
+ assert_includes posts.explain, "Seq Scan on posts"
+ end
+
+ assert_sql(%r{\ASELECT /\*\+ SeqScan\(posts\) \*/}) do
+ posts = Post.optimizer_hints("/*+ SeqScan(posts) */")
+ posts = posts.select(:id).where(author_id: [0, 1])
+ assert_includes posts.explain, "Seq Scan on posts"
+ end
+ end
+ end
+end