70 lines
2.2 KiB
Ruby
70 lines
2.2 KiB
Ruby
|
|
def api_base_url
|
|
"http://#{@site.domains.first}/locomotive/api/"
|
|
end
|
|
|
|
def do_api_request(type, url, param_string = nil)
|
|
begin
|
|
params = param_string && JSON.parse(param_string) || {}
|
|
@json_response = do_request(type, api_base_url, url,
|
|
params.merge({ 'CONTENT_TYPE' => 'application/json' }))
|
|
rescue CanCan::AccessDenied
|
|
@error = $!
|
|
end
|
|
end
|
|
|
|
def last_json
|
|
@json_response.try(:body) || page.source
|
|
end
|
|
|
|
Given /^I have an? "([^"]*)" API token$/ do |role|
|
|
@membership = Locomotive::Site.first.memberships.where(:role => role.downcase).first \
|
|
|| FactoryGirl.create(role.downcase.to_sym, :site => Locomotive::Site.first)
|
|
|
|
login_params = {
|
|
'email' => @membership.account.email,
|
|
'password' => 'easyone'
|
|
}
|
|
|
|
response = do_request('POST', api_base_url, 'tokens.json',
|
|
login_params.merge({ 'CONTENT_TYPE' => 'application/json' }))
|
|
|
|
if response.status == 200
|
|
@auth_token = JSON.parse(response.body)['token']
|
|
else
|
|
raise JSON.parse(response.body)['message']
|
|
end
|
|
|
|
add_default_params(:auth_token => @auth_token)
|
|
end
|
|
|
|
Given /^I do not have an API token$/ do
|
|
@auth_token = nil
|
|
end
|
|
|
|
When /^I visit "([^"]*)"$/ do |path|
|
|
@json_response = get("http://#{@site.domains.first}#{path}", { auth_token: @auth_token }, { 'CONTENT_TYPE' => 'application/json' })
|
|
end
|
|
|
|
# http://stackoverflow.com/questions/9009392/racktest-put-method-with-json-fails-to-convert-json-to-params
|
|
When /^I post to "([^"]*)"$/ do |path|
|
|
@json_response = post("http://#{@site.domains.first}#{path}", '', { 'CONTENT_TYPE' => 'application/json' })
|
|
end
|
|
|
|
When /^I post to "([^"]*)" with:$/ do |path, json_string|
|
|
@json_response = post("http://#{@site.domains.first}#{path}", json_string, { 'CONTENT_TYPE' => 'application/json' })
|
|
end
|
|
|
|
When /^I do an API (\w+) (?:request )?to ([\w.\/]+)$/ do |request_type, url|
|
|
do_api_request(request_type, url)
|
|
end
|
|
|
|
When /^I do an API (\w+) (?:request )?to ([\w.\/]+) with:$/ do |request_type, url, param_string|
|
|
do_api_request(request_type, url, param_string)
|
|
end
|
|
|
|
Then /^an access denied error should occur$/ do
|
|
@error.should_not be_nil
|
|
@error.is_a?(CanCan::AccessDenied).should be_true
|
|
end
|