mirror of
https://github.com/vyos/vyos-build.git
synced 2025-10-01 20:28:40 +02:00
T596: use a more descriptive dev build version format.
This commit is contained in:
parent
7c8769b751
commit
d2e4f63f03
3
data/versions
Normal file
3
data/versions
Normal file
@ -0,0 +1,3 @@
|
||||
{
|
||||
"current": "1.2.0"
|
||||
}
|
||||
@ -32,7 +32,8 @@ deps = {
|
||||
'live-build',
|
||||
'pbuilder',
|
||||
'devscripts',
|
||||
'python3-pystache'
|
||||
'python3-pystache',
|
||||
'python3-git'
|
||||
],
|
||||
'binaries': []
|
||||
}
|
||||
|
||||
@ -1,6 +1,6 @@
|
||||
#!/usr/bin/python3
|
||||
#
|
||||
# Copyright (C) 2016 VyOS maintainers and contributors
|
||||
# Copyright (C) 2018 VyOS maintainers and contributors
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License version 2 or later as
|
||||
@ -25,16 +25,18 @@ import datetime
|
||||
import json
|
||||
import uuid
|
||||
|
||||
import git
|
||||
|
||||
import defaults
|
||||
import util
|
||||
|
||||
# Load the build config
|
||||
util.check_build_config()
|
||||
with open(defaults.BUILD_CONFIG, 'r') as f:
|
||||
build_config = json.load(f)
|
||||
|
||||
|
||||
# Create a build timestamp
|
||||
now = datetime.datetime.today()
|
||||
|
||||
build_timestamp = now.strftime("%Y%m%d%H%M")
|
||||
|
||||
# FIXME: use aware rather than naive object
|
||||
@ -43,9 +45,23 @@ build_date = now.strftime("%a %d %b %Y %H:%M UTC")
|
||||
# Assign a (hopefully) unique identifier to the build (UUID)
|
||||
build_id = str(uuid.uuid4())
|
||||
|
||||
# Create a build version
|
||||
if build_config['build_type'] == 'development':
|
||||
version = "999.{0}".format(build_timestamp)
|
||||
try:
|
||||
# Load the branch to version mapping file
|
||||
with open('data/versions') as f:
|
||||
version_mapping = json.load(f)
|
||||
|
||||
repo = git.Repo('.')
|
||||
git_branch = repo.active_branch.name
|
||||
branch_version = version_mapping[git_branch]
|
||||
|
||||
version = "{0}-rolling+{1}".format(branch_version, build_timestamp)
|
||||
except Exception as e:
|
||||
print("Could not build a version string specific to git branch, falling back to default: {0}".format(str(e)))
|
||||
version = "999.{0}".format(build_timestamp)
|
||||
else:
|
||||
# Release build, use the version from ./configure arguments
|
||||
version = build_config['version']
|
||||
|
||||
version_data = {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user