mirror of
https://github.com/ChristianLight/tutor.git
synced 2025-01-23 05:38:23 +00:00
fix: type tests
Type tests were broken following the upgrade of click. We take the opportunity to simplify the TutorCli implementation.
This commit is contained in:
parent
7e443ac40d
commit
39d3eaf801
@ -32,7 +32,7 @@ def main() -> None:
|
|||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
|
||||||
class TutorCli(click.MultiCommand):
|
class TutorCli(click.Group):
|
||||||
"""
|
"""
|
||||||
Dynamically load subcommands at runtime.
|
Dynamically load subcommands at runtime.
|
||||||
|
|
||||||
@ -43,26 +43,14 @@ class TutorCli(click.MultiCommand):
|
|||||||
|
|
||||||
IS_ROOT_READY = False
|
IS_ROOT_READY = False
|
||||||
|
|
||||||
@classmethod
|
def get_command(
|
||||||
def iter_commands(cls, ctx: click.Context) -> t.Iterator[click.Command]:
|
self, ctx: click.Context, cmd_name: str
|
||||||
|
) -> t.Optional[click.Command]:
|
||||||
"""
|
"""
|
||||||
Return the list of subcommands (click.Command).
|
This is run when passing a command from the CLI. E.g: tutor config ...
|
||||||
"""
|
"""
|
||||||
cls.ensure_plugins_enabled(ctx)
|
self.ensure_plugins_enabled(ctx)
|
||||||
yield from hooks.Filters.CLI_COMMANDS.iterate()
|
return super().get_command(ctx, cmd_name=cmd_name)
|
||||||
|
|
||||||
@classmethod
|
|
||||||
def ensure_plugins_enabled(cls, ctx: click.Context) -> None:
|
|
||||||
"""
|
|
||||||
We enable plugins as soon as possible to have access to commands.
|
|
||||||
"""
|
|
||||||
if not "root" in ctx.params:
|
|
||||||
# When generating docs, this function is called with empty args.
|
|
||||||
# That's ok, we just ignore it.
|
|
||||||
return
|
|
||||||
if not cls.IS_ROOT_READY:
|
|
||||||
hooks.Actions.PROJECT_ROOT_READY.do(ctx.params["root"])
|
|
||||||
cls.IS_ROOT_READY = True
|
|
||||||
|
|
||||||
def list_commands(self, ctx: click.Context) -> list[str]:
|
def list_commands(self, ctx: click.Context) -> list[str]:
|
||||||
"""
|
"""
|
||||||
@ -70,20 +58,22 @@ class TutorCli(click.MultiCommand):
|
|||||||
- shell autocompletion: tutor <tab>
|
- shell autocompletion: tutor <tab>
|
||||||
- print help: tutor, tutor -h
|
- print help: tutor, tutor -h
|
||||||
"""
|
"""
|
||||||
return sorted(
|
self.ensure_plugins_enabled(ctx)
|
||||||
[command.name or "<undefined>" for command in self.iter_commands(ctx)]
|
return super().list_commands(ctx)
|
||||||
)
|
|
||||||
|
|
||||||
def get_command(
|
def ensure_plugins_enabled(self, ctx: click.Context) -> None:
|
||||||
self, ctx: click.Context, cmd_name: str
|
|
||||||
) -> t.Optional[click.Command]:
|
|
||||||
"""
|
"""
|
||||||
This is run when passing a command from the CLI. E.g: tutor config ...
|
We enable plugins as soon as possible to have access to commands.
|
||||||
"""
|
"""
|
||||||
for command in self.iter_commands(ctx):
|
if not "root" in ctx.params:
|
||||||
if cmd_name == command.name:
|
# When generating docs, this function is called with empty args.
|
||||||
return command
|
# That's ok, we just ignore it.
|
||||||
return None
|
return
|
||||||
|
if not self.IS_ROOT_READY:
|
||||||
|
hooks.Actions.PROJECT_ROOT_READY.do(ctx.params["root"])
|
||||||
|
self.IS_ROOT_READY = True
|
||||||
|
for cmd in hooks.Filters.CLI_COMMANDS.iterate():
|
||||||
|
self.add_command(cmd)
|
||||||
|
|
||||||
|
|
||||||
@click.group(
|
@click.group(
|
||||||
|
Loading…
x
Reference in New Issue
Block a user