1

我正在尝试测试下面的登录方法,但它似乎没有将 data_provider_user 保存到数据库中。我已经使用调试器进行了检查,它运行良好,直到它离开方法并返回到 rspec 代码,如下所示。我还检查了对象在使用 .valid 保存后是否有效?所以我有点迷路了!

def login
 require 'TwitterOauth'
 @data_provider_user = DataProviderUser.find(params[:id])

 if @data_provider_user.twitter?

  @request_token = TwitterOauth.request_url

  @data_provider_user.access_token = @request_token.token
  @data_provider_user.oauth_token_secret = @request_token.secret

  if @data_provider_user.save
    debugger
    redirect_to @request_token.authorize_url              
  end      

 end
end

测试:

it "should update the tokens" do
    require 'TwitterOauth'
    TwitterOauth.stub(:request_url).and_return(@token)
    debugger
    get :login, {id: @data_provider_user.id}
    debugger
    @data_provider_user.access_token.should_not eq(nil)
    @data_provider_user.oauth_token_secret.should_not eq(nil)
  end

调试器输出:

#<DataProviderUser id: 84, user_id: 63, data_provider_id: 63, username: nil, password: nil, created_at: "2013-02-19 15:21:59", updated_at: "2013-02-19 15:21:59", access_token: nil, update_frequency: nil, oauth_token_secret: nil>

#<DataProviderUser id: 84, user_id: 63, data_provider_id: 63, username: nil, password: nil, created_at: "2013-02-19 15:21:59", updated_at: "2013-02-19 15:22:12", access_token: "186553918-sEAEO2fcvtyO1x99eH4Q4XwVcOYatODCQ5f1TwqD", update_frequency: nil, oauth_token_secret: "gLw2PtUyTZfxIan1gJBnbP7icboXbi98KlUoOn7ycVs">

#<DataProviderUser id: 84, user_id: 63, data_provider_id: 63, username: nil, password: nil, created_at: "2013-02-19 15:21:59", updated_at: "2013-02-19 15:21:59", access_token: nil, update_frequency: nil, oauth_token_secret: nil>

任何帮助将不胜感激!!

- - - 更新 - - - -

代码实际上没有任何问题,问题是 rspec 没有及时重新加载它。解决此问题的一种方法是使用:

@data_provider_user.reload 

在刷新对象之前,相应地更新值。

4

3 回答 3

5

代码实际上没有任何问题,问题是 rspec 没有及时重新加载它。解决此问题的一种方法是使用:

@data_provider_user.reload 

在刷新对象之前,相应地更新值。

于 2013-02-20T10:01:19.690 回答
0

您确定您正在查看正确的数据库吗?当您进行测试时,它可能会myapp_test(myapp 是您所谓的应用程序)。您可能正在查看您的myapp_development数据库。

如果您通过rails db机会访问数据库,那么您将进入您的开发数据库。您可以检查select database();是否使用 MySQL。如果要检查测试数据库,请使用RAILS_ENV=test rails db. 同样,您可以使用 select 语句来验证您是否在正确的数据库中。

于 2013-02-19T16:23:12.330 回答
0

在规范/rails_helper.rb

false设置为use_transactional_fixtures

# If you're not using ActiveRecord, or you'd prefer not to run each of your
# examples within a transaction, remove the following line or assign false
# instead of true.
config.use_transactional_fixtures = false
于 2020-09-17T04:51:08.593 回答