/mandos/trunk

To get this branch, use:
bzr branch http://bzr.recompile.se/loggerhead/mandos/trunk

« back to all changes in this revision

Viewing changes to mandos-ctl

  • Committer: Teddy Hogeborn
  • Date: 2022-04-24 11:04:54 UTC
  • Revision ID: teddy@recompile.se-20220424110454-p1tgedieq5eg74q1
Server: Fix minor style issue

* mandos-ctl: Consistently use double quotes instead of single quotes.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
#!/usr/bin/python3 -bbI
2
 
# -*- coding: utf-8; lexical-binding: t -*-
 
2
# -*- after-save-hook: (lambda () (let ((command (if (fboundp 'file-local-name) (file-local-name (buffer-file-name)) (or (file-remote-p (buffer-file-name) 'localname) (buffer-file-name))))) (if (= (progn (if (get-buffer "*Test*") (kill-buffer "*Test*")) (process-file-shell-command (format "%s --check" (shell-quote-argument command)) nil "*Test*")) 0) (let ((w (get-buffer-window "*Test*"))) (if w (delete-window w))) (progn (with-current-buffer "*Test*" (compilation-mode)) (display-buffer "*Test*" '(display-buffer-in-side-window)))))); coding: utf-8 -*-
3
3
#
4
4
# Mandos Control - Control or query the Mandos server
5
5
#
23
23
#
24
24
# Contact the authors at <mandos@recompile.se>.
25
25
#
 
26
 
26
27
from __future__ import (division, absolute_import, print_function,
27
28
                        unicode_literals)
28
29
 
32
33
    pass
33
34
 
34
35
import sys
35
 
import unittest
36
36
import argparse
37
 
import logging
38
 
import os
39
37
import locale
40
38
import datetime
41
39
import re
 
40
import os
42
41
import collections
43
42
import json
 
43
import unittest
 
44
import logging
44
45
import io
45
46
import tempfile
46
47
import contextlib
48
49
if sys.version_info.major == 2:
49
50
    __metaclass__ = type
50
51
    str = unicode
51
 
    input = raw_input
52
52
 
53
53
class gi:
54
54
    """Dummy gi module, for the tests"""
77
77
    import warnings
78
78
    warnings.simplefilter("default")
79
79
 
80
 
log = logging.getLogger(os.path.basename(sys.argv[0]))
 
80
log = logging.getLogger(sys.argv[0])
81
81
logging.basicConfig(level="INFO", # Show info level messages
82
82
                    format="%(message)s") # Show basic log messages
83
83
 
2742
2742
class TestSetSecretCmd(TestPropertySetterCmd):
2743
2743
    command = command.SetSecret
2744
2744
    propname = "Secret"
2745
 
    def __init__(self, *args, **kwargs):
2746
 
        self.values_to_set = [io.BytesIO(b""),
2747
 
                              io.BytesIO(b"secret\0xyzzy\nbar")]
2748
 
        self.values_to_get = [f.getvalue() for f in
2749
 
                              self.values_to_set]
2750
 
        super(TestSetSecretCmd, self).__init__(*args, **kwargs)
 
2745
    values_to_set = [io.BytesIO(b""),
 
2746
                     io.BytesIO(b"secret\0xyzzy\nbar")]
 
2747
    values_to_get = [f.getvalue() for f in values_to_set]
2751
2748
 
2752
2749
 
2753
2750
class TestSetTimeoutCmd(TestPropertySetterCmd):
2806
2803
 
2807
2804
 
2808
2805
 
2809
 
def parse_test_args():
2810
 
    # type: () -> argparse.Namespace
 
2806
def should_only_run_tests():
2811
2807
    parser = argparse.ArgumentParser(add_help=False)
2812
 
    parser.add_argument("--check", action="store_true")
2813
 
    parser.add_argument("--prefix", )
 
2808
    parser.add_argument("--check", action='store_true')
2814
2809
    args, unknown_args = parser.parse_known_args()
2815
 
    if args.check:
2816
 
        # Remove test options from sys.argv
 
2810
    run_tests = args.check
 
2811
    if run_tests:
 
2812
        # Remove --check argument from sys.argv
2817
2813
        sys.argv[1:] = unknown_args
2818
 
    return args
 
2814
    return run_tests
2819
2815
 
2820
2816
# Add all tests from doctest strings
2821
2817
def load_tests(loader, tests, none):
2824
2820
    return tests
2825
2821
 
2826
2822
if __name__ == "__main__":
2827
 
    options = parse_test_args()
2828
2823
    try:
2829
 
        if options.check:
2830
 
            extra_test_prefix = options.prefix
2831
 
            if extra_test_prefix is not None:
2832
 
                if not (unittest.main(argv=[""], exit=False)
2833
 
                        .result.wasSuccessful()):
2834
 
                    sys.exit(1)
2835
 
                class ExtraTestLoader(unittest.TestLoader):
2836
 
                    testMethodPrefix = extra_test_prefix
2837
 
                # Call using ./scriptname --check [--verbose]
2838
 
                unittest.main(argv=[""], testLoader=ExtraTestLoader())
2839
 
            else:
2840
 
                unittest.main(argv=[""])
 
2824
        if should_only_run_tests():
 
2825
            # Call using ./tdd-python-script --check [--verbose]
 
2826
            unittest.main()
2841
2827
        else:
2842
2828
            main()
2843
2829
    finally:
2844
2830
        logging.shutdown()
2845
 
 
2846
 
# Local Variables:
2847
 
# run-tests:
2848
 
# (lambda (&optional extra)
2849
 
#   (if (not (funcall run-tests-in-test-buffer default-directory
2850
 
#             extra))
2851
 
#       (funcall show-test-buffer-in-test-window)
2852
 
#     (funcall remove-test-window)
2853
 
#     (if extra (message "Extra tests run successfully!"))))
2854
 
# run-tests-in-test-buffer:
2855
 
# (lambda (dir &optional extra)
2856
 
#   (with-current-buffer (get-buffer-create "*Test*")
2857
 
#     (setq buffer-read-only nil
2858
 
#           default-directory dir)
2859
 
#     (erase-buffer)
2860
 
#     (compilation-mode))
2861
 
#   (let ((inhibit-read-only t))
2862
 
#     (= (process-file-shell-command
2863
 
#         (funcall get-command-line extra)
2864
 
#         nil "*Test*") 0)))
2865
 
# get-command-line:
2866
 
# (lambda (&optional extra)
2867
 
#   (let ((quoted-script
2868
 
#          (shell-quote-argument (funcall get-script-name))))
2869
 
#     (format
2870
 
#      (concat "%s --check" (if extra " --prefix=atest" ""))
2871
 
#      quoted-script)))
2872
 
# get-script-name:
2873
 
# (lambda ()
2874
 
#   (if (fboundp 'file-local-name)
2875
 
#       (file-local-name (buffer-file-name))
2876
 
#     (or (file-remote-p (buffer-file-name) 'localname)
2877
 
#         (buffer-file-name))))
2878
 
# remove-test-window:
2879
 
# (lambda ()
2880
 
#   (let ((test-window (get-buffer-window "*Test*")))
2881
 
#     (if test-window (delete-window test-window))))
2882
 
# show-test-buffer-in-test-window:
2883
 
# (lambda ()
2884
 
#   (when (not (get-buffer-window-list "*Test*"))
2885
 
#     (setq next-error-last-buffer (get-buffer "*Test*"))
2886
 
#     (let* ((side (if (>= (window-width) 146) 'right 'bottom))
2887
 
#            (display-buffer-overriding-action
2888
 
#             `((display-buffer-in-side-window) (side . ,side)
2889
 
#               (window-height . fit-window-to-buffer)
2890
 
#               (window-width . fit-window-to-buffer))))
2891
 
#       (display-buffer "*Test*"))))
2892
 
# eval:
2893
 
# (progn
2894
 
#   (let* ((run-extra-tests (lambda () (interactive)
2895
 
#                             (funcall run-tests t)))
2896
 
#          (inner-keymap `(keymap (116 . ,run-extra-tests))) ; t
2897
 
#          (outer-keymap `(keymap (3 . ,inner-keymap))))     ; C-c
2898
 
#     (setq minor-mode-overriding-map-alist
2899
 
#           (cons `(run-tests . ,outer-keymap)
2900
 
#                 minor-mode-overriding-map-alist)))
2901
 
#   (add-hook 'after-save-hook run-tests 90 t))
2902
 
# End: