如果您已成功测试发布,放置和删除受到doorkeeper OAuth2提供程序gem保护的Rails API的http方法,请分享,我会给你爱。rspec在rails api上测试红宝石保护与门卫
doorkeeper wiki documentation和sample application很好地展示了如何测试get方法。我成功地测试了一个类似于使用Capybara测试驱动程序和Cucumber的文章。无法测试从put或delete路由的任何API。无法使用rspec测试进行发布。
@user = create :user
@client = create(:oauth_application)
@token = create(:oauth_token, :application => @client, :resource_owner_id => @user)
json_for_new_entry = {
date_attr: Time.now.to_date,
decimal_attr: '1.1',
string_attr: 'oath2, you make me blue',
bool_attr: false,
int_attr: 1
}.to_json
page.driver.header 'Authorization', "Bearer #{@token.token}"
page.driver.post api_entry_path, json_for_new_entry,
'CONTENT_TYPE' => 'application/json'
的工厂都没有什么特别的:
factory :user, :class => User do |user|
sequence :email do |n| "user#{n}@example.com" end
pwd = "password"
password pwd
end
factory :oauth_application, :class => Doorkeeper::Application do
sequence(:name) { |n| "application_name_#{n}" }
#redirect_uri 'urn:ietf:wg:oauth:2.0:oob'
redirect_uri 'http://localhost:3000/'
end
factory :oauth_token, :class => Doorkeeper::AccessToken do
association :application, :factory => :oauth_application
association :resource_owner_id, :factory => :user
end
我的环境是有点落后了最新版本:
- 在3.1.12
- 水豚2.2.0 轨宝石
- 黄瓜1.3.10
- 设计2.2.7
- 区长1.2.3
- 看门0.7.4
- rspec的核2.14.5
- rspec的-期望2.14.3
- rspec的-嘲笑2.14.3
- rspec的-rails 2.14.0
谢谢。它会起作用,但我并不是疯狂地在生产代码中加入特殊情况来测试它。我希望得到的答案将是独立于应用程序的测试代码。 Upvote,因为它会解决问题并进行测试。谢谢你的答案。 –