author | Mads Kiilerich <mads@kiilerich.com> |
Sat, 14 Jan 2012 01:56:27 +0100 | |
branch | stable |
changeset 15942 | d7a34c07e69b |
parent 15443 | a1914d214579 |
child 16857 | 1415edd88c56 |
permissions | -rw-r--r-- |
15443
a1914d214579
tests: use 'hghave unix-permissions' for tests that really use chmod
Mads Kiilerich <mads@kiilerich.com>
parents:
15243
diff
changeset
|
1 |
$ "$TESTDIR/hghave" unix-permissions || exit 80 |
a1914d214579
tests: use 'hghave unix-permissions' for tests that really use chmod
Mads Kiilerich <mads@kiilerich.com>
parents:
15243
diff
changeset
|
2 |
|
11744 | 3 |
Helper functions: |
4 |
||
5 |
$ cacheexists() { |
|
13272
5ccdca7df211
move tags.cache and branchheads.cache to a collected cache folder .hg/cache/
jfh <jason@jasonfharris.com>
parents:
12763
diff
changeset
|
6 |
> [ -f .hg/cache/tags ] && echo "tag cache exists" || echo "no tag cache" |
11744 | 7 |
> } |
345 | 8 |
|
11744 | 9 |
$ dumptags() { |
10 |
> rev=$1 |
|
11 |
> echo "rev $rev: .hgtags:" |
|
12 |
> hg cat -r$rev .hgtags |
|
13 |
> } |
|
9151
f528d1a93491
tags: implement persistent tag caching (issue548).
Greg Ward <greg-hg@gerg.ca>
parents:
9144
diff
changeset
|
14 |
|
9152
4017291c4c48
tags: support 'instant' tag retrieval (issue548)
Greg Ward <greg-hg@gerg.ca>
parents:
9151
diff
changeset
|
15 |
# XXX need to test that the tag cache works when we strip an old head |
4017291c4c48
tags: support 'instant' tag retrieval (issue548)
Greg Ward <greg-hg@gerg.ca>
parents:
9151
diff
changeset
|
16 |
# and add a new one rooted off non-tip: i.e. node and rev of tip are the |
4017291c4c48
tags: support 'instant' tag retrieval (issue548)
Greg Ward <greg-hg@gerg.ca>
parents:
9151
diff
changeset
|
17 |
# same, but stuff has changed behind tip. |
4017291c4c48
tags: support 'instant' tag retrieval (issue548)
Greg Ward <greg-hg@gerg.ca>
parents:
9151
diff
changeset
|
18 |
|
11744 | 19 |
Setup: |
9143
a604c98dbf62
test-tags: clarify test output; simplify test script a bit (issue548).
Greg Ward <greg-hg@gerg.ca>
parents:
5658
diff
changeset
|
20 |
|
11744 | 21 |
$ hg init t |
22 |
$ cd t |
|
23 |
$ cacheexists |
|
24 |
no tag cache |
|
25 |
$ hg id |
|
26 |
000000000000 tip |
|
27 |
$ cacheexists |
|
28 |
no tag cache |
|
29 |
$ echo a > a |
|
30 |
$ hg add a |
|
31 |
$ hg commit -m "test" |
|
32 |
$ hg co |
|
33 |
0 files updated, 0 files merged, 0 files removed, 0 files unresolved |
|
34 |
$ hg identify |
|
35 |
acb14030fe0a tip |
|
36 |
$ cacheexists |
|
37 |
tag cache exists |
|
38 |
||
12758
2d754eae430c
tags: do not fail if tags.cache is corrupted (issue2444)
Nicolas Dumazet <nicdumz.commits@gmail.com>
parents:
12640
diff
changeset
|
39 |
Try corrupting the cache |
2d754eae430c
tags: do not fail if tags.cache is corrupted (issue2444)
Nicolas Dumazet <nicdumz.commits@gmail.com>
parents:
12640
diff
changeset
|
40 |
|
13272
5ccdca7df211
move tags.cache and branchheads.cache to a collected cache folder .hg/cache/
jfh <jason@jasonfharris.com>
parents:
12763
diff
changeset
|
41 |
$ printf 'a b' > .hg/cache/tags |
12758
2d754eae430c
tags: do not fail if tags.cache is corrupted (issue2444)
Nicolas Dumazet <nicdumz.commits@gmail.com>
parents:
12640
diff
changeset
|
42 |
$ hg identify |
13272
5ccdca7df211
move tags.cache and branchheads.cache to a collected cache folder .hg/cache/
jfh <jason@jasonfharris.com>
parents:
12763
diff
changeset
|
43 |
.hg/cache/tags is corrupt, rebuilding it |
12758
2d754eae430c
tags: do not fail if tags.cache is corrupted (issue2444)
Nicolas Dumazet <nicdumz.commits@gmail.com>
parents:
12640
diff
changeset
|
44 |
acb14030fe0a tip |
2d754eae430c
tags: do not fail if tags.cache is corrupted (issue2444)
Nicolas Dumazet <nicdumz.commits@gmail.com>
parents:
12640
diff
changeset
|
45 |
$ cacheexists |
2d754eae430c
tags: do not fail if tags.cache is corrupted (issue2444)
Nicolas Dumazet <nicdumz.commits@gmail.com>
parents:
12640
diff
changeset
|
46 |
tag cache exists |
2d754eae430c
tags: do not fail if tags.cache is corrupted (issue2444)
Nicolas Dumazet <nicdumz.commits@gmail.com>
parents:
12640
diff
changeset
|
47 |
$ hg identify |
2d754eae430c
tags: do not fail if tags.cache is corrupted (issue2444)
Nicolas Dumazet <nicdumz.commits@gmail.com>
parents:
12640
diff
changeset
|
48 |
acb14030fe0a tip |
2d754eae430c
tags: do not fail if tags.cache is corrupted (issue2444)
Nicolas Dumazet <nicdumz.commits@gmail.com>
parents:
12640
diff
changeset
|
49 |
|
11744 | 50 |
Create local tag with long name: |
51 |
||
52 |
$ T=`hg identify --debug --id` |
|
53 |
$ hg tag -l "This is a local tag with a really long name!" |
|
54 |
$ hg tags |
|
55 |
tip 0:acb14030fe0a |
|
56 |
This is a local tag with a really long name! 0:acb14030fe0a |
|
57 |
$ rm .hg/localtags |
|
58 |
||
59 |
Create a tag behind hg's back: |
|
9143
a604c98dbf62
test-tags: clarify test output; simplify test script a bit (issue548).
Greg Ward <greg-hg@gerg.ca>
parents:
5658
diff
changeset
|
60 |
|
11744 | 61 |
$ echo "$T first" > .hgtags |
62 |
$ cat .hgtags |
|
63 |
acb14030fe0a21b60322c440ad2d20cf7685a376 first |
|
64 |
$ hg add .hgtags |
|
65 |
$ hg commit -m "add tags" |
|
66 |
$ hg tags |
|
67 |
tip 1:b9154636be93 |
|
68 |
first 0:acb14030fe0a |
|
69 |
$ hg identify |
|
70 |
b9154636be93 tip |
|
71 |
||
72 |
Repeat with cold tag cache: |
|
73 |
||
13272
5ccdca7df211
move tags.cache and branchheads.cache to a collected cache folder .hg/cache/
jfh <jason@jasonfharris.com>
parents:
12763
diff
changeset
|
74 |
$ rm -f .hg/cache/tags |
11744 | 75 |
$ hg identify |
76 |
b9154636be93 tip |
|
77 |
||
78 |
And again, but now unable to write tag cache: |
|
9143
a604c98dbf62
test-tags: clarify test output; simplify test script a bit (issue548).
Greg Ward <greg-hg@gerg.ca>
parents:
5658
diff
changeset
|
79 |
|
13272
5ccdca7df211
move tags.cache and branchheads.cache to a collected cache folder .hg/cache/
jfh <jason@jasonfharris.com>
parents:
12763
diff
changeset
|
80 |
$ rm -f .hg/cache/tags |
11744 | 81 |
$ chmod 555 .hg |
82 |
$ hg identify |
|
83 |
b9154636be93 tip |
|
84 |
$ chmod 755 .hg |
|
85 |
||
86 |
Create a branch: |
|
9151
f528d1a93491
tags: implement persistent tag caching (issue548).
Greg Ward <greg-hg@gerg.ca>
parents:
9144
diff
changeset
|
87 |
|
11744 | 88 |
$ echo bb > a |
89 |
$ hg status |
|
90 |
M a |
|
91 |
$ hg identify |
|
92 |
b9154636be93+ tip |
|
93 |
$ hg co first |
|
94 |
0 files updated, 0 files merged, 1 files removed, 0 files unresolved |
|
95 |
$ hg id |
|
96 |
acb14030fe0a+ first |
|
97 |
$ hg -v id |
|
98 |
acb14030fe0a+ first |
|
99 |
$ hg status |
|
100 |
M a |
|
101 |
$ echo 1 > b |
|
102 |
$ hg add b |
|
103 |
$ hg commit -m "branch" |
|
104 |
created new head |
|
105 |
$ hg id |
|
106 |
c8edf04160c7 tip |
|
107 |
||
108 |
Merge the two heads: |
|
9366
9ff178e7b627
tags: don't crash if unable to write tag cache
Greg Ward <greg-hg@gerg.ca>
parents:
9152
diff
changeset
|
109 |
|
11744 | 110 |
$ hg merge 1 |
111 |
1 files updated, 0 files merged, 0 files removed, 0 files unresolved |
|
112 |
(branch merge, don't forget to commit) |
|
113 |
$ hg id |
|
114 |
c8edf04160c7+b9154636be93+ tip |
|
115 |
$ hg status |
|
116 |
M .hgtags |
|
117 |
$ hg commit -m "merge" |
|
118 |
||
119 |
Create a fake head, make sure tag not visible afterwards: |
|
120 |
||
121 |
$ cp .hgtags tags |
|
122 |
$ hg tag last |
|
123 |
$ hg rm .hgtags |
|
124 |
$ hg commit -m "remove" |
|
9143
a604c98dbf62
test-tags: clarify test output; simplify test script a bit (issue548).
Greg Ward <greg-hg@gerg.ca>
parents:
5658
diff
changeset
|
125 |
|
11744 | 126 |
$ mv tags .hgtags |
127 |
$ hg add .hgtags |
|
128 |
$ hg commit -m "readd" |
|
129 |
$ |
|
130 |
$ hg tags |
|
131 |
tip 6:35ff301afafe |
|
132 |
first 0:acb14030fe0a |
|
133 |
||
134 |
Add invalid tags: |
|
345 | 135 |
|
11744 | 136 |
$ echo "spam" >> .hgtags |
137 |
$ echo >> .hgtags |
|
138 |
$ echo "foo bar" >> .hgtags |
|
12366
c01dc9087d9a
tests: drop a bunch of sed calls from unified tests
Matt Mackall <mpm@selenic.com>
parents:
12327
diff
changeset
|
139 |
$ echo "a5a5 invalid" >> .hg/localtags |
11744 | 140 |
$ cat .hgtags |
141 |
acb14030fe0a21b60322c440ad2d20cf7685a376 first |
|
142 |
spam |
|
143 |
||
144 |
foo bar |
|
145 |
$ hg commit -m "tags" |
|
146 |
||
147 |
Report tag parse error on other head: |
|
2320
dbdce3b99988
fix parsing of tags. make parse errors useful. add new tag tests.
Vadim Gelfer <vadim.gelfer@gmail.com>
parents:
2283
diff
changeset
|
148 |
|
11744 | 149 |
$ hg up 3 |
150 |
1 files updated, 0 files merged, 0 files removed, 0 files unresolved |
|
151 |
$ echo 'x y' >> .hgtags |
|
152 |
$ hg commit -m "head" |
|
153 |
created new head |
|
2320
dbdce3b99988
fix parsing of tags. make parse errors useful. add new tag tests.
Vadim Gelfer <vadim.gelfer@gmail.com>
parents:
2283
diff
changeset
|
154 |
|
11744 | 155 |
$ hg tags |
156 |
.hgtags@75d9f02dfe28, line 2: cannot parse entry |
|
157 |
.hgtags@75d9f02dfe28, line 4: node 'foo' is not well formed |
|
158 |
.hgtags@c4be69a18c11, line 2: node 'x' is not well formed |
|
159 |
tip 8:c4be69a18c11 |
|
160 |
first 0:acb14030fe0a |
|
161 |
$ hg tip |
|
162 |
changeset: 8:c4be69a18c11 |
|
163 |
tag: tip |
|
164 |
parent: 3:ac5e980c4dc0 |
|
165 |
user: test |
|
166 |
date: Thu Jan 01 00:00:00 1970 +0000 |
|
167 |
summary: head |
|
168 |
||
2320
dbdce3b99988
fix parsing of tags. make parse errors useful. add new tag tests.
Vadim Gelfer <vadim.gelfer@gmail.com>
parents:
2283
diff
changeset
|
169 |
|
11744 | 170 |
Test tag precedence rules: |
2320
dbdce3b99988
fix parsing of tags. make parse errors useful. add new tag tests.
Vadim Gelfer <vadim.gelfer@gmail.com>
parents:
2283
diff
changeset
|
171 |
|
11744 | 172 |
$ cd .. |
173 |
$ hg init t2 |
|
174 |
$ cd t2 |
|
175 |
$ echo foo > foo |
|
176 |
$ hg add foo |
|
177 |
$ hg ci -m 'add foo' # rev 0 |
|
178 |
$ hg tag bar # rev 1 |
|
179 |
$ echo >> foo |
|
180 |
$ hg ci -m 'change foo 1' # rev 2 |
|
181 |
$ hg up -C 1 |
|
182 |
1 files updated, 0 files merged, 0 files removed, 0 files unresolved |
|
183 |
$ hg tag -r 1 -f bar # rev 3 |
|
184 |
$ hg up -C 1 |
|
185 |
1 files updated, 0 files merged, 0 files removed, 0 files unresolved |
|
186 |
$ echo >> foo |
|
187 |
$ hg ci -m 'change foo 2' # rev 4 |
|
188 |
created new head |
|
189 |
$ hg tags |
|
190 |
tip 4:0c192d7d5e6b |
|
191 |
bar 1:78391a272241 |
|
2320
dbdce3b99988
fix parsing of tags. make parse errors useful. add new tag tests.
Vadim Gelfer <vadim.gelfer@gmail.com>
parents:
2283
diff
changeset
|
192 |
|
11744 | 193 |
Repeat in case of cache effects: |
2320
dbdce3b99988
fix parsing of tags. make parse errors useful. add new tag tests.
Vadim Gelfer <vadim.gelfer@gmail.com>
parents:
2283
diff
changeset
|
194 |
|
11744 | 195 |
$ hg tags |
196 |
tip 4:0c192d7d5e6b |
|
197 |
bar 1:78391a272241 |
|
198 |
||
199 |
Detailed dump of tag info: |
|
1986
719cf07b076d
add checking for invalid entries in tag files
Benoit Boissinot <benoit.boissinot@ens-lyon.org>
parents:
1933
diff
changeset
|
200 |
|
11744 | 201 |
$ hg heads -q # expect 4, 3, 2 |
202 |
4:0c192d7d5e6b |
|
203 |
3:6fa450212aeb |
|
204 |
2:7a94127795a3 |
|
205 |
$ dumptags 2 |
|
206 |
rev 2: .hgtags: |
|
207 |
bbd179dfa0a71671c253b3ae0aa1513b60d199fa bar |
|
208 |
$ dumptags 3 |
|
209 |
rev 3: .hgtags: |
|
210 |
bbd179dfa0a71671c253b3ae0aa1513b60d199fa bar |
|
211 |
bbd179dfa0a71671c253b3ae0aa1513b60d199fa bar |
|
212 |
78391a272241d70354aa14c874552cad6b51bb42 bar |
|
213 |
$ dumptags 4 |
|
214 |
rev 4: .hgtags: |
|
215 |
bbd179dfa0a71671c253b3ae0aa1513b60d199fa bar |
|
9144
ad72e3b08bc0
test-tags: enhance the test to probe tag caching better (issue548).
Greg Ward <greg-hg@gerg.ca>
parents:
9143
diff
changeset
|
216 |
|
11744 | 217 |
Dump cache: |
218 |
||
13272
5ccdca7df211
move tags.cache and branchheads.cache to a collected cache folder .hg/cache/
jfh <jason@jasonfharris.com>
parents:
12763
diff
changeset
|
219 |
$ cat .hg/cache/tags |
11744 | 220 |
4 0c192d7d5e6b78a714de54a2e9627952a877e25a 0c04f2a8af31de17fab7422878ee5a2dadbc943d |
221 |
3 6fa450212aeb2a21ed616a54aea39a4a27894cd7 7d3b718c964ef37b89e550ebdafd5789e76ce1b0 |
|
222 |
2 7a94127795a33c10a370c93f731fd9fea0b79af6 0c04f2a8af31de17fab7422878ee5a2dadbc943d |
|
223 |
||
224 |
78391a272241d70354aa14c874552cad6b51bb42 bar |
|
225 |
||
226 |
Test tag removal: |
|
9144
ad72e3b08bc0
test-tags: enhance the test to probe tag caching better (issue548).
Greg Ward <greg-hg@gerg.ca>
parents:
9143
diff
changeset
|
227 |
|
11744 | 228 |
$ hg tag --remove bar # rev 5 |
229 |
$ hg tip -vp |
|
230 |
changeset: 5:5f6e8655b1c7 |
|
231 |
tag: tip |
|
232 |
user: test |
|
233 |
date: Thu Jan 01 00:00:00 1970 +0000 |
|
234 |
files: .hgtags |
|
235 |
description: |
|
236 |
Removed tag bar |
|
237 |
||
238 |
||
239 |
diff -r 0c192d7d5e6b -r 5f6e8655b1c7 .hgtags |
|
240 |
--- a/.hgtags Thu Jan 01 00:00:00 1970 +0000 |
|
241 |
+++ b/.hgtags Thu Jan 01 00:00:00 1970 +0000 |
|
242 |
@@ -1,1 +1,3 @@ |
|
243 |
bbd179dfa0a71671c253b3ae0aa1513b60d199fa bar |
|
244 |
+78391a272241d70354aa14c874552cad6b51bb42 bar |
|
245 |
+0000000000000000000000000000000000000000 bar |
|
246 |
||
247 |
$ hg tags |
|
248 |
tip 5:5f6e8655b1c7 |
|
249 |
$ hg tags # again, try to expose cache bugs |
|
250 |
tip 5:5f6e8655b1c7 |
|
4213 | 251 |
|
11744 | 252 |
Remove nonexistent tag: |
253 |
||
254 |
$ hg tag --remove foobar |
|
255 |
abort: tag 'foobar' does not exist |
|
12316
4134686b83e1
tests: add exit codes to unified tests
Matt Mackall <mpm@selenic.com>
parents:
11744
diff
changeset
|
256 |
[255] |
11744 | 257 |
$ hg tip |
258 |
changeset: 5:5f6e8655b1c7 |
|
259 |
tag: tip |
|
260 |
user: test |
|
261 |
date: Thu Jan 01 00:00:00 1970 +0000 |
|
262 |
summary: Removed tag bar |
|
263 |
||
4266
fe7f38dda34b
tags: fix abababa case, with test case
Matt Mackall <mpm@selenic.com>
parents:
4213
diff
changeset
|
264 |
|
11744 | 265 |
Undo a tag with rollback: |
4651
7176f278d6f9
Test attempt to remove nonexistent tag
Brendan Cully <brendan@kublai.com>
parents:
4482
diff
changeset
|
266 |
|
11744 | 267 |
$ hg rollback # destroy rev 5 (restore bar) |
13446
1e497df514e2
rollback: clarifies the message about the reverted state (issue2628)
Gilles Moris <gilles.moris@free.fr>
parents:
13272
diff
changeset
|
268 |
repository tip rolled back to revision 4 (undo commit) |
1e497df514e2
rollback: clarifies the message about the reverted state (issue2628)
Gilles Moris <gilles.moris@free.fr>
parents:
13272
diff
changeset
|
269 |
working directory now based on revision 4 |
11744 | 270 |
$ hg tags |
271 |
tip 4:0c192d7d5e6b |
|
272 |
bar 1:78391a272241 |
|
273 |
$ hg tags |
|
274 |
tip 4:0c192d7d5e6b |
|
275 |
bar 1:78391a272241 |
|
276 |
||
277 |
Test tag rank: |
|
9144
ad72e3b08bc0
test-tags: enhance the test to probe tag caching better (issue548).
Greg Ward <greg-hg@gerg.ca>
parents:
9143
diff
changeset
|
278 |
|
11744 | 279 |
$ cd .. |
280 |
$ hg init t3 |
|
281 |
$ cd t3 |
|
282 |
$ echo foo > foo |
|
283 |
$ hg add foo |
|
284 |
$ hg ci -m 'add foo' # rev 0 |
|
285 |
$ hg tag -f bar # rev 1 bar -> 0 |
|
286 |
$ hg tag -f bar # rev 2 bar -> 1 |
|
287 |
$ hg tag -fr 0 bar # rev 3 bar -> 0 |
|
288 |
$ hg tag -fr 1 bar # rev 4 bar -> 1 |
|
289 |
$ hg tag -fr 0 bar # rev 5 bar -> 0 |
|
290 |
$ hg tags |
|
291 |
tip 5:85f05169d91d |
|
292 |
bar 0:bbd179dfa0a7 |
|
293 |
$ hg co 3 |
|
294 |
1 files updated, 0 files merged, 0 files removed, 0 files unresolved |
|
295 |
$ echo barbar > foo |
|
296 |
$ hg ci -m 'change foo' # rev 6 |
|
297 |
created new head |
|
298 |
$ hg tags |
|
299 |
tip 6:735c3ca72986 |
|
300 |
bar 0:bbd179dfa0a7 |
|
4267
8185a1ca8628
tags: require -f to replace an existing tag
Matt Mackall <mpm@selenic.com>
parents:
4266
diff
changeset
|
301 |
|
11744 | 302 |
Don't allow moving tag without -f: |
303 |
||
304 |
$ hg tag -r 3 bar |
|
305 |
abort: tag 'bar' already exists (use -f to force) |
|
12316
4134686b83e1
tests: add exit codes to unified tests
Matt Mackall <mpm@selenic.com>
parents:
11744
diff
changeset
|
306 |
[255] |
11744 | 307 |
$ hg tags |
308 |
tip 6:735c3ca72986 |
|
309 |
bar 0:bbd179dfa0a7 |
|
310 |
||
311 |
Strip 1: expose an old head: |
|
4482
99f411ba0380
use .extend instead of .append in readtags
Alexis S. L. Carvalho <alexis@cecm.usp.br>
parents:
4267
diff
changeset
|
312 |
|
11744 | 313 |
$ hg --config extensions.mq= strip 5 |
12640
6cc4b14fb76b
tests: remove redundant globs
Mads Kiilerich <mads@kiilerich.com>
parents:
12376
diff
changeset
|
314 |
saved backup bundle to $TESTTMP/t3/.hg/strip-backup/*-backup.hg (glob) |
11744 | 315 |
$ hg tags # partly stale cache |
316 |
tip 5:735c3ca72986 |
|
317 |
bar 1:78391a272241 |
|
318 |
$ hg tags # up-to-date cache |
|
319 |
tip 5:735c3ca72986 |
|
320 |
bar 1:78391a272241 |
|
321 |
||
322 |
Strip 2: destroy whole branch, no old head exposed |
|
9144
ad72e3b08bc0
test-tags: enhance the test to probe tag caching better (issue548).
Greg Ward <greg-hg@gerg.ca>
parents:
9143
diff
changeset
|
323 |
|
11744 | 324 |
$ hg --config extensions.mq= strip 4 |
12640
6cc4b14fb76b
tests: remove redundant globs
Mads Kiilerich <mads@kiilerich.com>
parents:
12376
diff
changeset
|
325 |
saved backup bundle to $TESTTMP/t3/.hg/strip-backup/*-backup.hg (glob) |
11744 | 326 |
$ hg tags # partly stale |
327 |
tip 4:735c3ca72986 |
|
328 |
bar 0:bbd179dfa0a7 |
|
13272
5ccdca7df211
move tags.cache and branchheads.cache to a collected cache folder .hg/cache/
jfh <jason@jasonfharris.com>
parents:
12763
diff
changeset
|
329 |
$ rm -f .hg/cache/tags |
11744 | 330 |
$ hg tags # cold cache |
331 |
tip 4:735c3ca72986 |
|
332 |
bar 0:bbd179dfa0a7 |
|
333 |
||
334 |
Test tag rank with 3 heads: |
|
5657
47915bf68c44
Properly check tag's existence as a local/global tag when removing it.
Osku Salerma <osku@iki.fi>
parents:
5524
diff
changeset
|
335 |
|
11744 | 336 |
$ cd .. |
337 |
$ hg init t4 |
|
338 |
$ cd t4 |
|
339 |
$ echo foo > foo |
|
340 |
$ hg add |
|
341 |
adding foo |
|
342 |
$ hg ci -m 'add foo' # rev 0 |
|
343 |
$ hg tag bar # rev 1 bar -> 0 |
|
344 |
$ hg tag -f bar # rev 2 bar -> 1 |
|
345 |
$ hg up -qC 0 |
|
346 |
$ hg tag -fr 2 bar # rev 3 bar -> 2 |
|
347 |
$ hg tags |
|
348 |
tip 3:197c21bbbf2c |
|
349 |
bar 2:6fa450212aeb |
|
350 |
$ hg up -qC 0 |
|
351 |
$ hg tag -m 'retag rev 0' -fr 0 bar # rev 4 bar -> 0, but bar stays at 2 |
|
5657
47915bf68c44
Properly check tag's existence as a local/global tag when removing it.
Osku Salerma <osku@iki.fi>
parents:
5524
diff
changeset
|
352 |
|
11744 | 353 |
Bar should still point to rev 2: |
354 |
||
355 |
$ hg tags |
|
356 |
tip 4:3b4b14ed0202 |
|
357 |
bar 2:6fa450212aeb |
|
358 |
||
359 |
Test that removing global/local tags does not get confused when trying |
|
360 |
to remove a tag of type X which actually only exists as a type Y: |
|
5657
47915bf68c44
Properly check tag's existence as a local/global tag when removing it.
Osku Salerma <osku@iki.fi>
parents:
5524
diff
changeset
|
361 |
|
11744 | 362 |
$ cd .. |
363 |
$ hg init t5 |
|
364 |
$ cd t5 |
|
365 |
$ echo foo > foo |
|
366 |
$ hg add |
|
367 |
adding foo |
|
368 |
$ hg ci -m 'add foo' # rev 0 |
|
5657
47915bf68c44
Properly check tag's existence as a local/global tag when removing it.
Osku Salerma <osku@iki.fi>
parents:
5524
diff
changeset
|
369 |
|
11744 | 370 |
$ hg tag -r 0 -l localtag |
371 |
$ hg tag --remove localtag |
|
372 |
abort: tag 'localtag' is not a global tag |
|
12316
4134686b83e1
tests: add exit codes to unified tests
Matt Mackall <mpm@selenic.com>
parents:
11744
diff
changeset
|
373 |
[255] |
11744 | 374 |
$ |
375 |
$ hg tag -r 0 globaltag |
|
376 |
$ hg tag --remove -l globaltag |
|
377 |
abort: tag 'globaltag' is not a local tag |
|
12316
4134686b83e1
tests: add exit codes to unified tests
Matt Mackall <mpm@selenic.com>
parents:
11744
diff
changeset
|
378 |
[255] |
11744 | 379 |
$ hg tags -v |
380 |
tip 1:a0b6fe111088 |
|
381 |
localtag 0:bbd179dfa0a7 local |
|
382 |
globaltag 0:bbd179dfa0a7 |