aboutsummaryrefslogtreecommitdiffstats
path: root/utils/agljobtemplate.py
diff options
context:
space:
mode:
authorLoys Ollivier <lollivier@baylibre.com>2018-01-03 14:53:55 +0100
committerLoys Ollivier <lollivier@baylibre.com>2018-01-10 15:31:28 +0100
commit788b31a122c3823d5e756524187975a2ad14cac6 (patch)
tree4fdcd1bc746e4ee958f6f71e030aaef192ed5995 /utils/agljobtemplate.py
parentc5cfc4c57f6acb4e1955aa2cd18d7a9062a67acb (diff)
utils: change the url / build behavior scheme
This is the first patch of the serie to differentiate builds and urls. As of now we were using the --url option to specify a build-type. Add a new option --build-type which specifies which type of build it is. From this build-type if no url is specified, the url can be defaulted by a configuration file. This configuration file is specific per user, e.g. AGL, others... Change-Id: I9ce801a7518b78ee859c6c3bbcad3a89e884e832 Signed-off-by: Loys Ollivier <lollivier@baylibre.com>
Diffstat (limited to 'utils/agljobtemplate.py')
-rw-r--r--utils/agljobtemplate.py22
1 files changed, 14 insertions, 8 deletions
diff --git a/utils/agljobtemplate.py b/utils/agljobtemplate.py
index f41dded..25efab6 100644
--- a/utils/agljobtemplate.py
+++ b/utils/agljobtemplate.py
@@ -11,13 +11,18 @@ def get_extension(path):
return path.split('.')[-1]
-def parse_url_file(template_path, url_file, url_type):
+def parse_url_file(template_path, url_file, build_type):
url_file_path = template_path + '/URLs/' + url_file
try:
with open(url_file_path):
cfg = ConfigParser.ConfigParser()
cfg.read(url_file_path)
- return cfg.get(url_type, 'urlbase'), cfg.get('infra', 'style')
+ config = cfg.items(build_type)
+ for section in config:
+ if section[0] == "test_plan":
+ print section[1]
+ print build_type
+ return cfg.get(build_type, 'urlbase'), cfg.get('infra', 'style')
except IOError as err:
raise err
@@ -86,6 +91,7 @@ class Agljobtemplate(object):
job_name="AGL-short-smoke", priority="medium", tests=[], rfs_type=None,
lava_callback=None, kci_callback=None,
rfs_image=None, kernel_image=None, dtb_image=None, modules_image=None,
+ build_type=None,
build_version=None):
test_templates = []
@@ -104,16 +110,16 @@ class Agljobtemplate(object):
job['yocto_machine'] = machine
job['priority'] = priority
- if url[:4] != 'http':
- # If not a full url, read from config file
- url_base, infra = parse_url_file(self._template_path, 'default.cfg', url)
+ # If the user doesn't specify an URL, use the default one from the build-type
+ if url is None:
+ url_base, infra = parse_url_file(self._template_path, 'default.cfg', build_type)
if infra == 'AGL':
# If not set, create a build_version from other args
if (not build_version) and (url_branch) and (url_version):
- build_version = 'AGL-' + url + '-' + url_branch + '-' + url_version
+ build_version = 'AGL-' + build_type + '-' + url_branch + '-' + url_version
url_fragment = ''
- if (url != 'default'):
+ if (build_type != 'default'):
url_fragment += url_branch + '/' + url_version + '/'
if (machine == 'm3ulcb') or (machine == 'porter'):
@@ -121,7 +127,7 @@ class Agljobtemplate(object):
else:
url_fragment += machine
- if (url != 'ci'):
+ if (build_type != 'ci'):
url_fragment += '/deploy/images/' + machine
url = urlparse.urljoin(url_base, url_fragment)