summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniil Baturin <daniil@vyos.io>2020-04-09 12:08:43 +0300
committerDaniil Baturin <daniil@vyos.io>2020-04-09 12:08:43 +0300
commitd64011558e32576eb521ba8cee8d9165897bbb60 (patch)
tree1c3c36b3cfe03a69720c6cf2a5fb7b743f415afe
parent967cf9df004aba4b883a2d35a01e159e10c3489c (diff)
downloadvyos-build-d64011558e32576eb521ba8cee8d9165897bbb60.tar.gz
vyos-build-d64011558e32576eb521ba8cee8d9165897bbb60.zip
T2254: add fields for git branch, build type, and build comment to the version data.
-rwxr-xr-xscripts/build-config3
-rwxr-xr-xscripts/make-version-file40
2 files changed, 32 insertions, 11 deletions
diff --git a/scripts/build-config b/scripts/build-config
index c613b0e4..356aa340 100755
--- a/scripts/build-config
+++ b/scripts/build-config
@@ -71,7 +71,8 @@ options = {
'pbuilder-debian-mirror': ('Debian repository mirror for pbuilder env bootstrap', lambda: build_defaults['debian_mirror'], None),
'vyos-mirror': ('VyOS package mirror', lambda: build_defaults["vyos_mirror"], None),
'build-type': ('Build type, release or development', lambda: 'development', lambda x: x in ['release', 'development']),
- 'version': ('Version number (release builds only)', None, None)
+ 'version': ('Version number (release builds only)', None, None),
+ 'build-comment': ('Optional build comment', lambda: '', None)
}
# Create the option parser
diff --git a/scripts/make-version-file b/scripts/make-version-file
index fa632eed..a2828434 100755
--- a/scripts/make-version-file
+++ b/scripts/make-version-file
@@ -46,22 +46,33 @@ build_date = now.strftime("%a %d %b %Y %H:%M UTC")
build_uuid = str(uuid.uuid4())
# Initialize Git object from our repository
-repo = git.Repo('.')
-
-# Retrieve the Git commit ID of the repository, 14 charaters will be sufficient
-build_git = repo.head.object.hexsha[:14]
-# If somone played around with the source tree and the build is "dirty", mark it
-if repo.is_dirty():
- build_git += "-dirty"
+try:
+ repo = git.Repo('.')
+
+ # Retrieve the Git commit ID of the repository, 14 charaters will be sufficient
+ build_git = repo.head.object.hexsha[:14]
+ # If somone played around with the source tree and the build is "dirty", mark it
+ if repo.is_dirty():
+ build_git += "-dirty"
+
+ # Retrieve git branch name
+ git_branch = repo.active_branch.name
+except Exception as e:
+ print("Could not retrieve information from git: {0}".format(str(e)))
+ build_git = ""
+ git_branch = ""
+ git_commit = ""
# Create a build version
if build_config['build_type'] == 'development':
try:
+ if not git_branch:
+ raise ValueError("git branch could not be determined")
+
# Load the branch to version mapping file
with open('data/versions') as f:
version_mapping = json.load(f)
- git_branch = repo.active_branch.name
branch_version = version_mapping[git_branch]
version = "{0}-rolling-{1}".format(branch_version, build_timestamp)
@@ -72,12 +83,20 @@ else:
# Release build, use the version from ./configure arguments
version = build_config['version']
+if build_config['build_type'] == 'development':
+ lts_build = False
+else:
+ lts_build = True
+
version_data = {
'version': version,
'built_by': build_config['build_by'],
'built_on': build_date,
'build_uuid': build_uuid,
- 'build_git': build_git
+ 'build_git': build_git,
+ 'build_branch': git_branch,
+ 'lts_build': lts_build,
+ 'build_comment': build_config['build_comment']
}
os.makedirs(os.path.join(defaults.CHROOT_INCLUDES_DIR, 'usr/share/vyos'), exist_ok=True)
@@ -85,8 +104,9 @@ with open(os.path.join(defaults.CHROOT_INCLUDES_DIR, 'usr/share/vyos/version.jso
json.dump(version_data, f)
# For backwards compatibility with 'add system image' script from older versions
-# we need a file in old format so that script can find out the version of the image
+# we need a file in the old format so that script can find out the version of the image
# for upgrade
+os.makedirs(os.path.join(defaults.CHROOT_INCLUDES_DIR, 'opt/vyatta/etc/'), exist_ok=True)
with open(os.path.join(defaults.CHROOT_INCLUDES_DIR, 'opt/vyatta/etc/version'), 'w') as f:
print("Version: {0}".format(version), file=f)