diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2011-05-10 17:10:08 -0700 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2011-05-10 17:10:08 -0700 |
commit | 65b55b850109385195f906b88f217da88a9056a6 (patch) | |
tree | 279cd2ffe42632ef4570efe6a5d499d9d1b94434 /test/visitors | |
parent | 64f2df112410705a8c9e100b5369bbdd1e248efe (diff) | |
parent | ede507d687e23cbd5e6f8697cd65836830e0d702 (diff) | |
download | rails-65b55b850109385195f906b88f217da88a9056a6.tar.gz rails-65b55b850109385195f906b88f217da88a9056a6.tar.bz2 rails-65b55b850109385195f906b88f217da88a9056a6.zip |
Merge branch 'master' of github.com:rails/arel
* 'master' of github.com:rails/arel:
Make ToSql more thread safe.
Diffstat (limited to 'test/visitors')
-rw-r--r-- | test/visitors/test_to_sql.rb | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/test/visitors/test_to_sql.rb b/test/visitors/test_to_sql.rb index 1d5f89280b..8084e6441c 100644 --- a/test/visitors/test_to_sql.rb +++ b/test/visitors/test_to_sql.rb @@ -1,5 +1,9 @@ require 'helper' +class Arel::Visitors::ToSql + def last_column; Thread.current[:arel_visitors_to_sql_last_column] || @last_column; end +end + module Arel module Visitors describe 'the to_sql visitor' do @@ -9,6 +13,19 @@ module Arel @attr = @table[:id] end + it "should be thread safe around usage of last_column" do + visit_integer_column = Thread.new do + Thread.stop + @visitor.send(:visit_Arel_Attributes_Attribute, @attr) + end + + @visitor.accept(@table[:name]) + assert_equal(:string, @visitor.last_column.type) + visit_integer_column.run + visit_integer_column.join + assert_equal(:string, @visitor.last_column.type) + end + it 'should not quote sql literals' do node = @table[Arel.star] sql = @visitor.accept node |