模拟数据库和存根的麻烦:保存

时间:2014-04-18 04:37:26

标签: ruby-on-rails rspec mocking

首先,我是模拟/存根的新手,我在模拟/存根方面遇到了麻烦

这是我的应用程序代码:

describe 'Register an User' do
    VALID_USERNAME = "..."
    VALID_PASSWORD =  "..."
    VALID_USER = User.new(VALID_USERNAME, VALID_PASSWORD)

    before (:each) do
        User.any_instance.stub(:save).and_return(true)
    end

    it 'should create a new user' do
        post :create, :username => VALID_USERNAME, :password => VALID_PASSWORD
        expect(response.status).to eq(201)
        #user_inserted = ...
        #expect(user_inserted).to eq(VALID_USER)
    end
end

def create
        username = params[:username]
        password = params[:password]
        if not username or not password
            render :json => '', :status => 400
        else
            success = User.new(username, password).save
            if success
                render :json => '', :status => 201
            else
                render :json => '', :status => 500
            end
        end
    end

我试图模仿ActiveRecord,测试'创建',而不需要测试' get'。 这里的想法是我打电话给用户。可以在不使用数据库的情况下保存用户,然后我会在我的测试用例中访问,所以我保证用户被插入'在我的数据库上。

如果我进行测试,它会通过,但我没有验证我愿意做什么。任何帮助或想法?

谢谢!

1 个答案:

答案 0 :(得分:1)

这没有意义,因为如果不插入数据库就无法在数据库中测试插入。为什么呢?

Rails带有内置验证,成为保存项目的第一步。如果验证通过,则项目将通过数据库中的ActiveRecord插入。数据库验证从此步骤开始,如果失败,则会引发异常。

因此。如果要测试是否可以在数据库中创建用户,请将验证添加到与数据库匹配的模型中。然后您就可以使用方法is_valid?

这将确保您的用户有效存储在数据库中。因此,您可以在任何地方使用它,因为user_instance.is_valid?定义了一个可插入的项目。

我希望这就是你所要求的。