qutebrowser/tests/end2end/features/misc.feature

725 lines
28 KiB
Gherkin
Raw Normal View History

2015-11-10 06:33:47 +01:00
Feature: Various utility commands.
## :set-cmd-text
2015-11-10 06:33:47 +01:00
Scenario: :set-cmd-text and :command-accept
When I run :set-cmd-text :message-info "Hello World"
And I run :command-accept
2015-11-26 17:50:39 +01:00
Then the message "Hello World" should be shown
2015-11-10 06:33:47 +01:00
Scenario: :set-cmd-text with two commands
When I run :set-cmd-text :message-info test ;; message-error error
And I run :command-accept
2015-11-26 17:50:39 +01:00
Then the message "test" should be shown
And the error "error" should be shown
2015-11-10 06:33:47 +01:00
2015-11-10 19:22:13 +01:00
Scenario: :set-cmd-text with URL replacement
When I open data/hello.txt
And I run :set-cmd-text :message-info {url}
2015-11-10 19:22:13 +01:00
And I run :command-accept
Then the message "http://localhost:*/hello.txt" should be shown
2015-11-10 19:22:13 +01:00
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
2015-11-10 19:22:13 +01:00
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
2015-11-26 17:50:39 +01:00
Then the message "foo bar" should be shown
2015-11-10 19:22:13 +01:00
Scenario: :set-cmd-text with -a but without text
When I run :set-cmd-text -a foo
2015-11-26 17:50:39 +01:00
Then the error "No current text!" should be shown
2015-11-10 19:22:13 +01:00
2015-11-10 06:33:47 +01:00
Scenario: :set-cmd-text with invalid command
When I run :set-cmd-text foo
2015-11-26 17:50:39 +01:00
Then the error "Invalid command text 'foo'." should be shown
2015-11-10 06:33:47 +01:00
## :message-*
2015-11-10 06:33:47 +01:00
Scenario: :message-error
When I run :message-error "Hello World"
2015-11-26 17:50:39 +01:00
Then the error "Hello World" should be shown
2015-11-10 06:33:47 +01:00
Scenario: :message-info
When I run :message-info "Hello World"
2015-11-26 17:50:39 +01:00
Then the message "Hello World" should be shown
2015-11-10 06:33:47 +01:00
Scenario: :message-warning
When I run :message-warning "Hello World"
2015-11-26 17:50:39 +01:00
Then the warning "Hello World" should be shown
2015-11-13 07:50:20 +01:00
## :jseval
2015-11-13 07:50:20 +01:00
Scenario: :jseval
When I set general -> log-javascript-console to info
2015-11-13 07:50:20 +01:00
And I run :jseval console.log("Hello from JS!");
And I wait for the javascript message "Hello from JS!"
2015-11-26 17:50:39 +01:00
Then the message "No output or error" should be shown
2015-11-15 12:23:34 +01:00
Scenario: :jseval without logging
When I set general -> log-javascript-console to none
2015-11-15 12:23:34 +01:00
And I run :jseval console.log("Hello from JS!");
2015-11-26 17:50:39 +01:00
Then the message "No output or error" should be shown
And "[:*] Hello from JS!" should not be logged
2015-11-15 12:23:34 +01:00
Scenario: :jseval with --quiet
When I set general -> log-javascript-console to info
2015-11-15 12:23:34 +01:00
And I run :jseval --quiet console.log("Hello from JS!");
And I wait for the javascript message "Hello from JS!"
2015-11-15 12:23:34 +01:00
Then "No output or error" should not be logged
Scenario: :jseval with a value
When I run :jseval "foo"
2015-11-26 17:50:39 +01:00
Then the message "foo" should be shown
2015-11-15 12:23:34 +01:00
Scenario: :jseval with a long, truncated value
When I run :jseval Array(5002).join("x")
2015-11-26 17:50:39 +01:00
Then the message "x* [...trimmed...]" should be shown
2015-11-15 12:23:54 +01:00
2016-09-12 15:59:17 +02:00
@qtwebengine_skip
Scenario: :jseval with --world on QtWebKit
When I set general -> log-javascript-console to info
And 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
@qtwebkit_skip @pyqt>=5.7.0
2016-09-12 15:59:17 +02:00
Scenario: :jseval uses separate world without --world
When I set general -> log-javascript-console to info
And 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
@qtwebkit_skip @pyqt>=5.7.0
2016-09-12 15:59:17 +02:00
Scenario: :jseval using the main world
When I set general -> log-javascript-console to info
And 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
@qtwebkit_skip @pyqt>=5.7.0
2016-09-12 18:23:23 +02:00
Scenario: :jseval using the main world as name
When I set general -> log-javascript-console to info
And 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
2015-11-15 12:23:54 +01:00
# :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
2015-11-26 17:50:39 +01:00
Then the error "blah is not a valid web action!" should be shown
2015-11-15 12:23:54 +01:00
Scenario: :debug-webaction with non-webaction member
When I open data/hello.txt
And I run :debug-webaction PermissionUnknown
2015-11-26 17:50:39 +01:00
Then the error "PermissionUnknown is not a valid web action!" should be shown
2015-11-18 20:08:25 +01:00
# :inspect
Scenario: Inspector without developer extras
When I set general -> developer-extras to false
And I run :inspector
2015-11-26 17:50:39 +01:00
Then the error "Please enable developer-extras before using the webinspector!" should be shown
2015-11-18 20:08:25 +01:00
@no_xvfb @posix @qtwebengine_skip
2015-11-18 20:08:25 +01:00
Scenario: Inspector smoke test
When I set general -> developer-extras to true
And I run :inspector
tests: Make inspector smoke test more reliable. Before we didn't wait until the inspector window was hidden, which caused the following tests to fail on our OS X buildbot: ==================================== ERRORS ==================================== _________ ERROR at teardown of test_fakekey_sending_key_to_the_website _________ [...] tests/integration/testprocess.py:186: InvalidLine ----------------------------- Captured stdout call ----------------------------- [...] INVALID: Traceback (most recent call last): IGNORED: File "/Users/buildbot/buildbot/slave/osx/build/qutebrowser/app.py", line 109, in <lambda> IGNORED: target_arg=target_arg)) IGNORED: File "/Users/buildbot/buildbot/slave/osx/build/qutebrowser/app.py", line 263, in process_pos_args IGNORED: commandrunner.run_safely_init(cmd[1:]) IGNORED: File "/Users/buildbot/buildbot/slave/osx/build/qutebrowser/commands/runners.py", line 266, in run_safely_init IGNORED: self.run(text, count) IGNORED: File "/Users/buildbot/buildbot/slave/osx/build/qutebrowser/commands/runners.py", line 249, in run IGNORED: result.cmd.run(self._win_id, args) IGNORED: File "/Users/buildbot/buildbot/slave/osx/build/qutebrowser/commands/command.py", line 505, in run IGNORED: self.handler(*posargs, **kwargs) IGNORED: File "/Users/buildbot/buildbot/slave/osx/build/qutebrowser/browser/commands.py", line 1781, in fake_key IGNORED: tab='current') IGNORED: File "/Users/buildbot/buildbot/slave/osx/build/qutebrowser/utils/objreg.py", line 215, in get IGNORED: reg = _get_registry(scope, window, tab) IGNORED: File "/Users/buildbot/buildbot/slave/osx/build/qutebrowser/utils/objreg.py", line 202, in _get_registry IGNORED: return _get_tab_registry(window, tab) IGNORED: File "/Users/buildbot/buildbot/slave/osx/build/qutebrowser/utils/objreg.py", line 152, in _get_tab_registry IGNORED: raise RegistryUnavailableError('tab') INVALID: qutebrowser.utils.objreg.RegistryUnavailableError: tab [...] While this is a real issue, this test shouldn't affect the next one. Since we have to wait for windows getting focused but Xvfb doesn't do that, we skip this tests when running via Xvfb.
2015-11-24 16:17:26 +01:00
And I wait for "Focus object changed: <PyQt5.QtWebKitWidgets.QWebView object at *>" in the log
2015-11-18 20:08:25 +01:00
And I run :inspector
And I wait for "Focus object changed: *" in the log
2015-11-18 20:08:25 +01:00
Then no crash should happen
2016-01-07 07:12:51 +01:00
# Different code path as an inspector got created now
Scenario: Inspector without developer extras (after smoke)
When I set general -> developer-extras to false
And I run :inspector
Then the error "Please enable developer-extras before using the webinspector!" should be shown
# Different code path as an inspector got created now
@no_xvfb @posix @qtwebengine_skip
2016-01-07 07:12:51 +01:00
Scenario: Inspector smoke test 2
When I set general -> developer-extras to true
And I run :inspector
And I wait for "Focus object changed: <PyQt5.QtWebKitWidgets.QWebView object at *>" in the log
And I run :inspector
And I wait for "Focus object changed: *" in the log
Then no crash should happen
2015-11-23 14:37:54 +01:00
# :stop/:reload
2015-11-21 14:23:44 +01:00
Scenario: :stop
Given I have a fresh instance
2015-11-21 14:23:44 +01:00
# We can't use "When I open" because we don't want to wait for load
# finished
When I run :open http://localhost:(port)/custom/redirect-later?delay=-1
2015-11-21 14:23:44 +01:00
And I wait for "emitting: cur_load_status_changed('loading') (tab *)" in the log
And I wait 1s
And I run :stop
And I open custom/redirect-later-continue in a new tab
And I wait 1s
Then the unordered requests should be:
custom/redirect-later-continue
custom/redirect-later?delay=-1
2015-11-21 14:23:44 +01:00
# no request on / because we stopped the redirect
2015-11-23 14:37:54 +01:00
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
2015-11-23 14:37:54 +01:00
Scenario: :reload
When I open data/reload.txt
2015-11-23 14:37:54 +01:00
And I run :reload
And I wait until data/reload.txt is loaded
2015-11-23 14:37:54 +01:00
Then the requests should be:
data/reload.txt
data/reload.txt
2015-11-23 14:37:54 +01:00
Scenario: :reload with force
When I open headers
And I run :reload --force
And I wait until headers is loaded
2015-11-23 14:37:54 +01:00
Then the header Cache-Control should be set to no-cache
2015-11-24 18:24:33 +01:00
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
2015-11-24 18:24:33 +01:00
# :view-source
2016-09-06 21:43:02 +02:00
# Flaky due to :view-source being async?
@qtwebengine_flaky
2015-11-24 18:24:33 +01:00
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 */"
2015-11-24 18:24:33 +01:00
2016-09-06 21:43:02 +02:00
# Flaky due to :view-source being async?
@qtwebengine_flaky
2015-11-24 18:24:33 +01:00
Scenario: :view-source on source page.
When I open data/hello.txt
And I run :view-source
And I run :view-source
2015-11-26 17:50:39 +01:00
Then the error "Already viewing source!" should be shown
2015-11-24 18:36:51 +01:00
# :debug-console
2015-11-24 19:24:39 +01:00
2016-02-16 20:36:23 +01:00
@no_xvfb
2015-11-24 18:36:51 +01:00
Scenario: :debug-console smoke test
When I run :debug-console
And I wait for "Focus object changed: <qutebrowser.misc.consolewidget.ConsoleLineEdit *>" in the log
And I run :debug-console
And I wait for "Focus object changed: *" in the log
Then no crash should happen
2015-11-28 22:34:19 +01:00
# :help
Scenario: :help without topic
When I run :tab-only
And I run :help
And I wait until qute://help/index.html is loaded
2015-11-28 22:34:19 +01:00
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
2016-01-04 20:10:03 +01:00
When the documentation is up to date
And I run :tab-only
2015-11-28 22:34:19 +01:00
And I run :help :back
And I wait until qute://help/commands.html#back is loaded
2015-11-28 22:34:19 +01:00
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
2016-01-04 20:10:03 +01:00
When the documentation is up to date
And I run :tab-only
2015-11-28 22:34:19 +01:00
And I run :help general->editor
And I wait until qute://help/settings.html#general-editor is loaded
2015-11-28 22:34:19 +01:00
Then the following tabs should be open:
- qute://help/settings.html#general-editor (active)
Scenario: :help with invalid setting (2 arrows)
When I run :help general->editor->foo
Then the error "Invalid help topic general->editor->foo!" should be shown
Scenario: :help with invalid setting (unknown section)
When I run :help foo->bar
Then the error "Invalid section foo!" should be shown
Scenario: :help with invalid setting (unknown option)
When I run :help general->bar
Then the error "Invalid option bar!" should be shown
Scenario: :help with -t
When I open about:blank
And I run :tab-only
And I run :help -t
And I wait until qute://help/index.html is loaded
2015-11-28 22:34:19 +01:00
Then the following tabs should be open:
- about:blank
- qute://help/index.html (active)
2015-11-28 22:44:05 +01:00
# :home
Scenario: :home with single page
When I set general -> startpage 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 general -> startpage 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
2015-12-20 20:00:56 +01:00
# pdfjs support
@qtwebengine_todo: pdfjs is not implemented yet
2015-12-20 20:00:56 +01:00
Scenario: pdfjs is used for pdf files
Given pdfjs is available
When I set content -> enable-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
2015-12-20 20:00:56 +01:00
Scenario: pdfjs is not used when disabled
When I set content -> enable-pdfjs to false
And I set storage -> prompt-download-directory to false
And I open data/misc/test.pdf
Then "Download test.pdf finished" should be logged
2016-01-06 07:15:34 +01:00
@qtwebengine_todo: 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 -> enable-pdfjs to true
And I set completion -> download-path-suggestion to filename
And I set storage -> prompt-download-directory 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 <qutebrowser.utils.usertypes.Question default='test.pdf' mode=<PromptMode.download: 5> text='Save file to:'>, *" in the log
And I run :leave-mode
Then no crash should happen
2016-01-06 07:15:34 +01:00
# :print
# Disabled because it causes weird segfaults and QPainter warnings in Qt...
2016-01-14 07:53:00 +01:00
@xfail_norun
2016-01-06 07:15:34 +01:00
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
2016-01-06 07:54:54 +01:00
# On Windows/OS X, we get a "QPrintDialog: Cannot be used on non-native
# printers" qWarning.
#
# Disabled because it causes weird segfaults and QPainter warnings in Qt...
2016-01-14 07:53:00 +01:00
@xfail_norun
2016-01-06 07:15:34 +01:00
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
2016-01-06 07:15:34 +01:00
And I run :debug-pyeval QApplication.instance().activeModalWidget().close()
Then no crash should happen
2016-01-06 07:15:42 +01:00
# FIXME:qtwebengine use a finer skipping here
@qtwebengine_skip: printing to pdf is not implemented with older Qt versions
2016-07-12 13:29:32 +02:00
Scenario: print --pdf
2016-07-12 02:08:24 +02:00
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
2016-07-12 02:08:24 +02:00
2016-01-06 07:15:42 +01:00
# :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"
2016-01-06 07:15:42 +01:00
Scenario: Running :pyeval with --quiet
When I run :debug-pyeval --quiet 1+1
Then "pyeval output: 2" should be logged
## https://github.com/The-Compiler/qutebrowser/issues/504
Scenario: Focusing download widget via Tab
When I open about:blank
And I press the key "<Tab>"
And I press the key "<Ctrl-C>"
Then no crash should happen
@pyqt>=5.3.1 @qtwebengine_skip: JS prompt is not implemented yet
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 "<Tab>"
And I press the key "<Ctrl-C>"
Then no crash should happen
## Custom headers
Scenario: Setting a custom header
When I set network -> custom-headers 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 network -> do-not-track to true
And I open headers
Then the header Dnt should be set to 1
And the header X-Do-Not-Track should be set to 1
Scenario: DNT header (off)
When I set network -> do-not-track to false
And I open headers
Then the header Dnt should be set to 0
And the header X-Do-Not-Track should be set to 0
Scenario: Accept-Language header
When I set network -> accept-language to en,de
And I open headers
Then the header Accept-Language should be set to en,de
## :messages
Scenario: Showing error messages
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=error 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 not contain the plaintext "the-warning-message"
And the page should not 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"
2016-09-06 21:43:02 +02:00
@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
Then no crash should happen
Scenario: Using qute:plainlog directly
When I open qute:plainlog
Then no crash should happen
Scenario: Using :messages without messages
Given I have a fresh instance
When I run :messages
Then qute://log?level=error should be loaded
And the page should contain the plaintext "No messages to show."
2016-08-05 15:13:36 +02:00
Scenario: Using :debug-log-capacity
When I run :debug-log-capacity 100
And I run :message-info oldstuff
2016-09-15 12:40:47 +02:00
And I run :repeat 20 :message-info otherstuff
2016-08-05 15:13:36 +02:00
And I run :message-info newstuff
And I open qute:log
Then the page should contain the plaintext "newstuff"
And the page should not contain the plaintext "oldstuff"
Scenario: Using :debug-log-capacity with negative capacity
When I run :debug-log-capacity -1
Then the error "Can't set a negative log capacity!" should be shown
# :debug-log-level / :debug-log-filter
# Other :debug-log-{level,filter} features are tested in
# unit/utils/test_log.py as using them would break end2end tests.
Scenario: Using debug-log-level with invalid level
When I run :debug-log-level hello
Then the error "level: Invalid value hello - expected one of: vdebug, debug, info, warning, error, critical" should be shown
Scenario: Using debug-log-filter with invalid filter
When I run :debug-log-filter blah
Then the error "filters: Invalid value blah - expected one of: statusbar, *" should be shown
## https://github.com/The-Compiler/qutebrowser/issues/1523
Scenario: Completing a single option argument
When I run :set-cmd-text -s :--
Then no crash should happen
## https://github.com/The-Compiler/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
# 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
## https://github.com/The-Compiler/qutebrowser/issues/1219
@qtwebengine_todo: private browsing is not implemented yet
Scenario: Sharing cookies with private browsing
When I set general -> private-browsing to true
And I open cookies/set?qute-test=42 without waiting
And I wait until cookies is loaded
And I open cookies in a new tab
And I set general -> private-browsing to false
Then the cookie qute-test should be set to 42
2016-07-03 22:32:07 +02:00
## https://github.com/The-Compiler/qutebrowser/issues/1742
@qtwebengine_todo: private browsing is not implemented yet
Scenario: Private browsing is activated in QtWebKit without restart
When I set general -> private-browsing to true
And I open data/javascript/localstorage.html
And I set general -> private-browsing to false
Then the page should contain the plaintext "Local storage status: not working"
2016-07-03 22:32:07 +02:00
Scenario: :repeat-command
Given I open data/scroll/simple.html
2016-07-03 22:32:07 +02:00
And I run :tab-only
When I run :scroll down
And I run :repeat-command
And I run :scroll up
Then the page should be scrolled vertically
Scenario: :repeat-command with count
Given I open data/scroll/simple.html
2016-07-03 22:32:07 +02:00
And I run :tab-only
When I run :scroll down with count 3
And I wait until the scroll position changed
2016-07-03 22:32:07 +02:00
And I run :scroll up
And I wait until the scroll position changed
2016-07-03 22:32:07 +02:00
And I run :repeat-command with count 2
And I wait until the scroll position changed to 0/0
2016-07-03 22:32:07 +02:00
Then the page should not be scrolled
Scenario: :repeat-command with not-normal command inbetween
Given I open data/scroll/simple.html
2016-07-03 22:32:07 +02:00
And I run :tab-only
When I run :scroll down with count 3
And I wait until the scroll position changed
2016-07-03 22:32:07 +02:00
And I run :scroll up
And I wait until the scroll position changed
2016-07-03 22:32:07 +02:00
And I run :prompt-accept
And I run :repeat-command with count 2
And I wait until the scroll position changed to 0/0
2016-07-03 22:32:07 +02:00
Then the page should not be scrolled
And the error "prompt-accept: This command is only allowed in prompt/yesno mode, not normal." should be shown
@qtwebengine_createWindow
Scenario: :repeat-command with mode-switching command
Given I open data/hints/link_blank.html
And I run :tab-only
When I hint with args "all"
And I run :leave-mode
And I run :repeat-command
2016-08-18 16:57:47 +02:00
And I run :follow-hint a
And I wait until data/hello.txt is loaded
Then the following tabs should be open:
- data/hints/link_blank.html
- data/hello.txt (active)
2016-08-10 19:42:03 +02:00
2016-09-30 18:14:22 +02:00
Scenario: Using 0 as count
When I run :scroll down with count 0
Then the error "scroll: A zero count is not allowed for this command!" 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
Then the session should look like:
windows:
- tabs:
- active: true
history:
- url: http://localhost:*/data/hello3.txt
2016-08-10 19:42:03 +02:00
## 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
@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
2016-08-18 15:30:04 +02:00
## :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!" 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 "Clicked editable element!" 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)
2016-09-06 21:43:02 +02:00
@qtwebengine_flaky
Scenario: Clicking an element which is out of view
When I open data/scroll/simple.html
And I run :scroll-page 0 1
2016-09-06 21:43:02 +02:00
And I wait until the scroll position changed
And I run :click-element id link
Then the error "Element position is out of view!" should be shown
## :command-history-{prev,next}
2016-10-10 07:34:22 +02:00
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
2016-10-10 07:34:22 +02:00
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
2016-10-10 07:34:22 +02:00
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
2016-10-10 07:34:22 +02:00
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
2016-10-10 07:33:59 +02:00
Scenario: Calling previous command with private-browsing mode
When I run :set-cmd-text :message-info blah
And I run :command-accept
And I set general -> private-browsing to true
And I run :set-cmd-text :message-error This should only be shown once
And I run :command-accept
And I wait for the error "This should only be shown once"
And I run :set-cmd-text :
And I run :command-history-prev
And I run :command-accept
And I set general -> private-browsing to false
Then the message "blah" should be shown