导轨|黄瓜| acl9 |拒绝访问
我正在加强 Cucumber,但在通过第一个测试时遇到问题。我得到的例外是:
And I visit the new contract screen
Acl9::AccessDenied (Acl9::AccessDenied)
/usr/local/lib/ruby/1.8/benchmark.rb:308:in `realtime'
(eval):2:in `visit'
./features/step_definitions/manage_contracts_steps.rb:2:in `/^I visit the (.*) screen$/'
features/manage_contracts.feature:15:in `And I visit the new contract screen'
这是我的黄瓜功能...
Background:
Given the following user records
| login | password | name | role |
| bob | secret | Bob | 'PSCM Staff' |
| admin | secret | Frank| admin |
@new
Scenario: Create Contract
When I log in as "bob" with password "secret"
And I visit the new contract screen
Then I should see "Contract Name"
我的steps.rb:
Given /^the following user records$/ do |table|
table.hashes.each do |hash|
role = hash.delete('role')
u = Factory(:user, hash)
u.has_role!(role) if role
end
end
When /^I visit the (.*) screen$/ do |screen|
visit path_to(screen)
end
最后在我的controller.rb中,我有以下access_control块:
before_filter :load_contract, :except => [:cancel_action,:new,:create]
access_control do
allow :admin
allow logged_in, :to => [:index,:show,:log]
allow "PSCM Staff", :to => [:new,:create]
allow :editor, :of => :contract
end
当我从浏览器中明确遵循步骤时,senario工作正常。
抱歉,帖子很长,谢谢!
I am ramping up Cucumber, and I am having a issue getting one of my first tests to pass. The exception I am getting is:
And I visit the new contract screen
Acl9::AccessDenied (Acl9::AccessDenied)
/usr/local/lib/ruby/1.8/benchmark.rb:308:in `realtime'
(eval):2:in `visit'
./features/step_definitions/manage_contracts_steps.rb:2:in `/^I visit the (.*) screen$/'
features/manage_contracts.feature:15:in `And I visit the new contract screen'
Here is my cucumber feature ...
Background:
Given the following user records
| login | password | name | role |
| bob | secret | Bob | 'PSCM Staff' |
| admin | secret | Frank| admin |
@new
Scenario: Create Contract
When I log in as "bob" with password "secret"
And I visit the new contract screen
Then I should see "Contract Name"
My steps.rb:
Given /^the following user records$/ do |table|
table.hashes.each do |hash|
role = hash.delete('role')
u = Factory(:user, hash)
u.has_role!(role) if role
end
end
When /^I visit the (.*) screen$/ do |screen|
visit path_to(screen)
end
Finally in my controller.rb I have the following access_control block:
before_filter :load_contract, :except => [:cancel_action,:new,:create]
access_control do
allow :admin
allow logged_in, :to => [:index,:show,:log]
allow "PSCM Staff", :to => [:new,:create]
allow :editor, :of => :contract
end
The senario works fine when I follow the steps explicitly from the browser.
Sorry for the long post, and thanks!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
我发现了这个问题。万一这对其他人有帮助。问题是在这一行的管道中包含引号
|鲍勃 |秘密|鲍勃 | 'PSCM Staff' |
它应该是
|鲍勃 |秘密|鲍勃 | PSCM 员工 |
I found the issue. In case this helps some one else. The issue was including quotes with in the pipes in this line
| bob | secret | Bob | 'PSCM Staff' |
it should read
| bob | secret | Bob | PSCM Staff |