2015-11-10 06:33:47 +01:00
|
|
|
Feature: Various utility commands.
|
|
|
|
|
2015-11-13 23:43:28 +01:00
|
|
|
## :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
|
|
|
|
When I run :set-cmd-text :message-info >{url}<
|
|
|
|
And I run :command-accept
|
2015-11-26 17:50:39 +01:00
|
|
|
Then the message ">http://localhost:*/hello.txt<" 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
|
|
|
|
2015-11-13 23:43:28 +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
|
|
|
|
2015-11-13 23:43:28 +01:00
|
|
|
## :jseval
|
|
|
|
|
2015-11-13 07:50:20 +01:00
|
|
|
Scenario: :jseval
|
2015-11-29 18:37:11 +01:00
|
|
|
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 "[:0] Hello from JS!" in the log
|
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
|
2015-11-29 18:37:11 +01:00
|
|
|
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
|
2015-11-15 12:23:34 +01:00
|
|
|
And "[:0] Hello from JS!" should not be logged
|
|
|
|
|
|
|
|
Scenario: :jseval with --quiet
|
2015-11-29 18:37:11 +01:00
|
|
|
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 "[:0] Hello from JS!" in the log
|
|
|
|
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
|
|
|
|
|
|
|
# :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
|
|
|
|
2016-02-16 20:36:23 +01:00
|
|
|
@no_xvfb @posix
|
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
|
2015-11-24 16:54:35 +01:00
|
|
|
And I wait for "Focus object changed: *" in the log
|
2015-11-18 20:08:25 +01:00
|
|
|
Then no crash should happen
|
2015-11-20 07:05:16 +01:00
|
|
|
|
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
|
2016-02-16 20:36:23 +01:00
|
|
|
@no_xvfb @posix
|
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
|
|
|
|
2016-01-05 22:46:52 +01:00
|
|
|
# WORKAROUND for https://bitbucket.org/cherrypy/cherrypy/pull-requests/117/
|
2016-01-05 20:13:25 +01:00
|
|
|
@not_osx
|
2015-11-21 14:23:44 +01:00
|
|
|
Scenario: :stop
|
2015-11-22 17:07:54 +01:00
|
|
|
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
|
2015-11-23 19:43:11 +01:00
|
|
|
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
|
2015-11-21 15:14:32 +01:00
|
|
|
And I run :stop
|
2015-12-18 20:24:03 +01:00
|
|
|
And I open custom/redirect-later-continue in a new tab
|
2015-11-23 19:43:11 +01:00
|
|
|
And I wait 1s
|
2015-11-23 20:00:25 +01:00
|
|
|
Then the unordered requests should be:
|
2015-11-23 19:43:11 +01:00
|
|
|
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
|
|
|
|
2016-01-06 07:15:20 +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
|
2016-01-05 22:46:52 +01:00
|
|
|
When I open data/reload.txt
|
2015-11-23 14:37:54 +01:00
|
|
|
And I run :reload
|
2016-01-05 22:46:52 +01:00
|
|
|
And I wait until data/reload.txt is loaded
|
2015-11-23 14:37:54 +01:00
|
|
|
Then the requests should be:
|
2016-01-05 22:46:52 +01:00
|
|
|
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
|
2015-11-23 19:44:53 +01:00
|
|
|
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
|
|
|
|
2016-01-06 07:15:20 +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
|
|
|
|
|
|
|
|
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 source should look like misc/hello.txt.html
|
|
|
|
|
|
|
|
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
|
2015-12-02 22:22:31 +01:00
|
|
|
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
|
2015-12-02 22:22:31 +01:00
|
|
|
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
|
2015-12-02 22:22:31 +01:00
|
|
|
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
|
2015-12-02 22:22:31 +01:00
|
|
|
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
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
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 finished" should be logged
|
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.
|
2016-01-06 18:25:22 +01:00
|
|
|
#
|
|
|
|
# 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
|
2016-01-06 08:29:53 +01:00
|
|
|
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
|
|
|
|
|
|
|
# :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"
|
|
|
|
|
2016-01-06 07:42:33 +01:00
|
|
|
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
|