chiark / gitweb /
Merge branch 'stable'
[stgit] / t / t2800-goto-subdir.sh
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 &&
16         git add foo/bar &&
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
27 test_expect_success 'Goto in subdirectory (just pop)' '
28     (cd foo && stg goto p1) &&
29     cat foo/bar > actual.txt &&
30     test_cmp expected1.txt actual.txt &&
31     ls foo > actual.txt &&
32     test_cmp expected2.txt actual.txt
33 '
34
35 test_expect_success 'Prepare conflicting goto' '
36     stg delete p2
37 '
38
39 cat > expected1.txt <<EOF
40 foo1
41 <<<<<<< current:foo/bar
42 =======
43 foo2
44 foo3
45 >>>>>>> patched:foo/bar
46 EOF
47 cat > expected2.txt <<EOF
48 bar
49 EOF
50 test_expect_success 'Goto in subdirectory (conflicting push)' '
51     (cd foo && stg goto p3) ;
52     [ $? -eq 3 ] &&
53     cat foo/bar > actual.txt &&
54     test_cmp expected1.txt actual.txt &&
55     ls foo > actual.txt &&
56     test_cmp expected2.txt actual.txt
57 '
58
59 test_done