-
Notifications
You must be signed in to change notification settings - Fork 0
/
version.sh
executable file
·85 lines (77 loc) · 2.99 KB
/
version.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
#!/usr/bin/env bash
#
# MIT License
#
# (C) Copyright 2021 Hewlett Packard Enterprise Development LP
#
# Permission is hereby granted, free of charge, to any person obtaining a
# copy of this software and associated documentation files (the "Software"),
# to deal in the Software without restriction, including without limitation
# the rights to use, copy, modify, merge, publish, distribute, sublicense,
# and/or sell copies of the Software, and to permit persons to whom the
# Software is furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included
# in all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
# OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
# OTHER DEALINGS IN THE SOFTWARE.
#
# Version script required by the build pipeline.
#
# This script outputs the version of the sat product stream as follows:
#
# - If on a release branch, i.e. a branch prefixed by release/, output the
# version exactly as defined in the file .version
# - Otherwise, if on any other branch, output the version defined in the file
# .version appended with the timestamp and a short git commit hash in the
# form VERSION-TIMESTAMP-GITHASH.
#
# In addition, if there are local, uncommitted changes, "-dirty" is appended to
# the version as determined by the rules above.
# Exits successfully if on a release branch, unsuccessfully otherwise.
function is_release_branch() {
local git_branch=$(git rev-parse --abbrev-ref HEAD)
case "$git_branch" in
release/*)
true
;;
*)
false
;;
esac
}
# Gets the timestamp and git commit hash suffix to append to a version string
function get_version_suffix() {
local short_git_hash=$(git rev-parse --short HEAD)
local timestamp=$(date +%Y%m%d%H%M%S)
echo "-${timestamp}-${short_git_hash}"
}
# Exits successfully if uncommitted changes exist, unsuccessfully if clean.
function uncommitted_changes_exist() {
status_lines=$(git status --porcelain=v1 2>/dev/null | wc -l)
if [[ $status_lines -gt 0 ]]; then
true
else
false
fi
}
full_version=""
dot_file_version="$(cat .version)"
if is_release_branch; then
full_version="${dot_file_version}"
else
full_version="${dot_file_version}$(get_version_suffix)"
fi
# Using the presence of the GIT_BRANCH environment variable to determine if we
# are running in a Jenkins pipeline. The pipeline puts files in place that look
# like uncommitted changes, but they are not.
if uncommitted_changes_exist && [[ -z $GIT_BRANCH ]]; then
full_version="${full_version}-dirty"
fi
echo $full_version