summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortoofar <toofar@spalge.com>2022-09-22 07:06:14 +1200
committertoofar <toofar@spalge.com>2022-09-22 07:06:14 +1200
commit260e23f1024ee78e351eddf1e1537824fcf96f0b (patch)
treedb6e9d5e04542f2c4738cabaf97b023e24909a14
parent03e510acff238e0247f76a1f3fcc66cc6a7f5dda (diff)
parent64f6284375efe2016dbd0bf2ee2ba31964e07011 (diff)
downloadqutebrowser-260e23f1024ee78e351eddf1e1537824fcf96f0b.tar.gz
qutebrowser-260e23f1024ee78e351eddf1e1537824fcf96f0b.zip
Merge pull request #7390 from tomiesz/master
Fix reappearing widgets progress and backfoward widgets. Closes: #7390
-rw-r--r--qutebrowser/mainwindow/statusbar/bar.py2
-rw-r--r--tests/unit/mainwindow/statusbar/test_backforward.py71
-rw-r--r--tests/unit/mainwindow/statusbar/test_progress.py8
3 files changed, 54 insertions, 27 deletions
diff --git a/qutebrowser/mainwindow/statusbar/bar.py b/qutebrowser/mainwindow/statusbar/bar.py
index e2b6e5786..7e5a8ff2c 100644
--- a/qutebrowser/mainwindow/statusbar/bar.py
+++ b/qutebrowser/mainwindow/statusbar/bar.py
@@ -287,6 +287,8 @@ class StatusBar(QWidget):
self.backforward, self.tabindex,
self.keystring, self.prog, self.clock, *self._text_widgets]:
assert isinstance(widget, QWidget)
+ if widget in [self.prog, self.backforward]:
+ widget.enabled = False # type: ignore[attr-defined]
widget.hide()
self._hbox.removeWidget(widget)
self._text_widgets.clear()
diff --git a/tests/unit/mainwindow/statusbar/test_backforward.py b/tests/unit/mainwindow/statusbar/test_backforward.py
index d3e033b34..ac73f8ee1 100644
--- a/tests/unit/mainwindow/statusbar/test_backforward.py
+++ b/tests/unit/mainwindow/statusbar/test_backforward.py
@@ -31,55 +31,72 @@ def backforward_widget(qtbot):
return widget
+@pytest.fixture
+def tabs(tabbed_browser_stubs):
+ tabbed_browser = tabbed_browser_stubs[0]
+ tabbed_browser.widget.current_index = 1
+ return tabbed_browser
+
+
@pytest.mark.parametrize('can_go_back, can_go_forward, expected_text', [
(False, False, ''),
(True, False, '[<]'),
(False, True, '[>]'),
(True, True, '[<>]'),
])
-def test_backforward_widget(backforward_widget, tabbed_browser_stubs,
- fake_web_tab, can_go_back, can_go_forward,
- expected_text):
+def test_widget_state(backforward_widget, tabs,
+ fake_web_tab, can_go_back, can_go_forward,
+ expected_text):
"""Ensure the Backforward widget shows the correct text."""
tab = fake_web_tab(can_go_back=can_go_back, can_go_forward=can_go_forward)
- tabbed_browser = tabbed_browser_stubs[0]
- tabbed_browser.widget.current_index = 1
- tabbed_browser.widget.tabs = [tab]
+ tabs.widget.tabs = [tab]
backforward_widget.enabled = True
- backforward_widget.on_tab_cur_url_changed(tabbed_browser)
+ backforward_widget.on_tab_cur_url_changed(tabs)
assert backforward_widget.text() == expected_text
assert backforward_widget.isVisible() == bool(expected_text)
- # Check that the widget stays hidden if not in the statusbar
- backforward_widget.enabled = False
- backforward_widget.hide()
- backforward_widget.on_tab_cur_url_changed(tabbed_browser)
- assert backforward_widget.isHidden()
- # Check that the widget gets reset if empty.
- if can_go_back and can_go_forward:
- tab = fake_web_tab(can_go_back=False, can_go_forward=False)
- tabbed_browser.widget.tabs = [tab]
- backforward_widget.enabled = True
- backforward_widget.on_tab_cur_url_changed(tabbed_browser)
- assert backforward_widget.text() == ''
- assert not backforward_widget.isVisible()
+def test_state_changes_on_tab_change(backforward_widget, tabs, fake_web_tab):
+ """Test we go invisible when switching to a tab without history."""
+ tab_with_history = fake_web_tab(can_go_back=True, can_go_forward=True)
+ tab_without_history = fake_web_tab(can_go_back=False, can_go_forward=False)
+ tabs.widget.tabs = [tab_with_history]
+ backforward_widget.enabled = True
+
+ backforward_widget.on_tab_cur_url_changed(tabs)
+ assert backforward_widget.isVisible()
+
+ tabs.widget.tabs = [tab_without_history]
+ backforward_widget.on_tab_cur_url_changed(tabs)
+ assert backforward_widget.text() == ''
+ assert not backforward_widget.isVisible()
-def test_none_tab(backforward_widget, tabbed_browser_stubs, fake_web_tab):
+def test_none_tab(backforward_widget, tabs, fake_web_tab):
"""Make sure nothing crashes when passing None as tab."""
tab = fake_web_tab(can_go_back=True, can_go_forward=True)
- tabbed_browser = tabbed_browser_stubs[0]
- tabbed_browser.widget.current_index = 1
- tabbed_browser.widget.tabs = [tab]
+ tabs.widget.tabs = [tab]
backforward_widget.enabled = True
- backforward_widget.on_tab_cur_url_changed(tabbed_browser)
+ backforward_widget.on_tab_cur_url_changed(tabs)
assert backforward_widget.text() == '[<>]'
assert backforward_widget.isVisible()
- tabbed_browser.widget.current_index = -1
- backforward_widget.on_tab_cur_url_changed(tabbed_browser)
+ tabs.widget.current_index = -1
+ backforward_widget.on_tab_cur_url_changed(tabs)
assert backforward_widget.text() == ''
assert not backforward_widget.isVisible()
+
+
+def test_not_shown_when_disabled(backforward_widget, tabs, fake_web_tab):
+ """The widget shouldn't get shown on an event when it's disabled."""
+ tab = fake_web_tab(can_go_back=True, can_go_forward=True)
+ tabs.widget.tabs = [tab]
+
+ backforward_widget.enabled = False
+ backforward_widget.on_tab_cur_url_changed(tabs)
+ assert not backforward_widget.isVisible()
+
+ backforward_widget.on_tab_changed(tab)
+ assert not backforward_widget.isVisible()
diff --git a/tests/unit/mainwindow/statusbar/test_progress.py b/tests/unit/mainwindow/statusbar/test_progress.py
index 888ed5943..1cc3bf9af 100644
--- a/tests/unit/mainwindow/statusbar/test_progress.py
+++ b/tests/unit/mainwindow/statusbar/test_progress.py
@@ -69,6 +69,14 @@ def test_tab_changed(fake_web_tab, progress_widget, progress, load_status,
assert actual == expected
+def test_not_shown_when_disabled(progress_widget, fake_web_tab):
+ """The widget shouldn't get shown on an event when it's disabled."""
+ tab = fake_web_tab(progress=15, load_status=usertypes.LoadStatus.loading)
+ progress_widget.enabled = False
+ progress_widget.on_tab_changed(tab)
+ assert not progress_widget.isVisible()
+
+
def test_progress_affecting_statusbar_height(config_stub, fake_statusbar,
progress_widget):
"""Make sure the statusbar stays the same height when progress is shown.