aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorzhihui wu <wu.zhihui1@zte.com.cn>2017-01-09 02:22:21 +0000
committerGerrit Code Review <gerrit@opnfv.org>2017-01-09 02:22:21 +0000
commit8e1acb5d6bcc8c96f452d269f269a417af85d8af (patch)
tree48f8ab5913be17029066764a654ec8f2ff310650
parentcca988890e67c0a87becd925b9baff11d416c6a5 (diff)
parentb1f9a775036c3bb2823ebe881540c480ec05355e (diff)
Merge "Rework Cli."
-rw-r--r--qtip/cli/entry.py69
-rw-r--r--tests/unit/cli/test_module.py31
-rw-r--r--tests/unit/cli/test_options.py32
3 files changed, 96 insertions, 36 deletions
diff --git a/qtip/cli/entry.py b/qtip/cli/entry.py
index c3ebf96a..0ecb06cd 100644
--- a/qtip/cli/entry.py
+++ b/qtip/cli/entry.py
@@ -7,13 +7,72 @@
# http://www.apache.org/licenses/LICENSE-2.0
##############################################################################
+import os
+import sys
import click
-from qtip.cli.commands import cmd_perftest
-from qtip.cli.commands import cmd_suite
+
CONTEXT_SETTINGS = dict(help_option_names=['-h', '--help'])
-cli = click.CommandCollection(sources=[cmd_perftest.cli, cmd_suite.cli])
-if __name__ == '__main__':
- cli()
+class Context(object):
+
+ ''' TODO(taseer) implementation'''
+
+ def __init__(self):
+ self.verbose = False
+ self.debug = False
+ self.version = 'qtip-1.0.0'
+
+ def log(self, msg, *args):
+ ''' Log message to stderr '''
+ pass
+
+ def verbose(self, msg, *args):
+ ''' Log message to stderr when verbose '''
+ pass
+
+ def version(self):
+ ''' Display programs version '''
+ pass
+
+ def debug(self, msg, *args):
+ ''' Log message to debug '''
+ pass
+
+
+pass_context = click.make_pass_decorator(Context, ensure=True)
+cmd_folder = os.path.abspath(os.path.join(os.path.dirname(__file__),
+ 'commands'))
+
+
+class QtipCli(click.MultiCommand):
+
+ def list_commands(self, ctx):
+ rv = []
+ for filename in os.listdir(cmd_folder):
+ if filename.endswith('.py') and \
+ filename.startswith('cmd_'):
+ rv.append(filename[4:-3])
+ rv.sort()
+ return rv
+
+ def get_command(self, ctx, name):
+ try:
+ if sys.version_info[0] == 2:
+ name = name.encode('ascii', 'replace')
+ mod = __import__('qtip.cli.commands.cmd_' + name,
+ None, None, ['cli'])
+ except ImportError:
+ return
+ return mod.cli
+
+
+@click.command(cls=QtipCli, context_settings=CONTEXT_SETTINGS,
+ invoke_without_command=True)
+@click.option('-v', '--verbose', is_flag=True, help='Enable verbose mode.')
+@click.option('-d', '--debug', is_flag=True, help='Enable debug mode.')
+@click.option('--version', is_flag=True, help='Shows program current version.')
+@pass_context
+def cli(ctx, verbose, version, debug):
+ pass
diff --git a/tests/unit/cli/test_module.py b/tests/unit/cli/test_module.py
deleted file mode 100644
index a8900684..00000000
--- a/tests/unit/cli/test_module.py
+++ /dev/null
@@ -1,31 +0,0 @@
-import os
-import pytest
-import sys
-import yaml
-
-from click.testing import CliRunner
-from qtip.cli.entry import cli
-
-
-class TestClass(object):
- '''TODO(taseer) Remove hardcoded behaviour '''
-
- @pytest.fixture()
- def runner(self):
- return CliRunner()
-
- def test(self, runner):
- unit = 'perftest'
- test_file = 'data/helper/' + unit + '.yaml'
- path = os.path.join(os.path.dirname(__file__), os.pardir, os.pardir, test_file)
-
- with open(path) as trial:
- content = trial.read()
- data = yaml.safe_load(content)['tests']
- if data is None:
- print("Unit Test does not exist")
- sys.exit(1)
- else:
- for i in range(0, len(data)):
- result = runner.invoke(cli, data[i]['command'])
- assert result.output == data[i]['output']
diff --git a/tests/unit/cli/test_options.py b/tests/unit/cli/test_options.py
new file mode 100644
index 00000000..5129b5cc
--- /dev/null
+++ b/tests/unit/cli/test_options.py
@@ -0,0 +1,32 @@
+###############################################################
+# Copyright (c) 2016 ZTE Corp and others.
+#
+# All rights reserved. This program and the accompanying materials
+# are made available under the terms of the Apache License, Version 2.0
+# which accompanies this distribution, and is available at
+# http://www.apache.org/licenses/LICENSE-2.0
+##############################################################################
+
+import pytest
+from click.testing import CliRunner
+
+from qtip.cli.entry import cli
+
+
+class TestClass(object):
+
+ @pytest.fixture()
+ def runner(self):
+ return CliRunner()
+
+ def test_verbose(self, runner):
+ result = runner.invoke(cli, ['-v'])
+ assert result.output == ''
+
+ def test_version(self, runner):
+ result = runner.invoke(cli, ['--version'])
+ assert '' in result.output
+
+ def test_debug(self, runner):
+ result = runner.invoke(cli, ['-d'])
+ assert '' in result.output