forked from fabric8-analytics/fabric8-analytics-server
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcico_setup.sh
executable file
·64 lines (55 loc) · 1.75 KB
/
cico_setup.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
#!/bin/bash -ex
load_jenkins_vars() {
if [ -e "jenkins-env" ]; then
cat jenkins-env \
| grep -E "(DEVSHIFT_TAG_LEN|DEVSHIFT_USERNAME|DEVSHIFT_PASSWORD|JENKINS_URL|GIT_BRANCH|GIT_COMMIT|BUILD_NUMBER|ghprbSourceBranch|ghprbActualCommit|BUILD_URL|ghprbPullId)=" \
| sed 's/^/export /g' \
> ~/.jenkins-env
source ~/.jenkins-env
fi
}
prep() {
yum -y update
yum -y install docker git
systemctl start docker
}
build_image() {
# build image and tests
make docker-build-tests
}
tag_push() {
local target=$1
local source=$2
docker tag ${source} ${target}
docker push ${target}
}
push_image() {
local image_name
local image_repository
local short_commit
local push_registry
image_name=$(make get-image-name)
image_repository=$(make get-image-repository)
short_commit=$(git rev-parse --short=7 HEAD)
push_registry="push.registry.devshift.net"
# login first
if [ -n "${DEVSHIFT_USERNAME}" -a -n "${DEVSHIFT_PASSWORD}" ]; then
docker login -u ${DEVSHIFT_USERNAME} -p ${DEVSHIFT_PASSWORD} ${push_registry}
else
echo "Could not login, missing credentials for the registry"
exit 1
fi
if [ -n "${ghprbPullId}" ]; then
# PR build
pr_id="SNAPSHOT-PR-${ghprbPullId}"
tag_push ${push_registry}/${image_repository}:${pr_id} ${image_name}
tag_push ${push_registry}/${image_repository}:${pr_id}-${short_commit} ${image_name}
else
# master branch build
tag_push ${push_registry}/${image_repository}:latest ${image_name}
tag_push ${push_registry}/${image_repository}:${short_commit} ${image_name}
fi
echo 'CICO: Image pushed, ready to update deployed app'
}
load_jenkins_vars
prep