X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/676dfa352dbf55a23e0123b47d1affe33c028908..040fdf6da00318b5b8e8e83eceeec783680ecb1c:/apps/workbench/test/integration/errors_test.rb diff --git a/apps/workbench/test/integration/errors_test.rb b/apps/workbench/test/integration/errors_test.rb index 092041d512..d2b8fd6fab 100644 --- a/apps/workbench/test/integration/errors_test.rb +++ b/apps/workbench/test/integration/errors_test.rb @@ -1,19 +1,123 @@ require 'integration_helper' class ErrorsTest < ActionDispatch::IntegrationTest - BAD_UUID = "zzzzz-zzzzz-zzzzzzzzzzzzzzz" + setup do + need_javascript + end + + BAD_UUID = "ffffffffffffffffffffffffffffffff+0" test "error page renders user navigation" do visit(page_with_token("active", "/collections/#{BAD_UUID}")) - assert(page.has_text?(@@API_AUTHS["active"]["email"]), + assert(page.has_text?(api_fixture("users")["active"]["email"]), "User information missing from error page") assert(page.has_no_text?(/log ?in/i), "Logged in user prompted to log in on error page") end + test "no user navigation with expired token" do + visit(page_with_token("expired", "/collections/#{BAD_UUID}")) + assert(page.has_no_text?(api_fixture("users")["active"]["email"]), + "Page visited with expired token included user information") + assert(page.has_selector?("a", text: /log ?in/i), + "Login prompt missing on expired token error page") + end + test "error page renders without login" do visit "/collections/download/#{BAD_UUID}/#{@@API_AUTHS['active']['api_token']}" assert(page.has_no_text?(/\b500\b/), "Error page without login returned 500") end + + test "'object not found' page includes search link" do + visit(page_with_token("active", "/collections/#{BAD_UUID}")) + assert(all("a").any? { |a| a[:href] =~ %r{/collections/?(\?|$)} }, + "no search link found on 404 page") + end + + def now_timestamp + Time.now.utc.to_i + end + + def page_has_error_token?(start_stamp) + matching_stamps = (start_stamp .. now_timestamp).to_a.join("|") + # Check the page HTML because we really don't care how it's presented. + # I think it would even be reasonable to put it in a comment. + page.html =~ /\b(#{matching_stamps})\+[0-9A-Fa-f]{8}\b/ + end + + # We use API tokens with limited scopes as the quickest way to get the API + # server to return an error. If Workbench gets smarter about coping when + # it has a too-limited token, these tests will need to be adjusted. + test "API error page includes error token" do + start_stamp = now_timestamp + visit(page_with_token("active_readonly", "/authorized_keys")) + click_on "Add a new authorized key" + assert(page.has_text?(/fiddlesticks/i), + "Not on an error page after making an SSH key out of scope") + assert(page_has_error_token?(start_stamp), "no error token on 404 page") + end + + test "showing a bad UUID returns 404" do + visit(page_with_token("active", "/pipeline_templates/zzz")) + assert(page.has_no_text?(/fiddlesticks/i), + "trying to show a bad UUID rendered a fiddlesticks page, not 404") + end + + test "404 page includes information about missing object" do + visit(page_with_token("active", "/groups/zazazaz")) + assert(page.has_text?(/group with UUID zazazaz/i), + "name of searched group missing from 404 page") + end + + test "unrouted 404 page works" do + visit(page_with_token("active", "/__asdf/ghjk/zxcv")) + assert(page.has_text?(/not found/i), + "unrouted page missing 404 text") + assert(page.has_no_text?(/fiddlesticks/i), + "unrouted request returned a generic error page, not 404") + end + + test "API error page has Report problem button" do + # point to a bad api server url to generate fiddlesticks error + original_arvados_v1_base = Rails.configuration.arvados_v1_base + Rails.configuration.arvados_v1_base = "https://[::1]:1/" + + visit page_with_token("active") + + assert_text 'fiddlesticks' + + # reset api server base config to let the popup rendering to work + Rails.configuration.arvados_v1_base = original_arvados_v1_base + + click_link 'Report problem' + + within '.modal-content' do + assert_text 'Report a problem' + assert_no_text 'Version / debugging info' + assert_text 'Describe the problem' + assert_text 'Send problem report' + # "Send" button should be disabled until text is entered + assert_no_selector 'a,button:not([disabled])', text: 'Send problem report' + assert_selector 'a,button', text: 'Cancel' + + report = mock + report.expects(:deliver).returns true + IssueReporter.expects(:send_report).returns report + + # enter a report text and click on report + find_field('report_issue_text').set 'my test report text' + click_button 'Send problem report' + + # ajax success updated button texts and added footer message + assert_no_selector 'a,button', text: 'Send problem report' + assert_no_selector 'a,button', text: 'Cancel' + assert_text 'Report sent' + assert_text 'Thanks for reporting this issue' + click_button 'Close' + end + + # out of the popup now and should be back in the error page + assert_text 'fiddlesticks' + end end