aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/readonly_test.rb
diff options
context:
space:
mode:
authorMarcel Molina <marcel@vernix.org>2006-03-30 22:27:32 +0000
committerMarcel Molina <marcel@vernix.org>2006-03-30 22:27:32 +0000
commit3f049b0b6b5a338786c3dfafb31edf937f4ecb13 (patch)
tree8a50caa833b407feca119b5d2de61ba9e46ce299 /activerecord/test/readonly_test.rb
parent58dd49a7ae13471b8f8e359286307853bfc22529 (diff)
downloadrails-3f049b0b6b5a338786c3dfafb31edf937f4ecb13.tar.gz
rails-3f049b0b6b5a338786c3dfafb31edf937f4ecb13.tar.bz2
rails-3f049b0b6b5a338786c3dfafb31edf937f4ecb13.zip
Do not implicitly mark recordss of has_many :through as readonly but do mark habtm records as readonly (eventually only on join tables without rich attributes).
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@4107 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord/test/readonly_test.rb')
-rwxr-xr-xactiverecord/test/readonly_test.rb18
1 files changed, 12 insertions, 6 deletions
diff --git a/activerecord/test/readonly_test.rb b/activerecord/test/readonly_test.rb
index 55f5cbe4ca..584eb735fe 100755
--- a/activerecord/test/readonly_test.rb
+++ b/activerecord/test/readonly_test.rb
@@ -3,6 +3,8 @@ require 'fixtures/post'
require 'fixtures/comment'
require 'fixtures/developer'
require 'fixtures/project'
+require 'fixtures/reader'
+require 'fixtures/person'
# Dummy class methods to test implicit association scoping.
def Comment.foo() find :first end
@@ -50,19 +52,23 @@ class ReadOnlyTest < Test::Unit::TestCase
def test_habtm_find_readonly
dev = Developer.find(1)
assert !dev.projects.empty?
- dev.projects.each { |p| assert !p.readonly? }
- dev.projects.find(:all) { |p| assert !p.readonly? }
- dev.projects.find(:all, :readonly => true) { |p| assert p.readonly? }
+ assert dev.projects.all?(&:readonly?)
+ assert dev.projects.find(:all).all?(&:readonly?)
+ assert dev.projects.find(:all, :readonly => true).all?(&:readonly?)
end
def test_has_many_find_readonly
post = Post.find(1)
assert !post.comments.empty?
- post.comments.each { |r| assert !r.readonly? }
- post.comments.find(:all) { |r| assert !r.readonly? }
- post.comments.find(:all, :readonly => true) { |r| assert r.readonly? }
+ assert !post.comments.any?(&:readonly?)
+ assert !post.comments.find(:all).any?(&:readonly?)
+ assert post.comments.find(:all, :readonly => true).all?(&:readonly?)
end
+ def test_has_many_with_through_is_not_implicitly_marked_readonly
+ assert people = Post.find(1).people
+ assert !people.any?(&:readonly?)
+ end
def test_readonly_scoping
Post.with_scope(:find => { :conditions => '1=1' }) do