When I want to test if attribute is / is not accessible with RSpec I'm doing it like this
class Foo
attr_accesible :something_else
end
describe Foo do
it('author should not be accessible') {lambda{described_class.new(:author=>true)}.should raise_error ActiveModel::MassAssignmentSecurity::Error}
it('something_else should be accessible'){lambda{described_class.new(:something_else=>true)}.should_not raise_error ActiveModel::MassAssignmentSecurity::Error}
end
is there better way doing that ?
...thx
This is the way attribute accessibility tests are done in the Rails Tutorial, which I think are pretty good. So, in your case, the test code could be modified slightly to read like:
If this isn't what you were looking for, can you give us a better idea of what kind of solution you're after when you ask if there is a "better way"?
Edit
You may be interested in the Shoulda ActiveModel matchers, which would clean up the code to just one line per test. Something like: