Fix endless recursion while validating aliases
This commit is contained in:
parent
ac78039171
commit
065f82f485
@ -726,18 +726,32 @@ class Command(BaseType):
|
|||||||
|
|
||||||
"""Base class for a command value with arguments."""
|
"""Base class for a command value with arguments."""
|
||||||
|
|
||||||
|
# See to_py for details
|
||||||
|
unvalidated = False
|
||||||
|
|
||||||
def to_py(self, value):
|
def to_py(self, value):
|
||||||
self._basic_py_validation(value, str)
|
self._basic_py_validation(value, str)
|
||||||
if not value:
|
if not value:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
# FIXME:conf is it okay to import runners.py here?
|
# This requires some trickery, as runners.CommandParser uses
|
||||||
|
# conf.val.aliases, which in turn map to a command again,
|
||||||
|
# leading to an endless recursion.
|
||||||
|
# To fix that, we turn off validating other commands (alias values)
|
||||||
|
# while validating a command.
|
||||||
|
# FIXME:conf Can't test this because we don't have a real config in
|
||||||
|
# TestCommand
|
||||||
|
if not Command.unvalidated: # pragma: no branch
|
||||||
|
Command.unvalidated = True
|
||||||
|
try:
|
||||||
from qutebrowser.commands import runners, cmdexc
|
from qutebrowser.commands import runners, cmdexc
|
||||||
parser = runners.CommandParser()
|
parser = runners.CommandParser()
|
||||||
try:
|
try:
|
||||||
list(parser.parse_all(value))
|
list(parser.parse_all(value))
|
||||||
except cmdexc.Error as e:
|
except cmdexc.Error as e:
|
||||||
raise configexc.ValidationError(value, str(e))
|
raise configexc.ValidationError(value, str(e))
|
||||||
|
finally:
|
||||||
|
Command.unvalidated = False
|
||||||
|
|
||||||
return value
|
return value
|
||||||
|
|
||||||
|
@ -1035,6 +1035,7 @@ class TestCommand:
|
|||||||
'cmd2': stubs.FakeCommand(desc="desc 2")})
|
'cmd2': stubs.FakeCommand(desc="desc 2")})
|
||||||
monkeypatch.setattr(configtypes, 'cmdutils', cmd_utils)
|
monkeypatch.setattr(configtypes, 'cmdutils', cmd_utils)
|
||||||
# FIXME:conf use some kind of config_stub here
|
# FIXME:conf use some kind of config_stub here
|
||||||
|
# also remove the no branch pragma from configtypes.Command then
|
||||||
ns = types.SimpleNamespace()
|
ns = types.SimpleNamespace()
|
||||||
ns.aliases = {'alias': 'cmd1'}
|
ns.aliases = {'alias': 'cmd1'}
|
||||||
monkeypatch.setattr('qutebrowser.config.config.val', ns)
|
monkeypatch.setattr('qutebrowser.config.config.val', ns)
|
||||||
|
Loading…
Reference in New Issue
Block a user