Ok, so to extend this issue, I'm attempting to use mocks and stubs on my model specs. I've got some questions though.. here is my code:
module UserSpecHelper def mock_user(user) @user = mock_model(User) if user == :lance || user == :account_owner @user.stub!(:login).and_return('lance') elsif user == :bob || user == :normal_user @user.stub!(:login).and_return('bob') @user.stub!(:email).and_return('[EMAIL PROTECTED]') @user.stub!(:account).and_return(mock_account(:lances)) end @user end def mock_account(account) @account = mock_model(Account) if account == :lances end @account end end describe "An account owner" do include UserSpecHelper before(:each) do @user = mock_user(:lance) end it "indicate they own the account" do @user.should_receive(:is_account_owner?).and_return(true) @user.is_account_owner?.should be_true end end 1st question: Am I approaching the mocking and stubbing correctly? 2nd question: I feel like I'm not actually testing the is_account_owner? code which I want to do, but can't figure out how to test the implementation. I feel like I want to stub account_id instead of account and have it rely on my model to supply the account method automatically. Where am I going wrong? TIA On 9/4/07, David Chelimsky <[EMAIL PROTECTED]> wrote: > On 9/4/07, Lance Carlson <[EMAIL PROTECTED]> wrote: > > What is the general opinion about fixtures versus mocking and stubbing > > in model specs? I heard from agile on IRC that they save the database > > testing for integration testing, but I also see that the caboose > > sample applicaiton uses fixtures. I also noticed that on the rspec > > site, it says "Ironically (for the traditional TDD'er) these are the > > only specs that we feel should actually interact with the database." > > I wrote that bit - but it doesn't suggest that you should use fixtures > or not. If I'm going to the DB I generally create the model objects I > want right in the examples. > > re: fixtures - the argument against is that they are a pain to > maintain - but there have been some recent developments like > http://code.google.com/p/fixture-scenarios/ that seem promising. > > With the recent addition of Story Runner (in trunk), I'm exploring > more and more the ideas espoused by Jay Fields on his blog re: mocking > declarative API calls to AR (see > http://blog.jayfields.com/2006/12/rails-unit-testing-activerecord.html) > to support super-fast object-level examples in concert w/ end-to-end > examples in Story Runner. > > So you have two separate issues here: > > 1. db or not db > 2. if db, fixtures or not fixtures > > I doubt you'll find general consensus on either question. Good luck! > > Cheers, > David > _______________________________________________ > rspec-users mailing list > rspec-users@rubyforge.org > http://rubyforge.org/mailman/listinfo/rspec-users > _______________________________________________ rspec-users mailing list rspec-users@rubyforge.org http://rubyforge.org/mailman/listinfo/rspec-users