blob: 0f464167a3a51cae03346ba068fcff6b784bf683 [file] [log] [blame]
Bartek Grzybowski896cc8b2020-05-20 06:34:27 -07001import pytest
Bartek Grzybowski5196e332020-05-25 03:10:39 -07002from MassPnfSim import MassPnfSim
3from test_settings import SIM_INSTANCES
Bartek Grzybowski896cc8b2020-05-20 06:34:27 -07004
Bartek Grzybowski896cc8b2020-05-20 06:34:27 -07005@pytest.mark.parametrize(('expect_string, cli_opts'), [
6 ("bootstrap: error: the following arguments are required: --urlves, --ipfileserver, --typefileserver, --ipstart",
7 ['bootstrap']),
8 ("bootstrap: error: argument --typefileserver: invalid choice: 'dummy' (choose from 'sftp', 'ftps')",
9 ['bootstrap', '--typefileserver', 'dummy']),
10 ("bootstrap: error: argument --urlves: invalid_url is not a valid URL",
11 ['bootstrap', '--urlves', 'invalid_url']),
12 ("bootstrap: error: argument --ipstart: x.x.x.x is not a valid IP address",
13 ['bootstrap', '--ipstart', 'x.x.x.x']),
14 ("trigger_custom: error: the following arguments are required: --triggerstart, --triggerend",
15 ['trigger_custom'])
16 ])
17def test_subcommands(parser, capsys, expect_string, cli_opts):
18 try:
19 parser.parse_args(cli_opts)
20 except SystemExit:
21 pass
22 assert expect_string in capsys.readouterr().err
23
Bartek Grzybowski5196e332020-05-25 03:10:39 -070024def test_validate_trigger_custom(parser, caplog):
25 args = parser.parse_args(['trigger_custom', '--triggerstart', '0',
26 '--triggerend', str(SIM_INSTANCES)])
27 try:
28 MassPnfSim(args).trigger_custom()
29 except SystemExit as e:
30 assert e.code == 1
31 assert "--triggerend value greater than existing instance count" in caplog.text
32 caplog.clear()
33
Bartek Grzybowski896cc8b2020-05-20 06:34:27 -070034@pytest.mark.parametrize(("subcommand"), [
35 'bootstrap',
36 'start',
37 'stop',
38 'trigger',
39 'status'
40 ])
41def test_count_option(parser, capsys, subcommand):
Bartek Grzybowskidf5004b2020-06-05 11:32:44 +020042 '''Test case where no arg passed to '--count' opt'''
Bartek Grzybowski896cc8b2020-05-20 06:34:27 -070043 try:
44 parser.parse_args([subcommand, '--count'])
45 except SystemExit:
46 pass
47 assert f"{subcommand}: error: argument --count: expected one argument" in capsys.readouterr().err
48
Bartek Grzybowskidf5004b2020-06-05 11:32:44 +020049@pytest.mark.parametrize(("subcommand"), [
50 'start',
51 'stop',
52 'trigger',
53 'status'
54 ])
55def test_count_option_bad_value(parser, caplog, subcommand):
56 '''Test case where invalid value passed to '--count' opt'''
57 try:
58 args = parser.parse_args([subcommand, '--count', str(SIM_INSTANCES + 1)])
59 m = getattr(MassPnfSim(args), subcommand)
60 m()
61 except SystemExit:
62 pass
63 assert '--count value greater that existing instance count' in caplog.text
64 caplog.clear()
65
Bartek Grzybowski896cc8b2020-05-20 06:34:27 -070066def test_empty(parser, capsys):
67 try:
68 parser.parse_args([])
69 except SystemExit:
70 pass
71 assert '' is capsys.readouterr().err
72 assert '' is capsys.readouterr().out