File: fix-test-failure-with-pcre-10.47.patch

package info (click to toggle)
remctl 3.18-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 5,612 kB
  • sloc: ansic: 19,504; sh: 5,386; perl: 1,778; java: 740; makefile: 715; xml: 502; python: 430
file content (48 lines) | stat: -rw-r--r-- 1,862 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
From: Russ Allbery <eagle@eyrie.org>
Date: Sat, 1 Nov 2025 09:26:31 -0700
X-Dgit-Generated: 3.18-5 ad1ff40e2856db2f3a76717540bc1dc5c6257a2c
Subject: Fix test failure with PCRE 10.47

PCRE 10.47 made a minor change in its error reporting that caused
a test failure. Allow for either format. Thanks, Matthew Vernon.

---

diff --git a/tests/server/acl-t.c b/tests/server/acl-t.c
index 8094b52..a1abf6b 100644
--- a/tests/server/acl-t.c
+++ b/tests/server/acl-t.c
@@ -2,7 +2,7 @@
  * Test suite for the server ACL checking.
  *
  * Written by Russ Allbery <eagle@eyrie.org>
- * Copyright 2015-2016, 2018, 2022 Russ Allbery <eagle@eyrie.org>
+ * Copyright 2015-2016, 2018, 2022, 2025 Russ Allbery <eagle@eyrie.org>
  * Copyright 2016 Dropbox, Inc.
  * Copyright 2007-2010, 2012, 2014
  *     The Board of Trustees of the Leland Stanford Junior University
@@ -252,15 +252,20 @@ main(void)
     errors_capture();
     ok(!acl_permit(&rule, "host/bar.org@EXAMPLE.ORG"), "PCRE invalid regex");
 
-    /* Truncate the error message since PCRE2 includes some error detail. */
+    /*
+     * Truncate the error message since PCRE2 includes some error detail. The
+     * error message is truncated one character before the colon to remove the
+     * error position; PCRE 10.46 and earlier reported the error in position 0
+     * and 10.47 and later report the error in position 1.
+     */
     if (strlen(errors) > 8) {
         colon = strchr(errors + 8, ':');
         if (colon != NULL) {
-            colon[0] = '\n';
-            colon[1] = '\0';
+            colon[-1] = '\n';
+            colon[0] = '\0';
         }
     }
-    is_string("TEST:0: compilation of regex '+host/.*' failed around 0\n",
+    is_string("TEST:0: compilation of regex '+host/.*' failed around \n",
               errors, "...with invalid regex error");
     errors_uncapture();
 #else