X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/0026484279e78edb42a01bc493f8014c4a647f8d..60501a83ead2f3c71144d3af842e714cb3f91000:/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 0ec91aac31..32f16a68df 100644 --- a/apps/workbench/test/integration/errors_test.rb +++ b/apps/workbench/test/integration/errors_test.rb @@ -1,6 +1,10 @@ require 'integration_helper' class ErrorsTest < ActionDispatch::IntegrationTest + setup do + need_javascript + end + BAD_UUID = "ffffffffffffffffffffffffffffffff+0" test "error page renders user navigation" do @@ -59,4 +63,66 @@ class ErrorsTest < ActionDispatch::IntegrationTest 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 + original_arvados_v1_base = Rails.configuration.arvados_v1_base + + begin + # point to a bad api server url to generate fiddlesticks error + Rails.configuration.arvados_v1_base = "https://[100::f]: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' + ensure + Rails.configuration.arvados_v1_base = original_arvados_v1_base + end + end end