Register the fake statusbar command in objreg.

The CompletionView looks in objreg for 'status-cmd', so move it from a
private fixture in test_completer to a public fixture that handles
objreg registration/deletion.
This commit is contained in:
Ryan Roden-Corrent 2016-07-12 12:47:28 -04:00
parent e5da179ebf
commit a740f99607
3 changed files with 25 additions and 23 deletions

View File

@ -275,6 +275,16 @@ def completion_widget_stub(win_registry):
objreg.delete('completion', scope='window', window=0) objreg.delete('completion', scope='window', window=0)
@pytest.yield_fixture
def status_command_stub(stubs, qtbot, win_registry):
"""Fixture which provides a fake status-command object."""
cmd = stubs.StatusBarCommandStub()
objreg.register('status-command', cmd, scope='window', window=0)
qtbot.addWidget(cmd)
yield cmd
objreg.delete('status-command', scope='window', window=0)
@pytest.fixture(scope='session') @pytest.fixture(scope='session')
def stubs(): def stubs():
"""Provide access to stub objects useful for testing.""" """Provide access to stub objects useful for testing."""

View File

@ -413,7 +413,7 @@ class FakeConfigType:
self.complete = lambda: [(val, '') for val in valid_values] self.complete = lambda: [(val, '') for val in valid_values]
class FakeStatusbarCommand(QLineEdit): class StatusBarCommandStub(QLineEdit):
"""Stub for the statusbar command prompt.""" """Stub for the statusbar command prompt."""

View File

@ -40,20 +40,12 @@ class FakeCompletionModel(QStandardItemModel):
@pytest.fixture @pytest.fixture
def cmd(stubs, qtbot): def completer_obj(qtbot, status_command_stub, config_stub, monkeypatch, stubs):
"""Create the statusbar command prompt the completer uses."""
cmd = stubs.FakeStatusbarCommand()
qtbot.addWidget(cmd)
return cmd
@pytest.fixture
def completer_obj(qtbot, cmd, config_stub, monkeypatch, stubs):
"""Create the completer used for testing.""" """Create the completer used for testing."""
monkeypatch.setattr('qutebrowser.completion.completer.QTimer', monkeypatch.setattr('qutebrowser.completion.completer.QTimer',
stubs.InstaTimer) stubs.InstaTimer)
config_stub.data = {'completion': {'auto-open': False}} config_stub.data = {'completion': {'auto-open': False}}
return completer.Completer(cmd, 0) return completer.Completer(status_command_stub, 0)
@pytest.fixture(autouse=True) @pytest.fixture(autouse=True)
@ -159,11 +151,11 @@ def _validate_cmd_prompt(cmd, txt):
(':set -t -p |', usertypes.Completion.section), (':set -t -p |', usertypes.Completion.section),
(':open -- |', None), (':open -- |', None),
]) ])
def test_update_completion(txt, expected, cmd, completer_obj, def test_update_completion(txt, expected, status_command_stub, completer_obj,
completion_widget_stub): completion_widget_stub):
"""Test setting the completion widget's model based on command text.""" """Test setting the completion widget's model based on command text."""
# this test uses | as a placeholder for the current cursor position # this test uses | as a placeholder for the current cursor position
_set_cmd_prompt(cmd, txt) _set_cmd_prompt(status_command_stub, txt)
completer_obj.schedule_completion_update() completer_obj.schedule_completion_update()
if expected is None: if expected is None:
assert not completion_widget_stub.set_model.called assert not completion_widget_stub.set_model.called
@ -174,19 +166,19 @@ def test_update_completion(txt, expected, cmd, completer_obj,
assert arg.srcmodel.kind == expected assert arg.srcmodel.kind == expected
def test_completion_item_prev(completer_obj, cmd, completion_widget_stub, def test_completion_item_prev(completer_obj, status_command_stub,
config_stub, qtbot): completion_widget_stub, config_stub, qtbot):
"""Test that completion_item_prev emits next_prev_item.""" """Test that completion_item_prev emits next_prev_item."""
cmd.setText(':') status_command_stub.setText(':')
with qtbot.waitSignal(completer_obj.next_prev_item) as blocker: with qtbot.waitSignal(completer_obj.next_prev_item) as blocker:
completer_obj.completion_item_prev() completer_obj.completion_item_prev()
assert blocker.args == [True] assert blocker.args == [True]
def test_completion_item_next(completer_obj, cmd, completion_widget_stub, def test_completion_item_next(completer_obj, status_command_stub,
config_stub, qtbot): completion_widget_stub, config_stub, qtbot):
"""Test that completion_item_next emits next_prev_item.""" """Test that completion_item_next emits next_prev_item."""
cmd.setText(':') status_command_stub.setText(':')
with qtbot.waitSignal(completer_obj.next_prev_item) as blocker: with qtbot.waitSignal(completer_obj.next_prev_item) as blocker:
completer_obj.completion_item_next() completer_obj.completion_item_next()
assert blocker.args == [False] assert blocker.args == [False]
@ -202,8 +194,8 @@ def test_completion_item_next(completer_obj, cmd, completion_widget_stub,
(':foo |', None, True, 1, ":foo |"), (':foo |', None, True, 1, ":foo |"),
]) ])
def test_selection_changed(before, newtxt, count, quick_complete, after, def test_selection_changed(before, newtxt, count, quick_complete, after,
completer_obj, cmd, completion_widget_stub, completer_obj, status_command_stub,
config_stub): completion_widget_stub, config_stub):
"""Test that change_completed_part modifies the cmd text properly. """Test that change_completed_part modifies the cmd text properly.
The | represents the current cursor position in the cmd prompt. The | represents the current cursor position in the cmd prompt.
@ -218,9 +210,9 @@ def test_selection_changed(before, newtxt, count, quick_complete, after,
selection = unittest.mock.Mock() selection = unittest.mock.Mock()
selection.indexes = unittest.mock.Mock(return_value=indexes) selection.indexes = unittest.mock.Mock(return_value=indexes)
completion_widget_stub.model = unittest.mock.Mock(return_value=model) completion_widget_stub.model = unittest.mock.Mock(return_value=model)
_set_cmd_prompt(cmd, before) _set_cmd_prompt(status_command_stub, before)
# schedule_completion_update is needed to pick up the cursor position # schedule_completion_update is needed to pick up the cursor position
completer_obj.schedule_completion_update() completer_obj.schedule_completion_update()
completer_obj.selection_changed(selection, None) completer_obj.selection_changed(selection, None)
model.data.assert_called_with(indexes[0]) model.data.assert_called_with(indexes[0])
_validate_cmd_prompt(cmd, after) _validate_cmd_prompt(status_command_stub, after)