forked from openedx-unsupported/devstack
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrepo.sh
executable file
·120 lines (104 loc) · 2.94 KB
/
repo.sh
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
#!/usr/bin/env bash
set -e
set -o pipefail
# Script for Git repos housing edX services. These repos are mounted as
# data volumes into their corresponding Docker containers to facilitate development.
# Repos are cloned to/removed from the directory above the one housing this file.
if [ -z "$DEVSTACK_WORKSPACE" ]; then
echo "need to set workspace dir"
exit 1
elif [ -d "$DEVSTACK_WORKSPACE" ]; then
cd $DEVSTACK_WORKSPACE
else
echo "Workspace directory $DEVSTACK_WORKSPACE doesn't exist"
exit 1
fi
repos=(
"https://github.com/edx/course-discovery.git"
"https://github.com/edx/credentials.git"
"https://github.com/edx/cs_comments_service.git"
"https://github.com/edx/ecommerce.git"
"https://github.com/edx/edx-e2e-tests.git"
"https://github.com/edx/edx-notes-api.git"
"https://github.com/edx/edx-platform.git"
"https://github.com/edx/xqueue.git"
"https://github.com/edx/edx-analytics-pipeline.git"
)
private_repos=(
# Needed to run whitelabel tests.
"https://github.com/edx/edx-themes.git"
)
name_pattern=".*edx/(.*).git"
_clone ()
{
# for repo in ${repos[*]}
repos_to_clone=("$@")
for repo in "${repos_to_clone[@]}"
do
# Use Bash's regex match operator to capture the name of the repo.
# Results of the match are saved to an array called $BASH_REMATCH.
[[ $repo =~ $name_pattern ]]
name="${BASH_REMATCH[1]}"
if [ -d "$name" ]; then
printf "The [%s] repo is already checked out. Continuing.\n" $name
else
if [ "${SHALLOW_CLONE}" == "1" ]; then
git clone --depth=1 $repo
else
git clone $repo
fi
fi
done
cd - &> /dev/null
}
clone ()
{
_clone "${repos[@]}"
}
clone_private ()
{
_clone "${private_repos[@]}"
}
reset ()
{
currDir=$(pwd)
for repo in ${repos[*]}
do
[[ $repo =~ $name_pattern ]]
name="${BASH_REMATCH[1]}"
if [ -d "$name" ]; then
cd $name;git reset --hard HEAD;git checkout master;git reset --hard origin/master;git pull;cd "$currDir"
else
printf "The [%s] repo is not cloned. Continuing.\n" $name
fi
done
cd - &> /dev/null
}
status ()
{
currDir=$(pwd)
for repo in ${repos[*]}
do
[[ $repo =~ $name_pattern ]]
name="${BASH_REMATCH[1]}"
if [ -d "$name" ]; then
printf "\nGit status for [%s]:\n" $name
cd $name;git status;cd "$currDir"
else
printf "The [%s] repo is not cloned. Continuing.\n" $name
fi
done
cd - &> /dev/null
}
if [ "$1" == "clone" ]; then
clone
elif [ "$1" == "whitelabel" ]; then
clone_private
elif [ "$1" == "reset" ]; then
read -p "This will override any uncommited changes in your local git checkouts. Would you like to proceed? [y/n] " -r
if [[ $REPLY =~ ^[Yy]$ ]]; then
reset
fi
elif [ "$1" == "status" ]; then
status
fi