2012-04-16 18:17:11 +00:00
|
|
|
|
|
|
|
def api_base_url
|
2012-04-24 16:22:35 +00:00
|
|
|
"http://#{@site.domains.first}/locomotive/api/"
|
2012-04-16 18:17:11 +00:00
|
|
|
end
|
|
|
|
|
2012-04-26 19:14:23 +00:00
|
|
|
def do_api_request(type, url, param_string_or_hash = nil)
|
2012-04-17 13:12:42 +00:00
|
|
|
begin
|
2012-04-26 19:14:23 +00:00
|
|
|
if param_string_or_hash
|
|
|
|
if param_string_or_hash.is_a? Hash
|
|
|
|
params = param_string_or_hash
|
|
|
|
else
|
|
|
|
params = JSON.parse(param_string_or_hash)
|
|
|
|
end
|
|
|
|
else
|
|
|
|
params = {}
|
|
|
|
end
|
2012-04-24 16:22:35 +00:00
|
|
|
@json_response = do_request(type, api_base_url, url,
|
|
|
|
params.merge({ 'CONTENT_TYPE' => 'application/json' }))
|
2012-04-26 19:10:40 +00:00
|
|
|
rescue CanCan::AccessDenied
|
2012-04-17 13:12:42 +00:00
|
|
|
@error = $!
|
|
|
|
end
|
2012-04-16 18:17:11 +00:00
|
|
|
end
|
|
|
|
|
2012-04-18 00:07:48 +00:00
|
|
|
def last_json
|
|
|
|
@json_response.try(:body) || page.source
|
|
|
|
end
|
|
|
|
|
|
|
|
Given /^I have an? "([^"]*)" API token$/ do |role|
|
2012-04-16 18:17:11 +00:00
|
|
|
@membership = Locomotive::Site.first.memberships.where(:role => role.downcase).first \
|
|
|
|
|| FactoryGirl.create(role.downcase.to_sym, :site => Locomotive::Site.first)
|
|
|
|
|
|
|
|
login_params = {
|
2012-04-18 00:07:48 +00:00
|
|
|
'email' => @membership.account.email,
|
|
|
|
'password' => 'easyone'
|
2012-04-16 18:17:11 +00:00
|
|
|
}
|
2012-04-18 00:07:48 +00:00
|
|
|
|
2012-04-24 16:22:35 +00:00
|
|
|
response = do_request('POST', api_base_url, 'tokens.json',
|
|
|
|
login_params.merge({ 'CONTENT_TYPE' => 'application/json' }))
|
2012-04-16 18:17:11 +00:00
|
|
|
|
|
|
|
if response.status == 200
|
2012-04-18 00:07:48 +00:00
|
|
|
@auth_token = JSON.parse(response.body)['token']
|
2012-04-16 18:17:11 +00:00
|
|
|
else
|
|
|
|
raise JSON.parse(response.body)['message']
|
|
|
|
end
|
|
|
|
|
2012-04-24 16:22:35 +00:00
|
|
|
add_default_params(:auth_token => @auth_token)
|
2012-04-18 00:07:48 +00:00
|
|
|
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' })
|
2012-04-16 18:17:11 +00:00
|
|
|
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
|
|
|
|
|
2012-04-24 16:22:35 +00:00
|
|
|
Then /^an access denied error should occur$/ do
|
2012-04-17 13:12:42 +00:00
|
|
|
@error.should_not be_nil
|
2012-04-26 19:10:40 +00:00
|
|
|
@error.is_a?(CanCan::AccessDenied).should be_true
|
2012-04-16 18:17:11 +00:00
|
|
|
end
|
2012-04-26 19:14:23 +00:00
|
|
|
|
|
|
|
When /^I do a multipart API (\w+) (?:request )?to ([\w.\/]+) with base key "([^"]*)" and:$/ \
|
|
|
|
do |request_type, url, base_key, table|
|
|
|
|
params = {}
|
|
|
|
params = table.rows_hash
|
|
|
|
params.each do |key, filename|
|
|
|
|
params[key] = Rack::Test::UploadedFile.new(Rails.root.join('..', 'fixtures', filename))
|
|
|
|
end
|
|
|
|
do_api_request(request_type, url, { base_key => params })
|
|
|
|
end
|