Commit | Line | Data |
---|---|---|
ab96cd1c KH |
1 | #!/bin/sh |
2 | ||
3 | test_description='Run "stg goto" in a subdirectory' | |
4 | ||
5 | . ./test-lib.sh | |
6 | ||
7 | test_expect_success 'Initialize StGit stack' ' | |
8 | stg init && | |
9 | echo expected1.txt >> .git/info/exclude && | |
10 | echo expected2.txt >> .git/info/exclude && | |
11 | echo actual.txt >> .git/info/exclude && | |
12 | mkdir foo && | |
13 | for i in 1 2 3; do | |
14 | echo foo$i >> foo/bar && | |
15 | stg new p$i -m p$i && | |
c7506039 | 16 | stg add foo/bar && |
ab96cd1c KH |
17 | stg refresh |
18 | done | |
19 | ' | |
20 | ||
21 | cat > expected1.txt <<EOF | |
22 | foo1 | |
23 | EOF | |
24 | cat > expected2.txt <<EOF | |
25 | bar | |
26 | EOF | |
8d96d568 | 27 | test_expect_success 'Goto in subdirectory (just pop)' ' |
ee11a289 | 28 | (cd foo && stg goto --keep p1) && |
ab96cd1c | 29 | cat foo/bar > actual.txt && |
d9b2f20a | 30 | test_cmp expected1.txt actual.txt && |
ab96cd1c | 31 | ls foo > actual.txt && |
d9b2f20a | 32 | test_cmp expected2.txt actual.txt |
ab96cd1c KH |
33 | ' |
34 | ||
35 | test_expect_success 'Prepare conflicting goto' ' | |
36 | stg delete p2 | |
37 | ' | |
38 | ||
533d85c2 KW |
39 | # git gives this result before commit 606475f3 ... |
40 | cat > expected1a.txt <<EOF | |
ab96cd1c KH |
41 | foo1 |
42 | <<<<<<< current:foo/bar | |
43 | ======= | |
44 | foo2 | |
45 | foo3 | |
46 | >>>>>>> patched:foo/bar | |
47 | EOF | |
533d85c2 KW |
48 | |
49 | # ... and this result after commit 606475f3. | |
50 | cat > expected1b.txt <<EOF | |
51 | foo1 | |
52 | <<<<<<< current | |
53 | ======= | |
54 | foo2 | |
55 | foo3 | |
56 | >>>>>>> patched | |
57 | EOF | |
58 | ||
ab96cd1c KH |
59 | cat > expected2.txt <<EOF |
60 | bar | |
61 | EOF | |
8d96d568 | 62 | test_expect_success 'Goto in subdirectory (conflicting push)' ' |
ee11a289 | 63 | (cd foo && stg goto --keep p3) ; |
ab96cd1c KH |
64 | [ $? -eq 3 ] && |
65 | cat foo/bar > actual.txt && | |
533d85c2 KW |
66 | ( test_cmp expected1a.txt actual.txt \ |
67 | || test_cmp expected1b.txt actual.txt ) && | |
ab96cd1c | 68 | ls foo > actual.txt && |
d9b2f20a | 69 | test_cmp expected2.txt actual.txt |
ab96cd1c KH |
70 | ' |
71 | ||
72 | test_done |