require 'test_helper' class PostTest < ActiveSupport::TestCase setup do @user = FactoryGirl.create(:user) CurrentUser.user = @user CurrentUser.ip_addr = "127.0.0.1" MEMCACHE.flush_all end teardown do CurrentUser.user = nil CurrentUser.ip_addr = nil end context "Deletion:" do context "Annihilating a post" do setup do @post = FactoryGirl.create(:post) end context "that is status locked" do setup do @post.update_attributes({:is_status_locked => true}, :as => :admin) end should "not destroy the record" do @post.annihilate! assert_equal(1, Post.where("id = ?", @post.id).count) end end should "destroy the record" do @post.annihilate! assert_equal([], @post.errors.full_messages) assert_equal(0, Post.where("id = ?", @post.id).count) end end context "Deleting a post" do context "that is status locked" do setup do @post = FactoryGirl.create(:post) @post.update_attributes({:is_status_locked => true}, :as => :admin) end should "fail" do @post.delete! assert_equal(["Is status locked ; cannot delete post"], @post.errors.full_messages) assert_equal(1, Post.where("id = ?", @post.id).count) end end should "update the fast count" do post = FactoryGirl.create(:post, :tag_string => "aaa") assert_equal(1, Post.fast_count) assert_equal(1, Post.fast_count("aaa")) post.delete! assert_equal(0, Post.fast_count) assert_equal(0, Post.fast_count("aaa")) end should "toggle the is_deleted flag" do post = FactoryGirl.create(:post) assert_equal(false, post.is_deleted?) post.delete! assert_equal(true, post.is_deleted?) end should "decrement the tag counts" do post = FactoryGirl.create(:post, :tag_string => "aaa") assert_equal(1, Tag.find_by_name("aaa").post_count) post.delete! assert_equal(0, Tag.find_by_name("aaa").post_count) end end end context "Parenting:" do context "Assignining a parent to a post" do should "update the has_children flag on the parent" do p1 = FactoryGirl.create(:post) assert(!p1.has_children?, "Parent should not have any children") c1 = FactoryGirl.create(:post, :parent_id => p1.id) p1.reload assert(p1.has_children?, "Parent not updated after child was added") end should "update the has_children flag on the old parent" do p1 = FactoryGirl.create(:post) p2 = FactoryGirl.create(:post) c1 = FactoryGirl.create(:post, :parent_id => p1.id) c1.parent_id = p2.id c1.save p1.reload p2.reload assert(!p1.has_children?, "Old parent should not have a child") assert(p2.has_children?, "New parent should have a child") end should "validate that the parent exists" do post = FactoryGirl.build(:post, :parent_id => 1_000_000) post.save assert(post.errors[:parent].any?, "Parent should be invalid") end should "fail if the parent has a parent" do p1 = FactoryGirl.create(:post) c1 = FactoryGirl.create(:post, :parent_id => p1.id) c2 = FactoryGirl.build(:post, :parent_id => c1.id) c2.save assert(c2.errors[:parent].any?, "Parent should be invalid") end end context "Destroying a post with" do context "a parent" do should "reset the has_children flag of the parent" do p1 = FactoryGirl.create(:post) c1 = FactoryGirl.create(:post, :parent_id => p1.id) c1.delete! p1.reload assert_equal(false, p1.has_children?) end should "reassign favorites to the parent" do p1 = FactoryGirl.create(:post) c1 = FactoryGirl.create(:post, :parent_id => p1.id) user = FactoryGirl.create(:user) c1.add_favorite!(user) c1.delete! p1.reload assert(!Favorite.exists?(:post_id => c1.id, :user_id => user.id)) assert(Favorite.exists?(:post_id => p1.id, :user_id => user.id)) end should "update the parent's has_children flag" do p1 = FactoryGirl.create(:post) c1 = FactoryGirl.create(:post, :parent_id => p1.id) c1.delete! p1.reload assert(!p1.has_children?, "Parent should not have children") end end context "one child" do should "remove the has_children flag" do p1 = FactoryGirl.create(:post) c1 = FactoryGirl.create(:post, :parent_id => p1.id) p1.delete! assert_equal(false, p1.has_children?) end should "remove the parent of that child" do p1 = FactoryGirl.create(:post) c1 = FactoryGirl.create(:post, :parent_id => p1.id) p1.delete! c1.reload assert_nil(c1.parent) end end context "two or more children" do should "reparent all children to the first child" do p1 = FactoryGirl.create(:post) c1 = FactoryGirl.create(:post, :parent_id => p1.id) c2 = FactoryGirl.create(:post, :parent_id => p1.id) c3 = FactoryGirl.create(:post, :parent_id => p1.id) p1.delete! c1.reload c2.reload c3.reload assert_nil(c1.parent) assert_equal(c1.id, c2.parent_id) assert_equal(c1.id, c3.parent_id) end end end context "Undestroying a post with a parent" do should "not preserve the parent's has_children flag" do p1 = FactoryGirl.create(:post) c1 = FactoryGirl.create(:post, :parent_id => p1.id) c1.delete! c1.undelete! p1.reload assert_nil(p1.parent_id) assert(!p1.has_children?, "Parent should not have children") end end end context "Moderation:" do context "A deleted post" do setup do @post = FactoryGirl.create(:post, :is_deleted => true) end context "that is status locked" do setup do @post.update_attributes({:is_status_locked => true}, :as => :admin) end should "not allow undeletion" do @post.undelete! assert_equal(["Is status locked ; cannot undelete post"], @post.errors.full_messages) assert_equal(true, @post.is_deleted?) end end should "be undeleted" do @post.undelete! @post.reload assert_equal(false, @post.is_deleted?) end should "be appealed" do assert_difference("PostAppeal.count", 1) do @post.appeal!("xxx") end assert(@post.is_deleted?, "Post should still be deleted") assert_equal(1, @post.appeals.count) end end context "An approved post" do should "be flagged" do post = FactoryGirl.create(:post) assert_difference("PostFlag.count", 1) do post.flag!("bad") end assert(post.is_flagged?, "Post should be flagged.") assert_equal(1, post.flags.count) end should "not be flagged if no reason is given" do post = FactoryGirl.create(:post) assert_difference("PostFlag.count", 0) do assert_raises(PostFlag::Error) do post.flag!("") end end end end context "An unapproved post" do should "preserve the approver's identity when approved" do post = FactoryGirl.create(:post, :is_pending => true) post.approve! assert_equal(post.approver_id, CurrentUser.id) end context "that was uploaded by person X" do setup do @post = FactoryGirl.create(:post) @post.flag!("reason") end should "not allow person X to approve that post" do assert_raises(Post::ApprovalError) do CurrentUser.scoped(@post.uploader, "127.0.0.1") do @post.approve! end end assert_equal(["You cannot approve a post you uploaded"], @post.errors.full_messages) end end context "that was previously approved by person X" do setup do @user = FactoryGirl.create(:janitor_user, :name => "xxx") @user2 = FactoryGirl.create(:janitor_user, :name => "yyy") @post = FactoryGirl.create(:post, :approver_id => @user.id) @post.flag!("bad") end should "not allow person X to reapprove that post" do CurrentUser.scoped(@user, "127.0.0.1") do assert_raises(Post::ApprovalError) do @post.approve! end end end should "allow person Y to approve the post" do CurrentUser.scoped(@user2, "127.0.0.1") do assert_nothing_raised do @post.approve! end end end end context "that has been reapproved" do should "no longer be flagged or pending" do post = FactoryGirl.create(:post) post.flag!("bad") post.approve! assert(post.errors.empty?, post.errors.full_messages.join(", ")) post.reload assert_equal(false, post.is_flagged?) assert_equal(false, post.is_pending?) end end end context "A status locked post" do setup do @post = FactoryGirl.create(:post) @post.update_attributes({:is_status_locked => true}, :as => :admin) end should "not allow new flags" do assert_raises(PostFlag::Error) do @post.flag!("wrong") end end should "not allow new appeals" do assert_raises(PostAppeal::Error) do @post.appeal!("wrong") end end should "not allow approval" do assert_raises(Post::ApprovalError) do @post.approve! end end end end context "Tagging:" do context "A post" do setup do @post = FactoryGirl.create(:post) end context "tagged with a metatag" do context "for a parent" do setup do @parent = FactoryGirl.create(:post) end should "update the parent relationships for both posts" do @post.update_attributes(:tag_string => "aaa parent:#{@parent.id}") @post.reload @parent.reload assert_equal(@parent.id, @post.parent_id) assert(@parent.has_children?) end end context "for a pool" do context "id" do setup do @pool = FactoryGirl.create(:pool) @post.update_attributes(:tag_string => "aaa pool:#{@pool.id}") end should "add the post to the pool" do @post.reload @pool.reload assert_equal("#{@post.id}", @pool.post_ids) assert_equal("pool:#{@pool.id}", @post.pool_string) end end context "name" do context "that exists" do setup do @pool = FactoryGirl.create(:pool, :name => "abc") @post.update_attributes(:tag_string => "aaa pool:abc") end should "add the post to the pool" do @post.reload @pool.reload assert_equal("#{@post.id}", @pool.post_ids) assert_equal("pool:#{@pool.id}", @post.pool_string) end end context "that doesn't exist" do should "create a new pool and add the post to that pool" do @post.update_attributes(:tag_string => "aaa pool:abc") @pool = Pool.find_by_name("abc") @post.reload assert_not_nil(@pool) assert_equal("#{@post.id}", @pool.post_ids) assert_equal("pool:#{@pool.id}", @post.pool_string) end end end end context "for a rating" do context "that is valid" do should "update the rating" do @post.update_attributes(:tag_string => "aaa rating:e") @post.reload assert_equal("e", @post.rating) end end context "that is invalid" do should "not update the rating" do @post.update_attributes(:tag_string => "aaa rating:z") @post.reload assert_equal("q", @post.rating) end end end context "for a fav" do should "add the current user to the post's favorite listing" do @post.update_attributes(:tag_string => "aaa fav:self") @post.reload assert_equal("fav:#{@user.id}", @post.fav_string) end end end should "have an array representation of its tags" do post = FactoryGirl.create(:post) post.set_tag_string("aaa bbb") assert_equal(%w(aaa bbb), post.tag_array) assert_equal(%w(tag1 tag2), post.tag_array_was) end context "that has been updated" do should "increment the updater's post_update_count" do post = FactoryGirl.create(:post, :tag_string => "aaa bbb ccc") assert_difference("CurrentUser.post_update_count", 1) do post.update_attributes(:tag_string => "zzz") CurrentUser.reload end end should "reset its tag array cache" do post = FactoryGirl.create(:post, :tag_string => "aaa bbb ccc") user = FactoryGirl.create(:user) assert_equal(%w(aaa bbb ccc), post.tag_array) post.tag_string = "ddd eee fff" post.tag_string = "ddd eee fff" post.save assert_equal("ddd eee fff", post.tag_string) assert_equal(%w(ddd eee fff), post.tag_array) end should "create the actual tag records" do assert_difference("Tag.count", 3) do post = FactoryGirl.create(:post, :tag_string => "aaa bbb ccc") end end should "update the post counts of relevant tag records" do post1 = FactoryGirl.create(:post, :tag_string => "aaa bbb ccc") post2 = FactoryGirl.create(:post, :tag_string => "bbb ccc ddd") post3 = FactoryGirl.create(:post, :tag_string => "ccc ddd eee") assert_equal(1, Tag.find_by_name("aaa").post_count) assert_equal(2, Tag.find_by_name("bbb").post_count) assert_equal(3, Tag.find_by_name("ccc").post_count) post3.tag_string = "xxx" post3.save assert_equal(1, Tag.find_by_name("aaa").post_count) assert_equal(2, Tag.find_by_name("bbb").post_count) assert_equal(2, Tag.find_by_name("ccc").post_count) assert_equal(1, Tag.find_by_name("ddd").post_count) assert_equal(0, Tag.find_by_name("eee").post_count) assert_equal(1, Tag.find_by_name("xxx").post_count) end should "update its tag counts" do artist_tag = FactoryGirl.create(:artist_tag) copyright_tag = FactoryGirl.create(:copyright_tag) general_tag = FactoryGirl.create(:tag) new_post = FactoryGirl.create(:post, :tag_string => "#{artist_tag.name} #{copyright_tag.name} #{general_tag.name}") assert_equal(1, new_post.tag_count_artist) assert_equal(1, new_post.tag_count_copyright) assert_equal(1, new_post.tag_count_general) assert_equal(0, new_post.tag_count_character) assert_equal(3, new_post.tag_count) new_post.tag_string = "babs" new_post.save assert_equal(0, new_post.tag_count_artist) assert_equal(0, new_post.tag_count_copyright) assert_equal(1, new_post.tag_count_general) assert_equal(0, new_post.tag_count_character) assert_equal(1, new_post.tag_count) end should "merge any changes that were made after loading the initial set of tags part 1" do post = FactoryGirl.create(:post, :tag_string => "aaa bbb ccc") # user a adds post_edited_by_user_a = Post.find(post.id) post_edited_by_user_a.old_tag_string = "aaa bbb ccc" post_edited_by_user_a.tag_string = "aaa bbb ccc ddd" post_edited_by_user_a.save # user b removes adds post_edited_by_user_b = Post.find(post.id) post_edited_by_user_b.old_tag_string = "aaa bbb ccc" post_edited_by_user_b.tag_string = "aaa bbb eee" post_edited_by_user_b.save # final should be , , , final_post = Post.find(post.id) assert_equal(%w(aaa bbb ddd eee), Tag.scan_tags(final_post.tag_string).sort) end should "merge any changes that were made after loading the initial set of tags part 2" do # This is the same as part 1, only the order of operations is reversed. # The results should be the same. post = FactoryGirl.create(:post, :tag_string => "aaa bbb ccc") # user a removes adds post_edited_by_user_a = Post.find(post.id) post_edited_by_user_a.old_tag_string = "aaa bbb ccc" post_edited_by_user_a.tag_string = "aaa bbb eee" post_edited_by_user_a.save # user b adds post_edited_by_user_b = Post.find(post.id) post_edited_by_user_b.old_tag_string = "aaa bbb ccc" post_edited_by_user_b.tag_string = "aaa bbb ccc ddd" post_edited_by_user_b.save # final should be , , , final_post = Post.find(post.id) assert_equal(%w(aaa bbb ddd eee), Tag.scan_tags(final_post.tag_string).sort) end end context "that has been tagged with a metatag" do should "not include the metatag in its tag string" do post = FactoryGirl.create(:post) post.tag_string = "aaa pool:1234 pool:test rating:s fav:bob" post.save assert_equal("aaa", post.tag_string) end end end end context "Favorites:" do context "Removing a post from a user's favorites" do setup do @user = FactoryGirl.create(:user) CurrentUser.user = @user CurrentUser.ip_addr = "127.0.0.1" @post = FactoryGirl.create(:post) @post.add_favorite!(@user) end teardown do CurrentUser.user = nil CurrentUser.ip_addr = nil end should "decrement the user's favorite_count" do assert_difference("CurrentUser.favorite_count", -1) do @post.remove_favorite!(@user) CurrentUser.reload end end should "not decrement the user's favorite_count if the user did not favorite the post" do @post2 = FactoryGirl.create(:post) assert_difference("CurrentUser.favorite_count", 0) do @post2.remove_favorite!(@user) CurrentUser.reload end end end context "Adding a post to a user's favorites" do setup do @user = FactoryGirl.create(:user) CurrentUser.user = @user CurrentUser.ip_addr = "127.0.0.1" @post = FactoryGirl.create(:post) end teardown do CurrentUser.user = nil CurrentUser.ip_addr = nil end should "increment the user's favorite_count" do assert_difference("CurrentUser.favorite_count", 1) do @post.add_favorite!(@user) CurrentUser.reload end end should "update the fav strings ont he post" do @post.add_favorite!(@user) @post.reload assert_equal("fav:#{@user.id}", @post.fav_string) assert(Favorite.exists?(:user_id => @user.id, :post_id => @post.id)) @post.add_favorite!(@user) @post.reload assert_equal("fav:#{@user.id}", @post.fav_string) assert(Favorite.exists?(:user_id => @user.id, :post_id => @post.id)) @post.remove_favorite!(@user) @post.reload assert_equal("", @post.fav_string) assert(!Favorite.exists?(:user_id => @user.id, :post_id => @post.id)) @post.remove_favorite!(@user) @post.reload assert_equal("", @post.fav_string) assert(!Favorite.exists?(:user_id => @user.id, :post_id => @post.id)) end end end context "Pools:" do context "Removing a post from a pool" do should "update the post's pool string" do post = FactoryGirl.create(:post) pool = FactoryGirl.create(:pool) post.add_pool!(pool) post.remove_pool!(pool) post.reload assert_equal("", post.pool_string) post.remove_pool!(pool) post.reload assert_equal("", post.pool_string) end end context "Adding a post to a pool" do should "update the post's pool string" do post = FactoryGirl.create(:post) pool = FactoryGirl.create(:pool) post.add_pool!(pool) post.reload assert_equal("pool:#{pool.id}", post.pool_string) post.add_pool!(pool) post.reload assert_equal("pool:#{pool.id}", post.pool_string) post.remove_pool!(pool) post.reload assert_equal("", post.pool_string) end end end context "Uploading:" do context "Uploading a post" do should "capture who uploaded the post" do post = FactoryGirl.create(:post) user1 = FactoryGirl.create(:user) user2 = FactoryGirl.create(:user) user3 = FactoryGirl.create(:user) post.uploader = user1 assert_equal(user1.id, post.uploader_id) post.uploader_id = user2.id assert_equal(user2.id, post.uploader_id) assert_equal(user2.id, post.uploader_id) assert_equal(user2.name, post.uploader_name) end end end context "Searching:" do should "return posts for 1 tag" do post1 = FactoryGirl.create(:post, :tag_string => "aaa") post2 = FactoryGirl.create(:post, :tag_string => "aaa bbb") post3 = FactoryGirl.create(:post, :tag_string => "bbb ccc") relation = Post.tag_match("aaa") assert_equal(2, relation.count) assert_equal(post2.id, relation.all[0].id) assert_equal(post1.id, relation.all[1].id) end should "return posts for a 2 tag join" do post1 = FactoryGirl.create(:post, :tag_string => "aaa") post2 = FactoryGirl.create(:post, :tag_string => "aaa bbb") post3 = FactoryGirl.create(:post, :tag_string => "bbb ccc") relation = Post.tag_match("aaa bbb") assert_equal(1, relation.count) assert_equal(post2.id, relation.first.id) end should "return posts for 1 tag with exclusion" do post1 = FactoryGirl.create(:post, :tag_string => "aaa") post2 = FactoryGirl.create(:post, :tag_string => "aaa bbb") post3 = FactoryGirl.create(:post, :tag_string => "bbb ccc") relation = Post.tag_match("aaa -bbb") assert_equal(1, relation.count) assert_equal(post1.id, relation.first.id) end should "return posts for 1 tag with a pattern" do post1 = FactoryGirl.create(:post, :tag_string => "aaa") post2 = FactoryGirl.create(:post, :tag_string => "aaab bbb") post3 = FactoryGirl.create(:post, :tag_string => "bbb ccc") relation = Post.tag_match("a*") assert_equal(2, relation.count) assert_equal(post2.id, relation.all[0].id) assert_equal(post1.id, relation.all[1].id) end should "return posts for 2 tags, one with a pattern" do post1 = FactoryGirl.create(:post, :tag_string => "aaa") post2 = FactoryGirl.create(:post, :tag_string => "aaab bbb") post3 = FactoryGirl.create(:post, :tag_string => "bbb ccc") relation = Post.tag_match("a* bbb") assert_equal(1, relation.count) assert_equal(post2.id, relation.first.id) end should "return posts for the metatag" do post1 = FactoryGirl.create(:post) post2 = FactoryGirl.create(:post) post3 = FactoryGirl.create(:post) relation = Post.tag_match("id:#{post2.id}") assert_equal(1, relation.count) assert_equal(post2.id, relation.first.id) relation = Post.tag_match("id:>#{post2.id}") assert_equal(1, relation.count) assert_equal(post3.id, relation.first.id) relation = Post.tag_match("id:<#{post2.id}") assert_equal(1, relation.count) assert_equal(post1.id, relation.first.id) end should "return posts for the metatag" do post1 = FactoryGirl.create(:post) post2 = FactoryGirl.create(:post) post3 = FactoryGirl.create(:post) user = FactoryGirl.create(:user) post1.add_favorite!(user) relation = Post.tag_match("fav:#{user.name}") assert_equal(1, relation.count) assert_equal(post1.id, relation.first.id) end should "return posts for the metatag" do post1 = FactoryGirl.create(:post) post2 = FactoryGirl.create(:post) post3 = FactoryGirl.create(:post) pool = FactoryGirl.create(:pool, :name => "xxx") post1.add_pool!(pool) relation = Post.tag_match("pool:xxx") assert_equal(1, relation.count) assert_equal(post1.id, relation.first.id) end should "return posts for the metatag" do second_user = FactoryGirl.create(:user) post1 = FactoryGirl.create(:post, :uploader => CurrentUser.user) assert_equal(CurrentUser.id, post1.uploader_id) CurrentUser.scoped(second_user, "127.0.0.2") do post2 = FactoryGirl.create(:post) post3 = FactoryGirl.create(:post) end relation = Post.tag_match("user:#{CurrentUser.user.name}") assert_equal(1, relation.count) assert_equal(post1.id, relation.first.id) end should "return posts for a list of md5 hashes" do post1 = FactoryGirl.create(:post, :md5 => "abcd") post2 = FactoryGirl.create(:post) post3 = FactoryGirl.create(:post) relation = Post.tag_match("md5:abcd") assert_equal(1, relation.count) assert_equal(post1.id, relation.first.id) end should "return posts for a source search" do post1 = FactoryGirl.create(:post, :source => "abcd") post2 = FactoryGirl.create(:post, :source => "abcdefg") post3 = FactoryGirl.create(:post, :source => "xyz") relation = Post.tag_match("source:abcde") assert_equal(1, relation.count) assert_equal(post2.id, relation.first.id) end should "return posts for a tag subscription search" do post1 = FactoryGirl.create(:post, :tag_string => "aaa") sub = FactoryGirl.create(:tag_subscription, :tag_query => "aaa", :name => "zzz") TagSubscription.process_all relation = Post.tag_match("sub:#{CurrentUser.name}") assert_equal(1, relation.count) end should "return posts for a particular rating" do post1 = FactoryGirl.create(:post, :rating => "s") post2 = FactoryGirl.create(:post, :rating => "q") post3 = FactoryGirl.create(:post, :rating => "e") relation = Post.tag_match("rating:e") assert_equal(1, relation.count) assert_equal(post3.id, relation.first.id) end should "return posts for a particular negated rating" do post1 = FactoryGirl.create(:post, :rating => "s") post2 = FactoryGirl.create(:post, :rating => "s") post3 = FactoryGirl.create(:post, :rating => "e") relation = Post.tag_match("-rating:s") assert_equal(1, relation.count) assert_equal(post3.id, relation.first.id) end should "return posts ordered by a particular attribute" do post1 = FactoryGirl.create(:post, :rating => "s") post2 = FactoryGirl.create(:post, :rating => "s") post3 = FactoryGirl.create(:post, :rating => "e", :score => 5, :image_width => 1000) relation = Post.tag_match("order:id") assert_equal(post1.id, relation.first.id) relation = Post.tag_match("order:mpixels") assert_equal(post3.id, relation.first.id) relation = Post.tag_match("order:landscape") assert_equal(post3.id, relation.first.id) end should "fail for exclusive tag searches with no other tag" do post1 = FactoryGirl.create(:post, :rating => "s", :tag_string => "aaa") assert_raise(::Post::SearchError) do relation = Post.tag_match("-aaa") end end should "succeed for exclusive tag searches combined with a metatag" do post1 = FactoryGirl.create(:post, :rating => "s", :tag_string => "aaa") assert_nothing_raised do relation = Post.tag_match("-aaa id:>0") end end end context "Voting:" do should "not allow duplicate votes" do user = FactoryGirl.create(:user) post = FactoryGirl.create(:post) CurrentUser.scoped(user, "127.0.0.1") do assert_nothing_raised {post.vote!("up")} assert_raises(PostVote::Error) {post.vote!("up")} post.reload assert_equal(1, PostVote.count) assert_equal(1, post.score) end end end context "Counting:" do context "Creating a post" do should "increment the post count" do assert_equal(0, Post.fast_count("")) post = FactoryGirl.create(:post, :tag_string => "aaa bbb") assert_equal(1, Post.fast_count("")) assert_equal(1, Post.fast_count("aaa")) assert_equal(1, Post.fast_count("bbb")) assert_equal(0, Post.fast_count("ccc")) post.tag_string = "ccc" post.save assert_equal(1, Post.fast_count("")) assert_equal(0, Post.fast_count("aaa")) assert_equal(0, Post.fast_count("bbb")) assert_equal(1, Post.fast_count("ccc")) end end end context "Reverting: " do context "a post that has been updated" do setup do @post = FactoryGirl.create(:post, :rating => "q", :tag_string => "aaa") @post.update_attributes(:tag_string => "aaa bbb ccc ddd") @post.update_attributes(:tag_string => "bbb xxx yyy", :source => "xyz") @post.update_attributes(:tag_string => "bbb mmm yyy", :source => "abc") end context "and then reverted to an early version" do setup do @post.revert_to(@post.versions[1]) end should "correctly revert all fields" do assert_equal("aaa bbb ccc ddd", @post.tag_string) assert_equal(nil, @post.source) assert_equal("q", @post.rating) end end context "and then reverted to a later version" do setup do @post.revert_to(@post.versions[-2]) end should "correctly revert all fields" do assert_equal("bbb xxx yyy", @post.tag_string) assert_equal("xyz", @post.source) assert_equal("q", @post.rating) end end end end end