aboutsummaryrefslogtreecommitdiffstats
path: root/test/visitors
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2013-09-11 16:37:16 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2013-09-11 16:37:16 -0700
commitbd6adc877af4687aec636f08e96e19785eea209d (patch)
treee61b114c5ade9d091611974ed1694370c0d54c57 /test/visitors
parenta1a46fd8c2a3d53e02e2e58ca575b2596646b2c3 (diff)
parentd93a05eec1adc5ca9d752a1e0b33313fc092c3e7 (diff)
downloadrails-bd6adc877af4687aec636f08e96e19785eea209d.tar.gz
rails-bd6adc877af4687aec636f08e96e19785eea209d.tar.bz2
rails-bd6adc877af4687aec636f08e96e19785eea209d.zip
Merge pull request #204 from trptcolin/visitor_dispatch_caching
Cache visitor dispatch on a per-visitor basis
Diffstat (limited to 'test/visitors')
-rw-r--r--test/visitors/test_dispatch_contamination.rb22
1 files changed, 22 insertions, 0 deletions
diff --git a/test/visitors/test_dispatch_contamination.rb b/test/visitors/test_dispatch_contamination.rb
new file mode 100644
index 0000000000..d3c9e8af2e
--- /dev/null
+++ b/test/visitors/test_dispatch_contamination.rb
@@ -0,0 +1,22 @@
+require 'helper'
+
+module Arel
+ module Visitors
+ describe 'avoiding contamination between visitor dispatch tables' do
+ before do
+ @connection = Table.engine.connection
+ @table = Table.new(:users)
+ end
+
+ it 'dispatches properly after failing upwards' do
+ node = Nodes::Union.new(Nodes::True.new, Nodes::False.new)
+ assert_equal "( TRUE UNION FALSE )", node.to_sql
+
+ node.first # from Nodes::Node's Enumerable mixin
+
+ assert_equal "( TRUE UNION FALSE )", node.to_sql
+ end
+ end
+ end
+end
+