X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/416d88101ba0f218952e092da1873026c6f77271..0eb72b526bf8bbb011551ecf019f604e17a534f1:/apps/workbench/test/integration/report_issue_test.rb diff --git a/apps/workbench/test/integration/report_issue_test.rb b/apps/workbench/test/integration/report_issue_test.rb index cf41e23c7e..dc898689e5 100644 --- a/apps/workbench/test/integration/report_issue_test.rb +++ b/apps/workbench/test/integration/report_issue_test.rb @@ -1,13 +1,12 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require 'integration_helper' -require 'selenium-webdriver' -require 'headless' class ReportIssueTest < ActionDispatch::IntegrationTest setup do - headless = Headless.new - headless.start - Capybara.current_driver = :selenium - + need_javascript @user_profile_form_fields = Rails.configuration.user_profile_form_fields end @@ -17,9 +16,9 @@ class ReportIssueTest < ActionDispatch::IntegrationTest # test version info and report issue from help menu def check_version_info_and_report_issue_from_help_menu - within('.navbar-fixed-top') do - page.find("#arv-help").click - within('.dropdown-menu') do + within '.navbar-fixed-top' do + find('.help-menu > a').click + within '.help-menu .dropdown-menu' do assert page.has_link?('Tutorials and User guide'), 'No link - Tutorials and User guide' assert page.has_link?('API Reference'), 'No link - API Reference' assert page.has_link?('SDK Reference'), 'No link - SDK Reference' @@ -37,15 +36,19 @@ class ReportIssueTest < ActionDispatch::IntegrationTest assert page.has_no_text?('Describe the problem?'), 'Found text - Describe the problem' assert page.has_button?('Close'), 'No button - Close' assert page.has_no_button?('Send problem report'), 'Found button - Send problem report' + history_links = all('a').select do |a| + a[:href] =~ %r!^https://arvados.org/projects/arvados/repository/changes\?rev=[0-9a-f]+$! + end + assert_operator(2, :<=, history_links.count, + "Should have found two links to revision history " + + "in #{history_links.inspect}") click_button 'Close' end # check report issue link - within('.navbar-fixed-top') do - page.find("#arv-help").click - within('.dropdown-menu') do - click_link 'Report a problem ...' - end + within '.navbar-fixed-top' do + find('.help-menu > a').click + find('.help-menu .dropdown-menu a', text: 'Report a problem ...').click end within '.modal-content' do @@ -53,15 +56,22 @@ class ReportIssueTest < ActionDispatch::IntegrationTest assert page.has_no_text?('Version / debugging info'), 'Found text - Version / debugging info' assert page.has_text?('Describe the problem'), 'No text - Describe the problem' assert page.has_no_button?('Close'), 'Found button - Close' - assert page.has_button?('Send problem report'), 'No button - Send problem report' + assert page.has_text?('Send problem report'), 'Send problem report button text is not found' + assert page.has_no_button?('Send problem report'), 'Send problem report button is not disabled before entering problem description' assert page.has_button?('Cancel'), 'No button - Cancel' # enter a report text and click on report page.find_field('report_issue_text').set 'my test report text' + assert page.has_button?('Send problem report'), 'Send problem report button not enabled after entering text' + + report = mock + report.expects(:deliver).returns true + IssueReporter.expects(:send_report).returns report + click_button 'Send problem report' # ajax success updated button texts and added footer message - assert page.has_no_button?('Send problem report'), 'Found button - Send problem report' + assert page.has_no_text?('Send problem report'), 'Found button - Send problem report' assert page.has_no_button?('Cancel'), 'Found button - Cancel' assert page.has_text?('Report sent'), 'No text - Report sent' assert page.has_button?('Close'), 'No text - Close' @@ -78,7 +88,8 @@ class ReportIssueTest < ActionDispatch::IntegrationTest ['active', api_fixture('users')['active']], ['admin', api_fixture('users')['admin']], ['active_no_prefs', api_fixture('users')['active_no_prefs']], - ['active_no_prefs_profile', api_fixture('users')['active_no_prefs_profile']], + ['active_no_prefs_profile_no_getting_started_shown', + api_fixture('users')['active_no_prefs_profile_no_getting_started_shown']], ].each do |token, user| test "check version info and report issue for user #{token}" do