Adding initial version of the OAuth token authentication method. This adds basic OAuth support for registering apps, getting and revoking keys, etc... The tokens come with 6 separate permissions bits; read/write user preferences, write diaries, write API and read/write GPS traces. Needs more tests.
This commit is contained in:
parent
2ad330d642
commit
b8f6dbd403
85 changed files with 3277 additions and 9 deletions
75
test/integration/client_application_test.rb
Normal file
75
test/integration/client_application_test.rb
Normal file
|
@ -0,0 +1,75 @@
|
|||
require File.dirname(__FILE__) + '/../test_helper'
|
||||
|
||||
class ClientApplicationTest < ActionController::IntegrationTest
|
||||
fixtures :users, :client_applications
|
||||
|
||||
##
|
||||
# run through the procedure of creating a client application and checking
|
||||
# that it shows up on the user's account page.
|
||||
def test_create_application
|
||||
post '/login', {'user[email]' => "test@example.com", 'user[password]' => "test", :referer => '/user/test/account'}
|
||||
assert_response :redirect
|
||||
follow_redirect!
|
||||
assert_response :success
|
||||
assert_template 'user/account'
|
||||
|
||||
# check that the form to allow new client application creations exists
|
||||
assert_in_body do
|
||||
assert_select "h2", "Application Developers"
|
||||
assert_select "a[href='/oauth_clients/new']"
|
||||
end
|
||||
|
||||
# now we follow the link to the new oauth client page
|
||||
get '/oauth_clients/new'
|
||||
assert_response :success
|
||||
assert_in_body do
|
||||
assert_select "h1", "Register a new application"
|
||||
assert_select "form[action='/oauth_clients']" do
|
||||
[ :name, :url, :callback_url, :support_url ].each do |inp|
|
||||
assert_select "input[name=?]", "client_application[#{inp}]"
|
||||
end
|
||||
ClientApplication.all_permissions.each do |perm|
|
||||
assert_select "input[name=?]", "client_application[#{perm}]"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
post '/oauth_clients', {
|
||||
'client_application[name]' => 'My New App',
|
||||
'client_application[url]' => 'http://my.new.app.org/',
|
||||
'client_application[callback_url]' => 'http://my.new.app.org/callback',
|
||||
'client_application[support_url]' => 'http://my.new.app.org/support'}
|
||||
assert_response :redirect
|
||||
follow_redirect!
|
||||
assert_response :success
|
||||
assert_template 'oauth_clients/show'
|
||||
assert_equal 'Registered the information successfully', flash[:notice]
|
||||
|
||||
# now go back to the account page and check its listed under this user
|
||||
get '/user/test/account'
|
||||
assert_response :success
|
||||
assert_template 'user/account'
|
||||
assert_in_body { assert_select "li>div>a", "My New App" }
|
||||
end
|
||||
|
||||
##
|
||||
# fake client workflow.
|
||||
# this acts like a 3rd party client trying to access the site.
|
||||
def test_3rd_party_token
|
||||
# apparently the oauth gem doesn't really support being used inside integration
|
||||
# tests, as its too tied into the HTTP headers and stuff that it signs.
|
||||
end
|
||||
|
||||
##
|
||||
# utility method to make the HTML screening easier to read.
|
||||
def assert_in_body
|
||||
assert_select "html:root" do
|
||||
assert_select "body" do
|
||||
assert_select "div#content" do
|
||||
yield
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue