diff options
author | Bartek Grzybowski <b.grzybowski@partner.samsung.com> | 2020-05-20 06:34:27 -0700 |
---|---|---|
committer | Bartek Grzybowski <b.grzybowski@partner.samsung.com> | 2020-05-20 06:34:27 -0700 |
commit | 896cc8b36cf5b0b3936f302f3b909f6ad3cfb98d (patch) | |
tree | 79edec9068e6805926180b3b36e00beb41c70125 /test/mocks | |
parent | 50975a2d401f79a57f4a72cd6fa1b0591bf64d81 (diff) |
Add tests for CLI script options
Change-Id: Iea4b353b37297e04b686d41b3494b00f61cfb9f3
Issue-ID: INT-1577
Signed-off-by: Bartek Grzybowski <b.grzybowski@partner.samsung.com>
Diffstat (limited to 'test/mocks')
-rw-r--r-- | test/mocks/mass-pnf-sim/test_cli.py | 47 | ||||
-rw-r--r-- | test/mocks/mass-pnf-sim/tox.ini | 2 |
2 files changed, 48 insertions, 1 deletions
diff --git a/test/mocks/mass-pnf-sim/test_cli.py b/test/mocks/mass-pnf-sim/test_cli.py new file mode 100644 index 000000000..e47b274d3 --- /dev/null +++ b/test/mocks/mass-pnf-sim/test_cli.py @@ -0,0 +1,47 @@ +import MassPnfSim +import pytest + +@pytest.fixture(scope="module") +def parser(): + return MassPnfSim.get_parser() + +@pytest.mark.parametrize(('expect_string, cli_opts'), [ + ("bootstrap: error: the following arguments are required: --urlves, --ipfileserver, --typefileserver, --ipstart", + ['bootstrap']), + ("bootstrap: error: argument --typefileserver: invalid choice: 'dummy' (choose from 'sftp', 'ftps')", + ['bootstrap', '--typefileserver', 'dummy']), + ("bootstrap: error: argument --urlves: invalid_url is not a valid URL", + ['bootstrap', '--urlves', 'invalid_url']), + ("bootstrap: error: argument --ipstart: x.x.x.x is not a valid IP address", + ['bootstrap', '--ipstart', 'x.x.x.x']), + ("trigger_custom: error: the following arguments are required: --triggerstart, --triggerend", + ['trigger_custom']) + ]) +def test_subcommands(parser, capsys, expect_string, cli_opts): + try: + parser.parse_args(cli_opts) + except SystemExit: + pass + assert expect_string in capsys.readouterr().err + +@pytest.mark.parametrize(("subcommand"), [ + 'bootstrap', + 'start', + 'stop', + 'trigger', + 'status' + ]) +def test_count_option(parser, capsys, subcommand): + try: + parser.parse_args([subcommand, '--count']) + except SystemExit: + pass + assert f"{subcommand}: error: argument --count: expected one argument" in capsys.readouterr().err + +def test_empty(parser, capsys): + try: + parser.parse_args([]) + except SystemExit: + pass + assert '' is capsys.readouterr().err + assert '' is capsys.readouterr().out diff --git a/test/mocks/mass-pnf-sim/tox.ini b/test/mocks/mass-pnf-sim/tox.ini index 98be4b667..7e7ba2cde 100644 --- a/test/mocks/mass-pnf-sim/tox.ini +++ b/test/mocks/mass-pnf-sim/tox.ini @@ -6,7 +6,7 @@ deps = pytest [testenv:pytest] basepython = python3 -commands = pytest +commands = pytest -v [testenv:MassPnfSim-runtime] basepython = python3 |