File: test_cli.py

package info (click to toggle)
python-sshsig 0.2.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 236 kB
  • sloc: python: 901; sh: 53; makefile: 9
file content (54 lines) | stat: -rw-r--r-- 1,788 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
import io
import subprocess
import tempfile
from pathlib import Path

from compat import ssh_keygen
from .test_sshsig import SshKeygenCheckNoValidate

from unittest import TestCase

TESTDATA_DIR = Path(__file__).parent.parent / "testdata"
SSHSIG_CASES = list((TESTDATA_DIR / "sshsig").iterdir())


class CompatTestSshKeygenCheckNoValidate(SshKeygenCheckNoValidate):
    def good_check_novalidate(
        self, message: str, signature: str, namespace: str = "git"
    ) -> bool:
        cmdline = ["ssh-keygen", "-Y", "check-novalidate", "-n", namespace]
        with tempfile.NamedTemporaryFile() as sig_file:
            sig_file.write(signature.encode())
            sig_file.flush()
            cmdline += ["-s", sig_file.name]
            result = subprocess.run(cmdline, input=message.encode())
            return result.returncode == 0


class SimCliCheckNoValidate(SshKeygenCheckNoValidate):

    def good_check_novalidate(
        self, message: str, signature: str, namespace: str = "git"
    ) -> bool:
        args = ["-Y", "check-novalidate", "-n", namespace]
        with tempfile.NamedTemporaryFile() as sig_file:
            sig_file.write(signature.encode())
            sig_file.flush()
            args += ["-s", sig_file.name]
            msg_in = io.BytesIO(message.encode())
            return 0 == ssh_keygen.main(msg_in, args)


class CLITests(TestCase):

    def verify(self, case):
        args = ["-Y", "verify"]
        args += ["-f", str(case / "allowed_signers")]
        args += ["-n", "git"]
        args += ["-s", str(case / "message.sig")]
        args += ["-I", '*']
        with open(case / "message", "rb") as msgin:
            self.assertEqual(0, ssh_keygen.main(msgin, args))

    def test_verify_case_0(self):
        self.verify(SSHSIG_CASES[0])