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
|
|
|
|
2015-11-24 17:48:09 +01:00
|
|
|
@not_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
|
|
|
|
2015-11-23 14:37:54 +01:00
|
|
|
# :stop/:reload
|
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
|
|
|
|
|
|
|
Scenario: :reload
|
|
|
|
When I open data/hello.txt
|
|
|
|
And I run :reload
|
2015-11-23 19:44:53 +01:00
|
|
|
And I wait until data/hello.txt is loaded
|
2015-11-23 14:37:54 +01:00
|
|
|
Then the requests should be:
|
|
|
|
data/hello.txt
|
|
|
|
data/hello.txt
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
# :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
|
|
|
|
2015-11-24 18:36:51 +01:00
|
|
|
@not_xvfb
|
|
|
|
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
|
|
|
|
When I run :tab-only
|
|
|
|
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
|
|
|
|
When I run :tab-only
|
|
|
|
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
|