aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases
diff options
context:
space:
mode:
authorJon Leighton <j@jonathanleighton.com>2011-08-13 16:37:44 +0100
committerJon Leighton <j@jonathanleighton.com>2011-08-13 16:54:05 +0100
commit24f902b1bcfa5dca4bfc7f2b978a4b0dece73894 (patch)
tree97f3ce1357170746f7ecd22f2dd9630408468d05 /activerecord/test/cases
parent291072a64a2b191816f395b25aae4a50d2dcfe16 (diff)
downloadrails-24f902b1bcfa5dca4bfc7f2b978a4b0dece73894.tar.gz
rails-24f902b1bcfa5dca4bfc7f2b978a4b0dece73894.tar.bz2
rails-24f902b1bcfa5dca4bfc7f2b978a4b0dece73894.zip
Fix default scope thread safety. Thanks @thedarkone for reporting.
Diffstat (limited to 'activerecord/test/cases')
-rw-r--r--activerecord/test/cases/relation_scoping_test.rb18
1 files changed, 18 insertions, 0 deletions
diff --git a/activerecord/test/cases/relation_scoping_test.rb b/activerecord/test/cases/relation_scoping_test.rb
index 673aff403f..1e2093273e 100644
--- a/activerecord/test/cases/relation_scoping_test.rb
+++ b/activerecord/test/cases/relation_scoping_test.rb
@@ -524,4 +524,22 @@ class DefaultScopingTest < ActiveRecord::TestCase
assert_equal 1, DeveloperWithIncludes.where(:audit_logs => { :message => 'foo' }).count
end
+
+ def test_default_scope_is_threadsafe
+ if in_memory_db?
+ skip "in memory db can't share a db between threads"
+ end
+
+ threads = []
+ assert_not_equal 1, ThreadsafeDeveloper.unscoped.count
+
+ threads << Thread.new do
+ Thread.current[:long_default_scope] = true
+ assert_equal 1, ThreadsafeDeveloper.all.count
+ end
+ threads << Thread.new do
+ assert_equal 1, ThreadsafeDeveloper.all.count
+ end
+ threads.each(&:join)
+ end
end