# vim: ft=cucumber fileencoding=utf-8 sts=4 sw=4 et: Feature: Special qute:// pages Background: Given I open about:blank # :help Scenario: :help without topic When I run :tab-only And I run :help And I wait until qute://help/index.html is loaded Then the following tabs should be open: - qute://help/index.html (active) Scenario: :help with invalid topic When I run :help foo Then the error "Invalid help topic foo!" should be shown Scenario: :help with command When the documentation is up to date And I run :tab-only And I run :help :back And I wait until qute://help/commands.html#back is loaded Then the following tabs should be open: - qute://help/commands.html#back (active) Scenario: :help with invalid command When I run :help :foo Then the error "Invalid command foo!" should be shown Scenario: :help with setting When the documentation is up to date And I run :tab-only And I run :help editor.command And I wait until qute://help/settings.html#editor.command is loaded Then the following tabs should be open: - qute://help/settings.html#editor.command (active) Scenario: :help with -t When I run :tab-only And I run :help -t And I wait until qute://help/index.html is loaded Then the following tabs should be open: - about:blank - qute://help/index.html (active) # https://github.com/qutebrowser/qutebrowser/issues/2513 Scenario: Opening link with qute:help When the documentation is up to date And I run :tab-only And I open qute:help without waiting And I wait for "Changing title for idx 0 to 'qutebrowser help'" in the log And I hint with args "links normal" and follow a Then qute://help/quickstart.html should be loaded Scenario: Opening a link with qute://help When the documentation is up to date And I run :tab-only And I open qute://help without waiting And I wait until qute://help/ is loaded And I hint with args "links normal" and follow a Then qute://help/quickstart.html should be loaded Scenario: Opening a link with qute://help/index.html/.. When the documentation is up to date And I open qute://help/index.html/.. without waiting Then qute://help/ should be loaded Scenario: Opening a link with qute://help/index.html/../ When the documentation is up to date And I open qute://help/index.html/../ without waiting Then qute://help/ should be loaded Scenario: Opening a link with qute://help/img/ When the documentation is up to date And I open qute://help/img/ without waiting Then "*Error while * qute://*" should be logged And "* url='qute://help/img'* LoadStatus.error" should be logged # :history Scenario: :history without arguments When I run :tab-only And I run :history And I wait until qute://history/ is loaded Then the following tabs should be open: - qute://history/ (active) Scenario: :history with -t When I run :tab-only And I run :history -t And I wait until qute://history/ is loaded Then the following tabs should be open: - about:blank - qute://history/ (active) # qute://settings # Sometimes, an unrelated value gets set, which also breaks other tests @skip Scenario: Focusing input fields in qute://settings and entering valid value When I set search.ignore_case to never And I open qute://settings # scroll to the right - the table does not fit in the default screen And I run :scroll-to-perc -x 100 And I run :jseval document.getElementById('input-search.ignore_case').value = '' And I run :click-element id input-search.ignore_case And I wait for "Entering mode KeyMode.insert *" in the log And I press the keys "always" And I press the key "" # an explicit Tab to unfocus the input field seems to stabilize the tests And I press the key "" And I wait for "Config option changed: search.ignore_case *" in the log Then the option search.ignore_case should be set to always # Sometimes, an unrelated value gets set # Too flaky... @skip Scenario: Focusing input fields in qute://settings and entering invalid value When I open qute://settings # scroll to the right - the table does not fit in the default screen And I run :scroll-to-perc -x 100 And I run :jseval document.getElementById('input-search.ignore_case').value = '' And I run :click-element id input-search.ignore_case And I wait for "Entering mode KeyMode.insert *" in the log And I press the keys "foo" And I press the key "" # an explicit Tab to unfocus the input field seems to stabilize the tests And I press the key "" Then "Invalid value 'foo' *" should be logged @qtwebkit_skip Scenario: qute://settings CSRF via img (webengine) When I open data/misc/qutescheme_csrf.html And I run :click-element id via-img Then "Blocking malicious request from http://localhost:*/data/misc/qutescheme_csrf.html to qute://settings/set?*" should be logged @qtwebkit_skip Scenario: qute://settings CSRF via link (webengine) When I open data/misc/qutescheme_csrf.html And I run :click-element id via-link Then "Blocking malicious request from qute://settings/set?* to qute://settings/set?*" should be logged @qtwebkit_skip Scenario: qute://settings CSRF via redirect (webengine) When I open data/misc/qutescheme_csrf.html And I run :click-element id via-redirect Then "Blocking malicious request from qute://settings/set?* to qute://settings/set?*" should be logged @qtwebkit_skip Scenario: qute://settings CSRF via form (webengine) When I open data/misc/qutescheme_csrf.html And I run :click-element id via-form Then "Blocking malicious request from qute://settings/set?* to qute://settings/set?*" should be logged @qtwebkit_skip Scenario: qute://settings CSRF token (webengine) When I open qute://settings And I run :jseval const xhr = new XMLHttpRequest(); xhr.open("GET", "qute://settings/set"); xhr.send() Then "RequestDeniedError while handling qute://* URL" should be logged And the error "Invalid CSRF token for qute://settings!" should be shown @qtwebengine_skip Scenario: qute://settings CSRF via img (webkit) When I open data/misc/qutescheme_csrf.html And I run :click-element id via-img Then "Blocking malicious request from http://localhost:*/data/misc/qutescheme_csrf.html to qute://settings/set?*" should be logged @qtwebengine_skip Scenario: qute://settings CSRF via link (webkit) When I open data/misc/qutescheme_csrf.html And I run :click-element id via-link Then "Blocking malicious request from http://localhost:*/data/misc/qutescheme_csrf.html to qute://settings/set?*" should be logged And "Error while loading qute://settings/set?*: Invalid qute://settings request" should be logged @qtwebengine_skip Scenario: qute://settings CSRF via redirect (webkit) When I open data/misc/qutescheme_csrf.html And I run :click-element id via-redirect Then "Blocking malicious request from http://localhost:*/data/misc/qutescheme_csrf.html to qute://settings/set?*" should be logged And "Error while loading qute://settings/set?*: Invalid qute://settings request" should be logged @qtwebengine_skip Scenario: qute://settings CSRF via form (webkit) When I open data/misc/qutescheme_csrf.html And I run :click-element id via-form Then "Error while loading qute://settings/set?*: Unsupported request type" should be logged # pdfjs support @qtwebengine_skip: pdfjs is not implemented yet Scenario: pdfjs is used for pdf files Given pdfjs is available When I set content.pdfjs to true And I open data/misc/test.pdf Then the javascript message "PDF * [*] (PDF.js: *)" should be logged @qtwebengine_todo: pdfjs is not implemented yet Scenario: pdfjs is not used when disabled When I set content.pdfjs to false And I set downloads.location.prompt to false And I open data/misc/test.pdf Then "Download test.pdf finished" should be logged @qtwebengine_skip: pdfjs is not implemented yet Scenario: Downloading a pdf via pdf.js button (issue 1214) Given pdfjs is available # WORKAROUND to prevent the "Painter ended with 2 saved states" warning # Might be related to https://bugreports.qt.io/browse/QTBUG-13524 and # a weird interaction with the previous test. And I have a fresh instance When I set content.pdfjs to true And I set downloads.location.suggestion to filename And I set downloads.location.prompt to true And I open data/misc/test.pdf And I wait for "[qute://pdfjs/*] PDF * (PDF.js: *)" in the log And I run :jseval document.getElementById("download").click() And I wait for "Asking question text=* title='Save file to:'>, *" in the log And I run :leave-mode Then no crash should happen # :pyeval Scenario: Running :pyeval When I run :debug-pyeval 1+1 And I wait until qute://pyeval/ is loaded Then the page should contain the plaintext "2" Scenario: Causing exception in :pyeval When I run :debug-pyeval 1/0 And I wait until qute://pyeval/ is loaded Then the page should contain the plaintext "ZeroDivisionError" Scenario: Running :pyveal with --file using a file that exists as python code When I run :debug-pyeval --file (testdata)/misc/pyeval_file.py Then the message "Hello World" should be shown And "pyeval output: No error" should be logged Scenario: Running :pyeval --file using a non existing file When I run :debug-pyeval --file nonexistentfile Then the error "[Errno 2] No such file or directory: 'nonexistentfile'" should be shown Scenario: Running :pyeval with --quiet When I run :debug-pyeval --quiet 1+1 Then "pyeval output: 2" should be logged ## :messages Scenario: :messages without level When I run :message-error the-error-message And I run :message-warning the-warning-message And I run :message-info the-info-message And I run :messages Then qute://log/?level=info should be loaded And the error "the-error-message" should be shown And the warning "the-warning-message" should be shown And the page should contain the plaintext "the-error-message" And the page should contain the plaintext "the-warning-message" And the page should contain the plaintext "the-info-message" Scenario: Showing messages of type 'warning' or greater When I run :message-error the-error-message And I run :message-warning the-warning-message And I run :message-info the-info-message And I run :messages warning Then qute://log/?level=warning should be loaded And the error "the-error-message" should be shown And the warning "the-warning-message" should be shown And the page should contain the plaintext "the-error-message" And the page should contain the plaintext "the-warning-message" And the page should not contain the plaintext "the-info-message" Scenario: Showing messages of type 'info' or greater When I run :message-error the-error-message And I run :message-warning the-warning-message And I run :message-info the-info-message And I run :messages info Then qute://log/?level=info should be loaded And the error "the-error-message" should be shown And the warning "the-warning-message" should be shown And the page should contain the plaintext "the-error-message" And the page should contain the plaintext "the-warning-message" And the page should contain the plaintext "the-info-message" @qtwebengine_flaky Scenario: Showing messages of an invalid level When I run :messages cataclysmic Then the error "Invalid log level cataclysmic!" should be shown Scenario: Using qute://log directly When I open qute://log without waiting # With Qt 5.9, we don't get a loaded message? And I wait for "Changing title for idx * to 'log'" in the log Then no crash should happen Scenario: Using qute://plainlog directly When I open qute://plainlog Then no crash should happen # :version Scenario: Open qute://version When I open qute://version Then the page should contain the plaintext "Version info" # qute://gpl Scenario: Open qute://gpl When I open qute://gpl Then the page should contain the plaintext "GNU GENERAL PUBLIC LICENSE"