summaryrefslogtreecommitdiff
path: root/gnu/packages/patches/u-boot-patman-get-maintainer.patch
blob: 4377f8394eb86eb54c909dc43ab3797f116dec84 (plain)
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
Upstream status: https://patchwork.ozlabs.org/project/uboot/list/?series=333427

diff --git a/tools/patman/patman.rst b/tools/patman/patman.rst
index 7828899879..95b6c9c3f0 100644
--- a/tools/patman/patman.rst
+++ b/tools/patman/patman.rst
@@ -88,7 +88,7 @@ To add your own, create a file `~/.patman` like this::
 Patman will also look for a `.patman` configuration file at the root
 of the current project git repository, which makes it possible to
 override the `project` settings variable or anything else in a
-project-specific way.  The values of this "local" configuration file
+project-specific way. The values of this "local" configuration file
 take precedence over those of the "global" one.
 
 Aliases are recursive.
diff --git a/tools/patman/test_settings.py b/tools/patman/test_settings.py
index 9c14b4aaa3..c768a2fc64 100644
--- a/tools/patman/test_settings.py
+++ b/tools/patman/test_settings.py
@@ -6,38 +6,62 @@
 import argparse
 import contextlib
 import os
-import subprocess
+import sys
 import tempfile
 
 from patman import settings
+from patman import tools
 
 
 @contextlib.contextmanager
 def empty_git_repository():
     with tempfile.TemporaryDirectory() as tmpdir:
         os.chdir(tmpdir)
-        subprocess.check_call(['git', 'init'])
+        tools.run('git', 'init', raise_on_error=True)
         yield tmpdir
 
 
+@contextlib.contextmanager
+def cleared_command_line_args():
+    old_value = sys.argv[:]
+    sys.argv = [sys.argv[0]]
+    try:
+        yield
+    finally:
+        sys.argv = old_value
+
+
 def test_git_local_config():
-    with empty_git_repository():
-        with tempfile.NamedTemporaryFile() as global_config:
-            global_config.write(b'[settings]\n'
-                                b'project=u-boot\n')
-            global_config.flush()
-            parser = argparse.ArgumentParser()
-            parser.add_argument('-p', '--project', default='unknown')
-
-            # Test "global" config is used.
-            settings.Setup(parser, 'unknown', global_config.name)
-            args, _ = parser.parse_known_args()
-            assert args.project == 'u-boot'
-
-            # Test local config can shadow it.
-            with open('.patman', 'w', buffering=1) as f:
-                f.write('[settings]\n'
-                        'project=guix-patches\n')
-            settings.Setup(parser, 'unknown', global_config.name)
-            args, _ = parser.parse_known_args([])
-            assert args.project == 'guix-patches'
+    # Clearing the command line arguments is required, otherwise
+    # arguments passed to the test running such as in 'pytest -k
+    # filter' would be processed by _UpdateDefaults and fail.
+    with cleared_command_line_args():
+        with empty_git_repository():
+            with tempfile.NamedTemporaryFile() as global_config:
+                global_config.write(b'[settings]\n'
+                                    b'project=u-boot\n')
+                global_config.flush()
+                parser = argparse.ArgumentParser()
+                parser.add_argument('-p', '--project', default='unknown')
+                subparsers = parser.add_subparsers(dest='cmd')
+                send = subparsers.add_parser('send')
+                send.add_argument('--no-check', action='store_false',
+                                  dest='check_patch', default=True)
+
+                # Test "global" config is used.
+                settings.Setup(parser, 'unknown', global_config.name)
+                args, _ = parser.parse_known_args([])
+                assert args.project == 'u-boot'
+                send_args, _ = send.parse_known_args([])
+                assert send_args.check_patch
+
+                # Test local config can shadow it.
+                with open('.patman', 'w', buffering=1) as f:
+                    f.write('[settings]\n'
+                            'project: guix-patches\n'
+                            'check_patch: False\n')
+                settings.Setup(parser, 'unknown', global_config.name)
+                args, _ = parser.parse_known_args([])
+                assert args.project == 'guix-patches'
+                send_args, _ = send.parse_known_args([])
+                assert not send_args.check_patch