summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFlorian Bruhin <me@the-compiler.org>2018-12-10 17:22:07 +0100
committerFlorian Bruhin <me@the-compiler.org>2018-12-10 17:26:58 +0100
commit7f06b54f25200f8af38dec5acc2510f255912ee4 (patch)
tree9e9c8de5b4f73522f583a27f4f2018fc06f98e66
parent7b1bcea30650578e28f9672835c34eb235605f4e (diff)
downloadqutebrowser-7f06b54f25200f8af38dec5acc2510f255912ee4.tar.gz
qutebrowser-7f06b54f25200f8af38dec5acc2510f255912ee4.zip
Add more extensions.loader tests
-rw-r--r--qutebrowser/extensions/loader.py3
-rw-r--r--tests/unit/extensions/test_loader.py97
2 files changed, 97 insertions, 3 deletions
diff --git a/qutebrowser/extensions/loader.py b/qutebrowser/extensions/loader.py
index 1a9b3d858..d7a106344 100644
--- a/qutebrowser/extensions/loader.py
+++ b/qutebrowser/extensions/loader.py
@@ -142,7 +142,8 @@ def _get_init_context() -> InitContext:
args=objreg.get('args'))
-def _load_component(info: ExtensionInfo, *, skip_hooks) -> types.ModuleType:
+def _load_component(info: ExtensionInfo, *,
+ skip_hooks=False) -> types.ModuleType:
"""Load the given extension and run its init hook (if any).
Args:
diff --git a/tests/unit/extensions/test_loader.py b/tests/unit/extensions/test_loader.py
index 710b1ce9c..0a7edc9d3 100644
--- a/tests/unit/extensions/test_loader.py
+++ b/tests/unit/extensions/test_loader.py
@@ -17,12 +17,18 @@
# You should have received a copy of the GNU General Public License
# along with qutebrowser. If not, see <http://www.gnu.org/licenses/>.
+import types
+
import pytest
from qutebrowser.extensions import loader
from qutebrowser.misc import objects
+pytestmark = pytest.mark.usefixtures('data_tmpdir', 'config_tmpdir',
+ 'fake_args')
+
+
def test_on_walk_error():
with pytest.raises(ImportError, match='Failed to import foo'):
loader._on_walk_error('foo')
@@ -43,7 +49,94 @@ def test_load_component(monkeypatch):
monkeypatch.setattr(objects, 'commands', {})
info = loader.ExtensionInfo(name='qutebrowser.components.scrollcommands')
- module = loader._load_component(info, skip_hooks=True)
+ mod = loader._load_component(info, skip_hooks=True)
- assert hasattr(module, 'scroll_to_perc')
+ assert hasattr(mod, 'scroll_to_perc')
assert 'scroll-to-perc' in objects.commands
+
+
+@pytest.fixture
+def module(monkeypatch, request):
+ mod = types.ModuleType('testmodule')
+
+ monkeypatch.setattr(loader, '_module_infos', [])
+ monkeypatch.setattr(loader.importlib, 'import_module',
+ lambda _name: mod)
+
+ mod.info = loader.add_module_info(mod)
+ return mod
+
+
+def test_get_init_context(data_tmpdir, config_tmpdir, fake_args):
+ ctx = loader._get_init_context()
+ assert str(ctx.data_dir) == data_tmpdir
+ assert str(ctx.config_dir) == config_tmpdir
+ assert ctx.args == fake_args
+
+
+def test_add_module_info():
+ mod = types.ModuleType('testmodule')
+ info1 = loader.add_module_info(mod)
+ assert mod.__qute_module_info is info1
+
+ info2 = loader.add_module_info(mod)
+ assert mod.__qute_module_info is info1
+ assert info2 is info1
+
+
+class _Hook:
+
+ """Hook to use in tests."""
+
+ __name__ = '_Hook'
+
+ def __init__(self):
+ self.called = False
+ self.raising = False
+
+ def __call__(self, *args):
+ if self.raising:
+ raise Exception("Should not be called!")
+ self.called = True
+
+
+@pytest.fixture
+def hook():
+ return _Hook()
+
+
+def test_skip_hooks(hook, module):
+ hook.raising = True
+
+ module.info.init_hook = hook
+ module.info.config_changed_hooks = [(None, hook)]
+
+ info = loader.ExtensionInfo(name='testmodule')
+ loader._load_component(info, skip_hooks=True)
+ loader._on_config_changed('test')
+
+ assert not hook.called
+
+
+@pytest.mark.parametrize('option_filter, option, called', [
+ (None, 'content.javascript.enabled', True),
+ ('content.javascript', 'content.javascript.enabled', True),
+ ('content.javascript.enabled', 'content.javascript.enabled', True),
+ ('content.javascript.log', 'content.javascript.enabled', False),
+])
+def test_on_config_changed(configdata_init, hook, module,
+ option_filter, option, called):
+ module.info.config_changed_hooks = [(option_filter, hook)]
+
+ info = loader.ExtensionInfo(name='testmodule')
+ loader._load_component(info)
+ loader._on_config_changed(option)
+
+ assert hook.called == called
+
+
+def test_init_hook(hook, module):
+ module.info.init_hook = hook
+ info = loader.ExtensionInfo(name='testmodule')
+ loader._load_component(info)
+ assert hook.called