##// END OF EJS Templates
tests: automatically glob the discovery timing information...
marmoute -
r51290:59fda851 default
parent child Browse files
Show More
@@ -1,211 +1,216
1 # common patterns in test at can safely be replaced
1 # common patterns in test at can safely be replaced
2
2
3 import os
3 import os
4
4
5 substitutions = [
5 substitutions = [
6 # list of possible compressions
6 # list of possible compressions
7 (br'(zstd,)?zlib,none,bzip2', br'$USUAL_COMPRESSIONS$'),
7 (br'(zstd,)?zlib,none,bzip2', br'$USUAL_COMPRESSIONS$'),
8 (br'=(zstd,)?zlib', br'=$BUNDLE2_COMPRESSIONS$'),
8 (br'=(zstd,)?zlib', br'=$BUNDLE2_COMPRESSIONS$'),
9 # capabilities sent through http
9 # capabilities sent through http
10 (
10 (
11 br'bundlecaps=HG20%2Cbundle2%3DHG20%250A'
11 br'bundlecaps=HG20%2Cbundle2%3DHG20%250A'
12 br'bookmarks%250A'
12 br'bookmarks%250A'
13 br'changegroup%253D01%252C02%252C03%250A'
13 br'changegroup%253D01%252C02%252C03%250A'
14 br'checkheads%253Drelated%250A'
14 br'checkheads%253Drelated%250A'
15 br'digests%253Dmd5%252Csha1%252Csha512%250A'
15 br'digests%253Dmd5%252Csha1%252Csha512%250A'
16 br'error%253Dabort%252Cunsupportedcontent%252Cpushraced%252Cpushkey%250A'
16 br'error%253Dabort%252Cunsupportedcontent%252Cpushraced%252Cpushkey%250A'
17 br'hgtagsfnodes%250A'
17 br'hgtagsfnodes%250A'
18 br'listkeys%250A'
18 br'listkeys%250A'
19 br'phases%253Dheads%250A'
19 br'phases%253Dheads%250A'
20 br'pushkey%250A'
20 br'pushkey%250A'
21 br'remote-changegroup%253Dhttp%252Chttps%250A'
21 br'remote-changegroup%253Dhttp%252Chttps%250A'
22 br'stream%253Dv2',
22 br'stream%253Dv2',
23 # (the replacement patterns)
23 # (the replacement patterns)
24 br'$USUAL_BUNDLE_CAPS$',
24 br'$USUAL_BUNDLE_CAPS$',
25 ),
25 ),
26 (
26 (
27 br'bundlecaps=HG20%2Cbundle2%3DHG20%250A'
27 br'bundlecaps=HG20%2Cbundle2%3DHG20%250A'
28 br'bookmarks%250A'
28 br'bookmarks%250A'
29 br'changegroup%253D01%252C02%252C03%250A'
29 br'changegroup%253D01%252C02%252C03%250A'
30 br'checkheads%3Drelated%0A'
30 br'checkheads%3Drelated%0A'
31 br'digests%253Dmd5%252Csha1%252Csha512%250A'
31 br'digests%253Dmd5%252Csha1%252Csha512%250A'
32 br'error%253Dabort%252Cunsupportedcontent%252Cpushraced%252Cpushkey%250A'
32 br'error%253Dabort%252Cunsupportedcontent%252Cpushraced%252Cpushkey%250A'
33 br'hgtagsfnodes%250A'
33 br'hgtagsfnodes%250A'
34 br'listkeys%250A'
34 br'listkeys%250A'
35 br'phases%253Dheads%250A'
35 br'phases%253Dheads%250A'
36 br'pushkey%250A'
36 br'pushkey%250A'
37 br'remote-changegroup%253Dhttp%252Chttps',
37 br'remote-changegroup%253Dhttp%252Chttps',
38 # (the replacement patterns)
38 # (the replacement patterns)
39 br'$USUAL_BUNDLE_CAPS_SERVER$',
39 br'$USUAL_BUNDLE_CAPS_SERVER$',
40 ),
40 ),
41 # bundle2 capabilities sent through ssh
41 # bundle2 capabilities sent through ssh
42 (
42 (
43 br'bundle2=HG20%0A'
43 br'bundle2=HG20%0A'
44 br'bookmarks%0A'
44 br'bookmarks%0A'
45 br'changegroup%3D01%2C02%2C03%0A'
45 br'changegroup%3D01%2C02%2C03%0A'
46 br'checkheads%3Drelated%0A'
46 br'checkheads%3Drelated%0A'
47 br'digests%3Dmd5%2Csha1%2Csha512%0A'
47 br'digests%3Dmd5%2Csha1%2Csha512%0A'
48 br'error%3Dabort%2Cunsupportedcontent%2Cpushraced%2Cpushkey%0A'
48 br'error%3Dabort%2Cunsupportedcontent%2Cpushraced%2Cpushkey%0A'
49 br'hgtagsfnodes%0A'
49 br'hgtagsfnodes%0A'
50 br'listkeys%0A'
50 br'listkeys%0A'
51 br'phases%3Dheads%0A'
51 br'phases%3Dheads%0A'
52 br'pushkey%0A'
52 br'pushkey%0A'
53 br'remote-changegroup%3Dhttp%2Chttps%0A'
53 br'remote-changegroup%3Dhttp%2Chttps%0A'
54 br'stream%3Dv2',
54 br'stream%3Dv2',
55 # (replacement patterns)
55 # (replacement patterns)
56 br'$USUAL_BUNDLE2_CAPS$',
56 br'$USUAL_BUNDLE2_CAPS$',
57 ),
57 ),
58 # bundle2 capabilities advertised by the server
58 # bundle2 capabilities advertised by the server
59 (
59 (
60 br'bundle2=HG20%0A'
60 br'bundle2=HG20%0A'
61 br'bookmarks%0A'
61 br'bookmarks%0A'
62 br'changegroup%3D01%2C02%2C03%0A'
62 br'changegroup%3D01%2C02%2C03%0A'
63 br'checkheads%3Drelated%0A'
63 br'checkheads%3Drelated%0A'
64 br'digests%3Dmd5%2Csha1%2Csha512%0A'
64 br'digests%3Dmd5%2Csha1%2Csha512%0A'
65 br'error%3Dabort%2Cunsupportedcontent%2Cpushraced%2Cpushkey%0A'
65 br'error%3Dabort%2Cunsupportedcontent%2Cpushraced%2Cpushkey%0A'
66 br'hgtagsfnodes%0A'
66 br'hgtagsfnodes%0A'
67 br'listkeys%0A'
67 br'listkeys%0A'
68 br'phases%3Dheads%0A'
68 br'phases%3Dheads%0A'
69 br'pushkey%0A'
69 br'pushkey%0A'
70 br'remote-changegroup%3Dhttp%2Chttps',
70 br'remote-changegroup%3Dhttp%2Chttps',
71 # (replacement patterns)
71 # (replacement patterns)
72 br'$USUAL_BUNDLE2_CAPS_SERVER$',
72 br'$USUAL_BUNDLE2_CAPS_SERVER$',
73 ),
73 ),
74 (
74 (
75 br'bundle2=HG20%0A'
75 br'bundle2=HG20%0A'
76 br'bookmarks%0A'
76 br'bookmarks%0A'
77 br'changegroup%3D01%2C02%2C03%0A'
77 br'changegroup%3D01%2C02%2C03%0A'
78 br'digests%3Dmd5%2Csha1%2Csha512%0A'
78 br'digests%3Dmd5%2Csha1%2Csha512%0A'
79 br'error%3Dabort%2Cunsupportedcontent%2Cpushraced%2Cpushkey%0A'
79 br'error%3Dabort%2Cunsupportedcontent%2Cpushraced%2Cpushkey%0A'
80 br'hgtagsfnodes%0A'
80 br'hgtagsfnodes%0A'
81 br'listkeys%0A'
81 br'listkeys%0A'
82 br'pushkey%0A'
82 br'pushkey%0A'
83 br'remote-changegroup%3Dhttp%2Chttps%0A'
83 br'remote-changegroup%3Dhttp%2Chttps%0A'
84 br'stream%3Dv2',
84 br'stream%3Dv2',
85 # (replacement patterns)
85 # (replacement patterns)
86 br'$USUAL_BUNDLE2_CAPS_NO_PHASES$',
86 br'$USUAL_BUNDLE2_CAPS_NO_PHASES$',
87 ),
87 ),
88 # HTTP access log dates
88 # HTTP access log dates
89 (
89 (
90 br' - - \[\d\d/.../2\d\d\d \d\d:\d\d:\d\d] "(GET|PUT|POST)',
90 br' - - \[\d\d/.../2\d\d\d \d\d:\d\d:\d\d] "(GET|PUT|POST)',
91 lambda m: br' - - [$LOGDATE$] "' + m.group(1),
91 lambda m: br' - - [$LOGDATE$] "' + m.group(1),
92 ),
92 ),
93 # HTTP error log dates
93 # HTTP error log dates
94 (
94 (
95 br' - - \[\d\d/.../2\d\d\d \d\d:\d\d:\d\d] (HG error:|Exception)',
95 br' - - \[\d\d/.../2\d\d\d \d\d:\d\d:\d\d] (HG error:|Exception)',
96 lambda m: br' - - [$ERRDATE$] ' + m.group(1),
96 lambda m: br' - - [$ERRDATE$] ' + m.group(1),
97 ),
97 ),
98 # HTTP header dates- RFC 1123
98 # HTTP header dates- RFC 1123
99 (
99 (
100 br'([Dd]ate): [A-Za-z]{3}, \d\d [A-Za-z]{3} \d{4} \d\d:\d\d:\d\d GMT',
100 br'([Dd]ate): [A-Za-z]{3}, \d\d [A-Za-z]{3} \d{4} \d\d:\d\d:\d\d GMT',
101 lambda m: br'%s: $HTTP_DATE$' % m.group(1),
101 lambda m: br'%s: $HTTP_DATE$' % m.group(1),
102 ),
102 ),
103 # LFS expiration value
103 # LFS expiration value
104 (
104 (
105 br'"expires_at": "\d{4}-\d\d-\d\dT\d\d:\d\d:\d\dZ"',
105 br'"expires_at": "\d{4}-\d\d-\d\dT\d\d:\d\d:\d\dZ"',
106 br'"expires_at": "$ISO_8601_DATE_TIME$"',
106 br'"expires_at": "$ISO_8601_DATE_TIME$"',
107 ),
107 ),
108 # Windows has an extra '/' in the following lines that get globbed away:
108 # Windows has an extra '/' in the following lines that get globbed away:
109 # pushing to file:/*/$TESTTMP/r2 (glob)
109 # pushing to file:/*/$TESTTMP/r2 (glob)
110 # comparing with file:/*/$TESTTMP/r2 (glob)
110 # comparing with file:/*/$TESTTMP/r2 (glob)
111 # sub/maybelarge.dat: largefile 34..9c not available from
111 # sub/maybelarge.dat: largefile 34..9c not available from
112 # file:/*/$TESTTMP/largefiles-repo (glob)
112 # file:/*/$TESTTMP/largefiles-repo (glob)
113 (
113 (
114 br'(.*file:/)/?(/\$TESTTMP.*)',
114 br'(.*file:/)/?(/\$TESTTMP.*)',
115 lambda m: m.group(1) + b'*' + m.group(2) + b' (glob)',
115 lambda m: m.group(1) + b'*' + m.group(2) + b' (glob)',
116 ),
116 ),
117 # `hg clone --stream` output
117 # `hg clone --stream` output
118 (
118 (
119 br'transferred (\S+?) KB in \S+? seconds \(.+?/sec\)(?: \(glob\))?(.*)',
119 br'transferred (\S+?) KB in \S+? seconds \(.+?/sec\)(?: \(glob\))?(.*)',
120 lambda m: (
120 lambda m: (
121 br'transferred %s KB in * seconds (* */sec) (glob)%s'
121 br'transferred %s KB in * seconds (* */sec) (glob)%s'
122 % (m.group(1), m.group(2))
122 % (m.group(1), m.group(2))
123 ),
123 ),
124 ),
124 ),
125 # `discovery debug output
126 (
127 br'\b(\d+) total queries in \d.\d\d\d\ds\b',
128 lambda m: (br'%s total queries in *.????s (glob)' % m.group(1)),
129 ),
125 ]
130 ]
126
131
127 # Various platform error strings, keyed on a common replacement string
132 # Various platform error strings, keyed on a common replacement string
128 _errors = {
133 _errors = {
129 br'$ENOENT$': (
134 br'$ENOENT$': (
130 # IOError in Python does not have the same error message
135 # IOError in Python does not have the same error message
131 # than in Rust, and automatic conversion is not possible
136 # than in Rust, and automatic conversion is not possible
132 # because of module member privacy.
137 # because of module member privacy.
133 br'No such file or directory \(os error 2\)',
138 br'No such file or directory \(os error 2\)',
134 # strerror()
139 # strerror()
135 br'No such file or directory',
140 br'No such file or directory',
136 # FormatMessage(ERROR_FILE_NOT_FOUND)
141 # FormatMessage(ERROR_FILE_NOT_FOUND)
137 br'The system cannot find the file specified',
142 br'The system cannot find the file specified',
138 ),
143 ),
139 br'$EACCES$': (
144 br'$EACCES$': (
140 br'Permission denied \(os error 13\)',
145 br'Permission denied \(os error 13\)',
141 # strerror
146 # strerror
142 br'Permission denied',
147 br'Permission denied',
143 ),
148 ),
144 br'$ENOTDIR$': (
149 br'$ENOTDIR$': (
145 # strerror()
150 # strerror()
146 br'Not a directory',
151 br'Not a directory',
147 # FormatMessage(ERROR_PATH_NOT_FOUND)
152 # FormatMessage(ERROR_PATH_NOT_FOUND)
148 br'The system cannot find the path specified',
153 br'The system cannot find the path specified',
149 ),
154 ),
150 br'$ECONNRESET$': (
155 br'$ECONNRESET$': (
151 # strerror()
156 # strerror()
152 br'Connection reset by peer',
157 br'Connection reset by peer',
153 # FormatMessage(WSAECONNRESET)
158 # FormatMessage(WSAECONNRESET)
154 br'An existing connection was forcibly closed by the remote host',
159 br'An existing connection was forcibly closed by the remote host',
155 ),
160 ),
156 br'$EADDRINUSE$': (
161 br'$EADDRINUSE$': (
157 # strerror()
162 # strerror()
158 br'Address already in use',
163 br'Address already in use',
159 # FormatMessage(WSAEADDRINUSE)
164 # FormatMessage(WSAEADDRINUSE)
160 br'Only one usage of each socket address'
165 br'Only one usage of each socket address'
161 br' \(protocol/network address/port\) is normally permitted',
166 br' \(protocol/network address/port\) is normally permitted',
162 ),
167 ),
163 br'$EADDRNOTAVAIL$': (
168 br'$EADDRNOTAVAIL$': (
164 # strerror()
169 # strerror()
165 br'Cannot assign requested address',
170 br'Cannot assign requested address',
166 br'Can\'t assign requested address',
171 br'Can\'t assign requested address',
167 # FormatMessage(WSAEADDRNOTAVAIL)
172 # FormatMessage(WSAEADDRNOTAVAIL)
168 ),
173 ),
169 }
174 }
170
175
171 for replace, msgs in _errors.items():
176 for replace, msgs in _errors.items():
172 substitutions.extend((m, replace) for m in msgs)
177 substitutions.extend((m, replace) for m in msgs)
173
178
174 # Output lines on Windows that can be autocorrected for '\' vs '/' path
179 # Output lines on Windows that can be autocorrected for '\' vs '/' path
175 # differences.
180 # differences.
176 _winpathfixes = [
181 _winpathfixes = [
177 # cloning subrepo s\ss from $TESTTMP/t/s/ss
182 # cloning subrepo s\ss from $TESTTMP/t/s/ss
178 # cloning subrepo foo\bar from http://localhost:$HGPORT/foo/bar
183 # cloning subrepo foo\bar from http://localhost:$HGPORT/foo/bar
179 br'(?m)^cloning subrepo \S+\\.*',
184 br'(?m)^cloning subrepo \S+\\.*',
180 # pulling from $TESTTMP\issue1852a
185 # pulling from $TESTTMP\issue1852a
181 br'(?m)^pulling from \$TESTTMP\\.*',
186 br'(?m)^pulling from \$TESTTMP\\.*',
182 # pushing to $TESTTMP\a
187 # pushing to $TESTTMP\a
183 br'(?m)^pushing to \$TESTTMP\\.*',
188 br'(?m)^pushing to \$TESTTMP\\.*',
184 # pushing subrepo s\ss to $TESTTMP/t/s/ss
189 # pushing subrepo s\ss to $TESTTMP/t/s/ss
185 br'(?m)^pushing subrepo \S+\\\S+ to.*',
190 br'(?m)^pushing subrepo \S+\\\S+ to.*',
186 # moving d1\d11\a1 to d3/d11/a1
191 # moving d1\d11\a1 to d3/d11/a1
187 br'(?m)^moving \S+\\.*',
192 br'(?m)^moving \S+\\.*',
188 # d1\a: not recording move - dummy does not exist
193 # d1\a: not recording move - dummy does not exist
189 br'\S+\\\S+: not recording move .+',
194 br'\S+\\\S+: not recording move .+',
190 # reverting s\a
195 # reverting s\a
191 br'(?m)^reverting (?!subrepo ).*\\.*',
196 br'(?m)^reverting (?!subrepo ).*\\.*',
192 # saved backup bundle to
197 # saved backup bundle to
193 # $TESTTMP\test\.hg\strip-backup/443431ffac4f-2fc5398a-backup.hg
198 # $TESTTMP\test\.hg\strip-backup/443431ffac4f-2fc5398a-backup.hg
194 br'(?m)^saved backup bundle to \$TESTTMP.*\.hg',
199 br'(?m)^saved backup bundle to \$TESTTMP.*\.hg',
195 # no changes made to subrepo s\ss since last push to ../tcc/s/ss
200 # no changes made to subrepo s\ss since last push to ../tcc/s/ss
196 br'(?m)^no changes made to subrepo \S+\\\S+ since.*',
201 br'(?m)^no changes made to subrepo \S+\\\S+ since.*',
197 # changeset 5:9cc5aa7204f0: stuff/maybelarge.dat references missing
202 # changeset 5:9cc5aa7204f0: stuff/maybelarge.dat references missing
198 # $TESTTMP\largefiles-repo-hg\.hg\largefiles\76..38
203 # $TESTTMP\largefiles-repo-hg\.hg\largefiles\76..38
199 br'(?m)^changeset .* references (corrupted|missing) \$TESTTMP\\.*',
204 br'(?m)^changeset .* references (corrupted|missing) \$TESTTMP\\.*',
200 # stuff/maybelarge.dat: largefile 76..38 not available from
205 # stuff/maybelarge.dat: largefile 76..38 not available from
201 # file:/*/$TESTTMP\largefiles-repo (glob)
206 # file:/*/$TESTTMP\largefiles-repo (glob)
202 br'.*: largefile \S+ not available from file:/\*/.+',
207 br'.*: largefile \S+ not available from file:/\*/.+',
203 ]
208 ]
204
209
205 if os.name == 'nt':
210 if os.name == 'nt':
206 substitutions.extend(
211 substitutions.extend(
207 [
212 [
208 (s, lambda match: match.group().replace(b'\\', b'/'))
213 (s, lambda match: match.group().replace(b'\\', b'/'))
209 for s in _winpathfixes
214 for s in _winpathfixes
210 ]
215 ]
211 )
216 )
General Comments 0
You need to be logged in to leave comments. Login now