spec/memento/state_spec.rb in memento-0.4.0 vs spec/memento/state_spec.rb in memento-0.4.1

- old
+ new

@@ -3,38 +3,48 @@ describe Memento::State do before do setup_db setup_data - @session = Memento::Session.create(:user => @user) + @session = Memento::Session.create({:user => @user}, :without_protection => true) end it "should belong to session" do - Memento::State.new(:session => @session).session.should eql(@session) + Memento::State.new({:session => @session}, :without_protection => true).session.should eql(@session) end it "should require session" do Memento::State.create.errors[:session].should eql(["can't be blank"]) end it "should require action_type to be one of Memento::State::RECORD_CAUSES" do Memento::State.create.errors[:action_type].should eql(["can't be blank"]) - Memento::State.create(:action_type => "move").errors[:action_type].should eql(["is not included in the list"]) + Memento::State.create({:action_type => "move"}, :without_protection => true).errors[:action_type].should eql(["is not included in the list"]) end it "should belong to polymorphic record" do - Memento::State.new(:record => @user).record.should eql(@user) - Memento::State.new(:record => @session).record.should eql(@session) + Memento::State.new({:record => @user}, :without_protection => true).record.should eql(@user) + Memento::State.new({:record => @session}, :without_protection => true).record.should eql(@session) end it "should require record" do Memento::State.create.errors[:record].should eql(["can't be blank"]) end + it "should disallow all mass assignment" do + Memento::State.accessible_attributes.deny?("id").should eql(true) + Memento::State.accessible_attributes.deny?("created_at").should eql(true) + Memento::State.accessible_attributes.deny?("updated_at").should eql(true) + Memento::State.accessible_attributes.deny?("session_id").should eql(true) + Memento::State.accessible_attributes.deny?("session").should eql(true) + Memento::State.accessible_attributes.deny?("record_id").should eql(true) + Memento::State.accessible_attributes.deny?("record_type").should eql(true) + Memento::State.accessible_attributes.deny?("record").should eql(true) + end describe "valid State" do before do - @state = @session.states.create!(:action_type => "destroy", :record => @project = Project.create(:name => "A") ) + @state = @session.states.create!({:action_type => "destroy", :record => @project = Project.create(:name => "A")}, :without_protection => true ) end it "should give back Memento::Result on undo" do result = @state.undo result.should be_a(Memento::Result) \ No newline at end of file