aboutsummaryrefslogtreecommitdiffstats
path: root/tests/create-repo.sh
blob: f837b5d4cd3097101c1b80afec625741901d53f4 (plain) (blame)
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#!/bin/bash

here=$(dirname $0)
test_repo=$here/test-repo

new_file () {
    cat <<EOF > $1
one
two
three
four
five
six
seven
eight
nine
ten
EOF

    git add $1
    git commit -m "create $1"
    tag $1
}

tag () {
    git tag "$@"
    echo -n "Hit Enter to continue ..."
    read
}

edit () {
    file="$1"
    line="$2"
    new="$3"
    sed -i "s/^$line.*/$line $new/" $file
    git commit -am "$file: change $line to $line $new"
    tag $file-$line-$new
}

main () {
    rm -rf $test_repo
    mkdir $test_repo
    cd $test_repo

    git init
    git config user.email git-test@fake.address

    # Start with two independently committed files
    for f in file-{a,b}; do
        new_file $f
    done

    # Now start making changes
    edit file-a three foo  # depends on file-a tag
    edit file-b three bar  # depends on file-b tag

    # Change non-overlapping part of previously changed file
    edit file-a eight foo  # depends on file-a tag

    # Change previously changed line
    edit file-a three baz  # depends on file-a-three-a tag
}

feature () {
    cd $test_repo

    # Start a feature branch
    git checkout -b feature file-b-three-bar
    new_file file-c
    edit file-c four foo
    edit file-c ten qux

    # Switch back to master
    git checkout master
}

case "$1" in
    feature)
        feature
        ;;
    *)
        main
        ;;
esac

exit 0