X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/192de21f18038794b56a1a0ec95c76e8e0eb1309..03002e6ce2ac4f784f28c0d1b0414f574645b4b8:/apps/workbench/test/integration/logins_test.rb diff --git a/apps/workbench/test/integration/logins_test.rb b/apps/workbench/test/integration/logins_test.rb index 19b6e4bf75..efa5a46214 100644 --- a/apps/workbench/test/integration/logins_test.rb +++ b/apps/workbench/test/integration/logins_test.rb @@ -1,21 +1,24 @@ -require 'test_helper' +require 'integration_helper' class LoginsTest < ActionDispatch::IntegrationTest + setup do + headless = Headless.new + headless.start + Capybara.current_driver = :selenium + end + test "login with api_token works after redirect" do visit page_with_token('active_trustedclient') assert page.has_text?('Recent jobs'), "Missing 'Recent jobs' from page" assert_no_match(/\bapi_token=/, current_path) end - test "can't use expired token" do - visit page_with_token('expired_trustedclient') - assert page.has_text? 'Log in' - end - - test "expired token yields login page, not error page" do + test "trying to use expired token redirects to login page" do visit page_with_token('expired_trustedclient') - # Even the error page has a "Log in" link. We should look for - # something that only appears the real login page. - assert page.has_text? 'log in here with your Google account' + buttons = all("a.btn", text: /Log in/) + assert_equal(1, buttons.size, "Failed to find one login button") + login_link = buttons.first[:href] + assert_match(%r{//[^/]+/login}, login_link) + assert_no_match(/\bapi_token=/, login_link) end end