Merge pull request #720 from izn/add-arch-update-tests
Add arch-update tests
This commit is contained in:
commit
f7feb3e674
1 changed files with 69 additions and 0 deletions
|
@ -1,7 +1,76 @@
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
|
import util.cli
|
||||||
|
import core.config
|
||||||
|
import modules.contrib.arch_update
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def module():
|
||||||
|
module = modules.contrib.arch_update.Module(
|
||||||
|
config=core.config.Config([]),
|
||||||
|
theme=None
|
||||||
|
)
|
||||||
|
|
||||||
|
yield module
|
||||||
|
|
||||||
def test_load_module():
|
def test_load_module():
|
||||||
__import__("modules.contrib.arch-update")
|
__import__("modules.contrib.arch-update")
|
||||||
|
|
||||||
def test_load_symbolic_link_module():
|
def test_load_symbolic_link_module():
|
||||||
__import__("modules.contrib.arch_update")
|
__import__("modules.contrib.arch_update")
|
||||||
|
|
||||||
|
def test_with_one_package(module, mocker):
|
||||||
|
command = mocker.patch(
|
||||||
|
'util.cli.execute',
|
||||||
|
return_value=(0, 'bumblebee 1.0.0')
|
||||||
|
)
|
||||||
|
|
||||||
|
module.update()
|
||||||
|
|
||||||
|
command.assert_called_with(
|
||||||
|
'checkupdates',
|
||||||
|
ignore_errors=True,
|
||||||
|
return_exitcode=True
|
||||||
|
)
|
||||||
|
|
||||||
|
widget = module.widget()
|
||||||
|
assert widget.full_text() == 'Update Arch: 1'
|
||||||
|
assert module.state(widget) == None
|
||||||
|
assert module.hidden() == False
|
||||||
|
|
||||||
|
def test_with_two_packages(module, mocker):
|
||||||
|
command = mocker.patch(
|
||||||
|
'util.cli.execute',
|
||||||
|
return_value=(0, 'bumblebee 1.0.0\ni3wm 3.5.7')
|
||||||
|
)
|
||||||
|
|
||||||
|
module.update()
|
||||||
|
|
||||||
|
widget = module.widget()
|
||||||
|
assert widget.full_text() == 'Update Arch: 2'
|
||||||
|
assert module.state(widget) == 'warning'
|
||||||
|
assert module.hidden() == False
|
||||||
|
|
||||||
|
def test_with_no_packages(module, mocker):
|
||||||
|
mocker.patch('util.cli.execute', return_value=(2, ''))
|
||||||
|
|
||||||
|
module.update()
|
||||||
|
|
||||||
|
widget = module.widget()
|
||||||
|
assert widget.full_text() == 'Update Arch: 0'
|
||||||
|
assert module.state(widget) == None
|
||||||
|
assert module.hidden() == True
|
||||||
|
|
||||||
|
def test_with_unknown_code(module, mocker):
|
||||||
|
mocker.patch('util.cli.execute', return_value=(99, 'error'))
|
||||||
|
logger = mocker.patch('logging.error')
|
||||||
|
|
||||||
|
module.update()
|
||||||
|
|
||||||
|
logger.assert_called_with('checkupdates exited with {}: {}'.format(99, 'error'))
|
||||||
|
|
||||||
|
widget = module.widget()
|
||||||
|
assert widget.full_text() == 'Update Arch: 0'
|
||||||
|
assert module.state(widget) == 'warning'
|
||||||
|
assert module.hidden() == False
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue