-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathtest_cli.py
79 lines (51 loc) · 2.13 KB
/
test_cli.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# -*- coding: utf-8 -*-
import platform
import sys
from subprocess import PIPE, Popen
import pytest
from getmac import __version__, get_mac_address
PY2 = sys.version_info[0] == 2
BASE_CMD = [sys.executable, "-m", "getmac"]
def run_cmd(command):
# type: (list) -> str
stdout, _ = Popen(command, stdout=PIPE, stderr=PIPE).communicate()
return stdout.decode("utf-8").strip()
def test_cli_main_basic():
assert run_cmd(BASE_CMD) == get_mac_address()
def test_cli_main_verbose():
assert get_mac_address() in run_cmd(BASE_CMD + ["--verbose"])
def test_cli_main_debug():
assert get_mac_address() in run_cmd(BASE_CMD + ["--verbose", "--debug"])
def test_cli_main_invalid_interface():
assert run_cmd(BASE_CMD + ["--interface", "INVALIDTESTINTERFACE"]) == ""
def test_cli_help():
assert run_cmd(BASE_CMD + ["--help"]) != ""
@pytest.mark.skipif(
PY2,
reason="This doesn't work in Python 2.7 "
"and I don't care enough to figure out why",
)
def test_cli_version():
assert __version__ in run_cmd(BASE_CMD + ["--version"])
def test_cli_multiple_debug_levels():
assert get_mac_address() in run_cmd(BASE_CMD + ["-v", "-dd"])
assert get_mac_address() in run_cmd(BASE_CMD + ["-v", "-ddd"])
assert get_mac_address() in run_cmd(BASE_CMD + ["-v", "-dddd"])
def test_cli_no_net():
assert get_mac_address(hostname="localhost") in run_cmd(
BASE_CMD + ["-n", "localhost", "--no-network-requests"]
)
def test_cli_override_port():
assert (
run_cmd(BASE_CMD + ["-v", "-dd", "-4", "127.0.0.1", "--override-port", "44444"])
!= ""
)
def test_cli_localhost():
assert run_cmd(BASE_CMD + ["-4", "127.0.0.1"]) != ""
assert run_cmd(BASE_CMD + ["-n", "localhost"]) != ""
assert run_cmd(BASE_CMD + ["--no-network-requests", "-4", "127.0.0.1"]) != ""
assert run_cmd(BASE_CMD + ["--no-network-requests", "-n", "localhost"]) != ""
# TODO: figure out how to properly test CLI commands and isolate platform-specific behavior
def test_cli_override_platform():
plat = platform.system().lower()
assert run_cmd(BASE_CMD + ["-v", "-dd", "--override-platform", plat]) != ""