X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/2ad330d642df0048686f63dc7e86a7dbeb0b30e4..b8f6dbd403507edd14f04f3151c285e232607360:/test/integration/client_application_test.rb diff --git a/test/integration/client_application_test.rb b/test/integration/client_application_test.rb new file mode 100644 index 000000000..0af226085 --- /dev/null +++ b/test/integration/client_application_test.rb @@ -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