# vim: ft=cucumber fileencoding=utf-8 sts=4 sw=4 et: Feature: Various utility commands. ## :set-cmd-text Scenario: :set-cmd-text and :command-accept When I run :set-cmd-text :message-info "Hello World" And I run :command-accept Then the message "Hello World" should be shown Scenario: :set-cmd-text and :command-accept --rapid When I run :set-cmd-text :message-info "Hello World" And I run :command-accept --rapid And I run :command-accept Then the message "Hello World" should be shown And the message "Hello World" should be shown Scenario: :set-cmd-text with two commands When I run :set-cmd-text :message-info test ;; message-error error And I run :command-accept Then the message "test" should be shown And the error "error" should be shown Scenario: :set-cmd-text with URL replacement When I open data/hello.txt And I run :set-cmd-text :message-info {url} And I run :command-accept Then the message "http://localhost:*/hello.txt" should be shown Scenario: :set-cmd-text with URL replacement with encoded spaces When I open data/title with spaces.html And I run :set-cmd-text :message-info {url} And I run :command-accept Then the message "http://localhost:*/title%20with%20spaces.html" should be shown Scenario: :set-cmd-text with URL replacement with decoded spaces When I open data/title with spaces.html And I run :set-cmd-text :message-info "> {url:pretty} <" And I run :command-accept Then the message "> http://localhost:*/title with spaces.html <" should be shown Scenario: :set-cmd-text with -s and -a When I run :set-cmd-text -s :message-info "foo And I run :set-cmd-text -a bar" And I run :command-accept Then the message "foo bar" should be shown Scenario: :set-cmd-text with -a but without text When I run :set-cmd-text -a foo Then the error "No current text!" should be shown Scenario: :set-cmd-text with invalid command When I run :set-cmd-text foo Then the error "Invalid command text 'foo'." should be shown Scenario: :set-cmd-text with run on count flag and no count When I run :set-cmd-text --run-on-count :message-info "Hello World" Then "message:info:86 Hello World" should not be logged Scenario: :set-cmd-text with run on count flag and a count When I run :set-cmd-text --run-on-count :message-info "Hello World" with count 1 Then the message "Hello World" should be shown ## :jseval Scenario: :jseval When I run :jseval console.log("Hello from JS!"); And I wait for the javascript message "Hello from JS!" Then the message "No output or error" should be shown Scenario: :jseval without logging When I set content.javascript.log to {"unknown": "none", "info": "none", "warning": "debug", "error": "debug"} And I run :jseval console.log("Hello from JS!"); And I wait for "No output or error" in the log And I set content.javascript.log to {"unknown": "debug", "info": "debug", "warning": "debug", "error": "debug"} Then "[:*] Hello from JS!" should not be logged Scenario: :jseval with --quiet When I run :jseval --quiet console.log("Hello from JS!"); And I wait for the javascript message "Hello from JS!" Then "No output or error" should not be logged Scenario: :jseval with a value When I run :jseval "foo" Then the message "foo" should be shown Scenario: :jseval with a long, truncated value When I run :jseval Array(5002).join("x") Then the message "x* [...trimmed...]" should be shown @qtwebengine_skip Scenario: :jseval with --world on QtWebKit When I run :jseval --world=1 console.log("Hello from JS!"); And I wait for the javascript message "Hello from JS!" Then "Ignoring world ID 1" should be logged And "No output or error" should be logged @qtwebkit_skip Scenario: :jseval uses separate world without --world When I open data/misc/jseval.html And I run :jseval do_log() Then the javascript message "Hello from the page!" should not be logged And the javascript message "Uncaught ReferenceError: do_log is not defined" should be logged And "No output or error" should be logged @qtwebkit_skip Scenario: :jseval using the main world When I open data/misc/jseval.html And I run :jseval --world 0 do_log() Then the javascript message "Hello from the page!" should be logged And "No output or error" should be logged @qtwebkit_skip Scenario: :jseval using the main world as name When I open data/misc/jseval.html And I run :jseval --world main do_log() Then the javascript message "Hello from the page!" should be logged And "No output or error" should be logged @qtwebkit_skip Scenario: :jseval using too high of a world When I run :jseval --world=257 console.log("Hello from JS!"); Then the error "World ID should be between 0 and *" should be shown @qtwebkit_skip Scenario: :jseval using a negative world id When I run :jseval --world=-1 console.log("Hello from JS!"); Then the error "World ID should be between 0 and *" should be shown Scenario: :jseval --file using a file that exists as js-code When I run :jseval --file (testdata)/misc/jseval_file.js Then the javascript message "Hello from JS!" should be logged And the javascript message "Hello again from JS!" should be logged And "No output or error" should be logged Scenario: :jseval --file using a file that doesn't exist as js-code When I run :jseval --file /nonexistentfile Then the error "[Errno 2] No such file or directory: '/nonexistentfile'" should be shown And "No output or error" should not be logged # :debug-webaction Scenario: :debug-webaction with valid value Given I open data/backforward/1.txt When I open data/backforward/2.txt And I run :tab-only And I run :debug-webaction Back And I wait until data/backforward/1.txt is loaded Then the session should look like: windows: - tabs: - history: - active: true url: http://localhost:*/data/backforward/1.txt - url: http://localhost:*/data/backforward/2.txt Scenario: :debug-webaction with invalid value When I open data/hello.txt And I run :debug-webaction blah Then the error "blah is not a valid web action!" should be shown Scenario: :debug-webaction with non-webaction member When I open data/hello.txt And I run :debug-webaction PermissionUnknown Then the error "PermissionUnknown is not a valid web action!" should be shown # :inspect @qtwebkit_skip @qt<5.11 Scenario: Inspector without --enable-webengine-inspector When I run :inspector Then the error "QtWebEngine inspector is not enabled. See 'qutebrowser --help' for details." should be shown @no_xvfb @posix @qtwebengine_skip Scenario: Inspector smoke test When I run :inspector And I wait for "Focus object changed: " in the log And I run :inspector And I wait for "Focus object changed: *" in the log Then no crash should happen # Different code path as an inspector got created now @no_xvfb @posix @qtwebengine_skip Scenario: Inspector smoke test 2 When I run :inspector And I wait for "Focus object changed: " in the log And I run :inspector And I wait for "Focus object changed: *" in the log Then no crash should happen # :stop/:reload @flaky Scenario: :stop Given I have a fresh instance # We can't use "When I open" because we don't want to wait for load # finished When I run :open http://localhost:(port)/redirect-later?delay=-1 And I wait for "emitting: cur_load_status_changed() (tab *)" in the log And I wait 1s And I run :stop And I open redirect-later-continue in a new tab And I wait 1s Then the unordered requests should be: redirect-later-continue redirect-later?delay=-1 # no request on / because we stopped the redirect Scenario: :stop with wrong count When I open data/hello.txt And I run :tab-only And I run :stop with count 2 Then no crash should happen Scenario: :reload When I open data/reload.txt And I run :reload And I wait until data/reload.txt is loaded Then the requests should be: data/reload.txt data/reload.txt Scenario: :reload with force When I open headers And I run :reload --force And I wait until headers is loaded Then the header Cache-Control should be set to no-cache Scenario: :reload with wrong count When I open data/hello.txt And I run :tab-only And I run :reload with count 2 Then no crash should happen # :view-source # Flaky due to :view-source being async? @qtwebengine_flaky Scenario: :view-source Given I open data/hello.txt When I run :tab-only And I run :view-source Then the session should look like: windows: - tabs: - history: - active: true url: http://localhost:*/data/hello.txt - active: true history: [] And the page should contain the html "/* Literal.Number.Integer */" # Flaky due to :view-source being async? @qtwebengine_flaky Scenario: :view-source on source page. When I open data/hello.txt And I run :view-source And I run :view-source Then the error "Already viewing source!" should be shown # :home Scenario: :home with single page When I set url.start_pages to ["http://localhost:(port)/data/hello2.txt"] And I run :home Then data/hello2.txt should be loaded Scenario: :home with multiple pages When I set url.start_pages to ["http://localhost:(port)/data/numbers/1.txt", "http://localhost:(port)/data/numbers/2.txt"] And I run :home Then data/numbers/1.txt should be loaded # :print # Disabled because it causes weird segfaults and QPainter warnings in Qt... @xfail_norun Scenario: print preview When I open data/hello.txt And I run :print --preview And I wait for "Focus object changed: *" in the log And I run :debug-pyeval QApplication.instance().activeModalWidget().close() Then no crash should happen # On Windows/macOS, we get a "QPrintDialog: Cannot be used on non-native # printers" qWarning. # # Disabled because it causes weird segfaults and QPainter warnings in Qt... @xfail_norun Scenario: print When I open data/hello.txt And I run :print And I wait for "Focus object changed: *" in the log or skip the test And I run :debug-pyeval QApplication.instance().activeModalWidget().close() Then no crash should happen # FIXME:qtwebengine use a finer skipping here @qtwebengine_skip: printing to pdf is not implemented with older Qt versions Scenario: print --pdf When I open data/hello.txt And I run :print --pdf (tmpdir)/hello.pdf And I wait for "Print to file: *" in the log or skip the test Then the PDF hello.pdf should exist in the tmpdir ## https://github.com/qutebrowser/qutebrowser/issues/504 Scenario: Focusing download widget via Tab When I open about:blank And I press the key "" And I press the key "" Then no crash should happen @js_prompt Scenario: Focusing download widget via Tab (original issue) When I open data/prompt/jsprompt.html And I run :click-element id button And I wait for "Entering mode KeyMode.prompt *" in the log And I press the key "" And I press the key "" And I run :leave-mode Then no crash should happen ## Custom headers Scenario: Setting a custom header When I set content.headers.custom to {"X-Qute-Test": "testvalue"} And I open headers Then the header X-Qute-Test should be set to testvalue Scenario: DNT header When I set content.headers.do_not_track to true And I open headers Then the header Dnt should be set to 1 Scenario: DNT header (off) When I set content.headers.do_not_track to false And I open headers Then the header Dnt should be set to 0 Scenario: DNT header (unset) When I set content.headers.do_not_track to And I open headers Then the header Dnt should be set to Scenario: Accept-Language header When I set content.headers.accept_language to en,de And I open headers Then the header Accept-Language should be set to en,de # This still doesn't set window.navigator.language # See https://bugreports.qt.io/browse/QTBUG-61949 @qtwebkit_skip Scenario: Accept-Language header (JS) When I set content.headers.accept_language to it,fr And I run :jseval console.log(window.navigator.languages) Then the javascript message "it,fr" should be logged Scenario: Setting a custom user-agent header When I set content.headers.user_agent to toaster And I open headers And I run :jseval console.log(window.navigator.userAgent) Then the header User-Agent should be set to toaster And the javascript message "toaster" should be logged Scenario: Setting the default user-agent header When I set content.headers.user_agent to And I open headers And I run :jseval console.log(window.navigator.userAgent) Then the header User-Agent should be set to Mozilla/5.0 * And the javascript message "Mozilla/5.0 *" should be logged ## https://github.com/qutebrowser/qutebrowser/issues/1523 Scenario: Completing a single option argument When I run :set-cmd-text -s :-- Then no crash should happen ## https://github.com/qutebrowser/qutebrowser/issues/1386 Scenario: Partial commandline matching with startup command When I run :message-i "Hello World" (invalid command) Then the error "message-i: no such command" should be shown Scenario: Multiple leading : in command When I run :::::set-cmd-text ::::message-i "Hello World" And I run :command-accept Then the message "Hello World" should be shown Scenario: Whitespace in command When I run : : set-cmd-text : : message-i "Hello World" And I run :command-accept Then the message "Hello World" should be shown # We can't run :message-i as startup command, so we use # :set-cmd-text Scenario: Partial commandline matching When I run :set-cmd-text :message-i "Hello World" And I run :command-accept Then the message "Hello World" should be shown @no_xvfb Scenario: :window-only Given I run :tab-only And I open data/hello.txt When I open data/hello2.txt in a new tab And I open data/hello3.txt in a new window And I run :window-only And I wait for "Closing window *" in the log And I wait for "removed: main-window" in the log Then the session should look like: windows: - tabs: - active: true history: - url: http://localhost:*/data/hello3.txt ## Variables Scenario: {url} as part of an argument When I open data/hello.txt And I run :message-info foo{url} Then the message "foohttp://localhost:*/hello.txt" should be shown Scenario: Multiple variables in an argument When I open data/hello.txt And I put "foo" into the clipboard And I run :message-info {clipboard}bar{url} Then the message "foobarhttp://localhost:*/hello.txt" should be shown Scenario: escaping {{url}} variable When I open data/hello.txt And I run :message-info foo{{url}}bar Then the message "foo{url}bar" should be shown @xfail_norun Scenario: {url} in clipboard should not be expanded When I open data/hello.txt # FIXME: {url} should be escaped, otherwise it is replaced before it enters clipboard And I put "{url}" into the clipboard And I run :message-info {clipboard}bar{url} Then the message "{url}barhttp://localhost:*/hello.txt" should be shown ## :click-element Scenario: Clicking an element with unknown ID When I open data/click_element.html And I run :click-element id blah Then the error "No element found with id blah!" should be shown Scenario: Clicking an element by ID When I open data/click_element.html And I run :click-element id qute-input Then "Entering mode KeyMode.insert (reason: clicking input)" should be logged Scenario: Clicking an element by ID with dot When I open data/click_element.html And I run :click-element id foo.bar Then the javascript message "id with dot" should be logged Scenario: Clicking an element with tab target When I open data/click_element.html And I run :tab-only And I run :click-element id link --target=tab Then data/hello.txt should be loaded And the following tabs should be open: - data/click_element.html - data/hello.txt (active) ## :command-history-{prev,next} Scenario: Calling previous command When I run :set-cmd-text :message-info blah And I run :command-accept And I wait for "blah" in the log And I run :set-cmd-text : And I run :command-history-prev And I run :command-accept Then the message "blah" should be shown Scenario: Calling previous command with :completion-item-focus When I run :set-cmd-text :message-info blah And I wait for "Entering mode KeyMode.command (reason: *)" in the log And I run :command-accept And I wait for "blah" in the log And I run :set-cmd-text : And I wait for "Entering mode KeyMode.command (reason: *)" in the log And I run :completion-item-focus prev --history And I run :command-accept Then the message "blah" should be shown Scenario: Browsing through commands When I run :set-cmd-text :message-info blarg And I run :command-accept And I wait for "blarg" in the log And I run :set-cmd-text : And I run :command-history-prev And I run :command-history-prev And I run :command-history-next And I run :command-history-next And I run :command-accept Then the message "blarg" should be shown Scenario: Calling previous command when history is empty Given I have a fresh instance When I run :set-cmd-text : And I run :command-history-prev And I run :command-accept Then the error "No command given" should be shown Scenario: Calling next command when there's no next command When I run :set-cmd-text : And I run :command-history-next And I run :command-accept Then the error "No command given" should be shown ## Modes blacklisted for :enter-mode Scenario: Trying to enter command mode with :enter-mode When I run :enter-mode command Then the error "Mode command can't be entered manually!" should be shown ## Renderer crashes # Skipped on Windows as "... has stopped working" hangs. @qtwebkit_skip @no_invalid_lines @posix @qt<5.9 Scenario: Renderer crash When I run :open -t chrome://crash Then the error "Renderer process crashed" should be shown @qtwebkit_skip @no_invalid_lines @qt<5.9 Scenario: Renderer kill When I run :open -t chrome://kill Then the error "Renderer process was killed" should be shown # Skipped on Windows as "... has stopped working" hangs. @qtwebkit_skip @no_invalid_lines @posix @qt>=5.9 Scenario: Renderer crash (5.9) When I run :open -t chrome://crash Then "Renderer process crashed" should be logged And "* 'Error loading chrome://crash/'" should be logged @qtwebkit_skip @no_invalid_lines @qt>=5.9 @flaky Scenario: Renderer kill (5.9) When I run :open -t chrome://kill Then "Renderer process was killed" should be logged And "* 'Error loading chrome://kill/'" should be logged # https://github.com/qutebrowser/qutebrowser/issues/2290 @qtwebkit_skip @no_invalid_lines @flaky Scenario: Navigating to URL after renderer process is gone When I run :tab-only And I open data/numbers/1.txt And I open data/numbers/2.txt in a new tab And I run :open chrome://kill And I wait for "Renderer process was killed" in the log And I open data/numbers/3.txt Then no crash should happen Scenario: Simple adblock update When I set up "simple" as block lists And I run :adblock-update Then the message "adblock: Read 1 hosts from 1 sources." should be shown