aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/mixin_test.rb
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2004-12-19 13:01:47 +0000
committerDavid Heinemeier Hansson <david@loudthinking.com>2004-12-19 13:01:47 +0000
commit356f16006b44ee500db0fda0da055436ff41e37e (patch)
treeafbff527c329a72c8ff41b65f05e24486248f897 /activerecord/test/mixin_test.rb
parenteeae1eecb9d02c4a3d8cf8436503f594acd8b302 (diff)
downloadrails-356f16006b44ee500db0fda0da055436ff41e37e.tar.gz
rails-356f16006b44ee500db0fda0da055436ff41e37e.tar.bz2
rails-356f16006b44ee500db0fda0da055436ff41e37e.zip
Added higher_item and lower_item as public methods for acts_as_list #342 [Tobias Luetke]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@221 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord/test/mixin_test.rb')
-rw-r--r--activerecord/test/mixin_test.rb206
1 files changed, 150 insertions, 56 deletions
diff --git a/activerecord/test/mixin_test.rb b/activerecord/test/mixin_test.rb
index 3caa5a3813..01b16cc631 100644
--- a/activerecord/test/mixin_test.rb
+++ b/activerecord/test/mixin_test.rb
@@ -3,72 +3,136 @@ require 'active_record/acts/tree'
require 'active_record/acts/list'
require 'fixtures/mixin'
-
class ListTest < Test::Unit::TestCase
fixtures :mixins
- def test_injection
- l = ListMixin.new("parent_id"=>1)
- assert_equal "parent_id = 1", l.scope_condition
- assert_equal "pos", l.position_column
-
- end
-
def test_reordering
- assert_equal [ListMixin.find(2), ListMixin.find(3)], ListMixin.find_all("parent_id=1", "pos")
-
- ListMixin.find(2).move_lower
-
- assert_equal [ListMixin.find(3), ListMixin.find(2)], ListMixin.find_all("parent_id=1", "pos")
-
- ListMixin.find(2).move_higher
+ assert_equal [@mixins['list_1'].find,
+ @mixins['list_2'].find,
+ @mixins['list_3'].find,
+ @mixins['list_4'].find],
+ ListMixin.find_all("parent_id=5", "pos")
+
+ @mixins['list_2'].find.move_lower
+
+ assert_equal [@mixins['list_1'].find,
+ @mixins['list_3'].find,
+ @mixins['list_2'].find,
+ @mixins['list_4'].find],
+ ListMixin.find_all("parent_id=5", "pos")
+
+ @mixins['list_2'].find.move_higher
- assert_equal [ListMixin.find(2), ListMixin.find(3)], ListMixin.find_all("parent_id=1", "pos")
+ assert_equal [@mixins['list_1'].find,
+ @mixins['list_2'].find,
+ @mixins['list_3'].find,
+ @mixins['list_4'].find],
+ ListMixin.find_all("parent_id=5", "pos")
- end
+ @mixins['list_1'].find.move_to_bottom
+
+ assert_equal [@mixins['list_2'].find,
+ @mixins['list_3'].find,
+ @mixins['list_4'].find,
+ @mixins['list_1'].find],
+ ListMixin.find_all("parent_id=5", "pos")
+
+ @mixins['list_1'].find.move_to_top
+ assert_equal [@mixins['list_1'].find,
+ @mixins['list_2'].find,
+ @mixins['list_3'].find,
+ @mixins['list_4'].find],
+ ListMixin.find_all("parent_id=5", "pos")
+
+
+ @mixins['list_2'].find.move_to_bottom
+
+ assert_equal [@mixins['list_1'].find,
+ @mixins['list_3'].find,
+ @mixins['list_4'].find,
+ @mixins['list_2'].find],
+ ListMixin.find_all("parent_id=5", "pos")
+
+ @mixins['list_4'].find.move_to_top
+
+ assert_equal [@mixins['list_4'].find,
+ @mixins['list_1'].find,
+ @mixins['list_3'].find,
+ @mixins['list_2'].find],
+ ListMixin.find_all("parent_id=5", "pos")
+
+ end
+
+ def test_next_prev
+ assert_equal @list_2, @list_1.lower_item
+ assert_nil @list_1.higher_item
+ assert_equal @list_3, @list_4.higher_item
+ assert_nil @list_4.lower_item
+ end
+
+
+ def test_injection
+ item = ListMixin.new("parent_id"=>1)
+ assert_equal "parent_id = 1", item.scope_condition
+ assert_equal "pos", item.position_column
+ end
+
def test_insert
- new = ListMixin.create("parent_id"=>5)
+ new = ListMixin.create("parent_id"=>20)
assert_equal 1, new.pos
assert new.first?
assert new.last?
- new = ListMixin.create("parent_id"=>5)
+ new = ListMixin.create("parent_id"=>20)
assert_equal 2, new.pos
assert !new.first?
assert new.last?
- new = ListMixin.create("parent_id"=>5)
+ new = ListMixin.create("parent_id"=>20)
assert_equal 3, new.pos
assert !new.first?
assert new.last?
- new = ListMixin.create("parent_id"=>10)
+ new = ListMixin.create("parent_id"=>0)
assert_equal 1, new.pos
assert new.first?
assert new.last?
end
def test_delete_middle
- first = ListMixin.create("parent_id"=>5)
- assert_equal 1, first.pos
-
- second = ListMixin.create("parent_id"=>5)
- assert_equal 2, second.pos
-
- third = ListMixin.create("parent_id"=>5)
- assert_equal 3, third.pos
- second.destroy
+ assert_equal [@mixins['list_1'].find,
+ @mixins['list_2'].find,
+ @mixins['list_3'].find,
+ @mixins['list_4'].find],
+ ListMixin.find_all("parent_id=5", "pos")
+
+ @mixins['list_2'].find.destroy
- assert_equal 1, @mixins["first"].find.pos
- assert_equal 2, @mixins["third"].find.pos
+ assert_equal [@mixins['list_1'].find,
+ @mixins['list_3'].find,
+ @mixins['list_4'].find],
+ ListMixin.find_all("parent_id=5", "pos")
+
+ assert_equal 1, @mixins['list_1'].find.pos
+ assert_equal 2, @mixins['list_3'].find.pos
+ assert_equal 3, @mixins['list_4'].find.pos
+
+ @mixins['list_1'].find.destroy
+
+ assert_equal [@mixins['list_3'].find,
+ @mixins['list_4'].find],
+ ListMixin.find_all("parent_id=5", "pos")
+
+ assert_equal 1, @mixins['list_3'].find.pos
+ assert_equal 2, @mixins['list_4'].find.pos
end
def test_with_string_based_scope
- new = ListWithStringScopeMixin.create("parent_id"=>5)
+ new = ListWithStringScopeMixin.create("parent_id"=>500)
assert_equal 1, new.pos
assert new.first?
assert new.last?
@@ -79,59 +143,89 @@ class TreeTest < Test::Unit::TestCase
fixtures :mixins
def test_has_child
- assert_equal true, @first.has_children?
- assert_equal false, @second.has_children?
- assert_equal false, @third.has_children?
+ assert_equal true, @tree_1.has_children?
+ assert_equal true, @tree_2.has_children?
+ assert_equal false, @tree_3.has_children?
+ assert_equal false, @tree_4.has_children?
end
def test_children
- assert_equal @first.children, [@second, @third]
- assert_equal @second.children, []
+ assert_equal @tree_1.children, [@tree_2, @tree_4]
+ assert_equal @tree_2.children, [@tree_3]
+ assert_equal @tree_3.children, []
+ assert_equal @tree_4.children, []
end
def test_parent
- assert_equal @second.parent, @first
- assert_equal @second.parent, @third.parent
- assert_nil @first.parent
+ assert_equal @tree_2.parent, @tree_1
+ assert_equal @tree_2.parent, @tree_4.parent
+ assert_nil @tree_1.parent
+ end
+
+ def test_delete
+ assert_equal 4, TreeMixin.count
+ @tree_1.destroy
+ assert_equal 0, TreeMixin.count
end
def test_insert
- @extra = @first.children.create
+ @extra = @tree_1.children.create
assert @extra
- assert_equal @extra.parent, @first
- assert_equal [@second, @third, @extra], @first.children
+ assert_equal @extra.parent, @tree_1
+ assert_equal [@tree_2, @tree_4, @extra], @tree_1.children
end
- def test_delete
- assert_equal 3, Mixin.count
- @first.destroy
- assert_equal 0, Mixin.count
- end
+
end
class TouchTest < Test::Unit::TestCase
fixtures :mixins
def test_update
- assert_nil @first.updated_at
- @first.save
- assert_not_nil @first.updated_at
+
+ stamped = Mixin.new
+
+ assert_nil stamped.updated_at
+ assert_nil stamped.created_at
+ stamped.save
+ assert_not_nil stamped.updated_at
+ assert_not_nil stamped.created_at
end
def test_create
- @obj = Mixin.create({"parent" => @third})
+ @obj = Mixin.create
assert_not_nil @obj.updated_at
assert_not_nil @obj.created_at
end
+
+ def test_many_updates
+
+ stamped = Mixin.new
+
+ assert_nil stamped.updated_at
+ assert_nil stamped.created_at
+ stamped.save
+ assert_not_nil stamped.created_at
+ assert_not_nil stamped.updated_at
+
+ old_updated_at = stamped.updated_at
+
+ sleep 1
+ stamped.save
+ assert_not_equal stamped.created_at, stamped.updated_at
+ assert_not_equal old_updated_at, stamped.updated_at
+
+ end
+
def test_create_turned_off
Mixin.record_timestamps = false
- assert_nil @first.updated_at
- @first.save
- assert_nil @first.updated_at
+ assert_nil @tree_1.updated_at
+ @tree_1.save
+ assert_nil @tree_1.updated_at
Mixin.record_timestamps = true
end