File: test_cli.py

package info (click to toggle)
getmac 0.9.5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 976 kB
  • sloc: python: 2,133; sh: 84; makefile: 23
file content (79 lines) | stat: -rw-r--r-- 2,176 bytes parent folder | download
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]) != ""