Add ability to manage extra repo config with different way
Add ability to manage extra repo config with:
- merge strategy, when passed extra repo config will be deeply merged
with default extra repo config;
- override strategy, when passed extra repo config will be used
instead of default extra repo config;
Also add function for merging nested maps.
Change-Id: I4b672e9dd984fc82c4a5a0e1a86e93d7b1099dba
diff --git a/src/com/mirantis/mk/Common.groovy b/src/com/mirantis/mk/Common.groovy
index 1f96449..09f1b51 100644
--- a/src/com/mirantis/mk/Common.groovy
+++ b/src/com/mirantis/mk/Common.groovy
@@ -919,9 +919,9 @@
/**
* Ugly processing basic funcs with /etc/apt
- * @param configYaml
+ * @param repoConfig YAML text or Map
* Example :
- configYaml = '''
+ repoConfig = '''
---
aprConfD: |-
APT::Get::AllowUnauthenticated 'true';
@@ -940,8 +940,13 @@
*
*/
-def debianExtraRepos(configYaml) {
- def config = readYaml text: configYaml
+def debianExtraRepos(repoConfig) {
+ def config = null
+ if (repoConfig instanceof Map) {
+ config = repoConfig
+ } else {
+ config = readYaml text: repoConfig
+ }
if (config.get('repo', false)) {
for (String repo in config['repo'].keySet()) {
source = config['repo'][repo]['source']
diff --git a/src/com/mirantis/mk/SaltModelTesting.groovy b/src/com/mirantis/mk/SaltModelTesting.groovy
index 3e40b0f..199f213 100644
--- a/src/com/mirantis/mk/SaltModelTesting.groovy
+++ b/src/com/mirantis/mk/SaltModelTesting.groovy
@@ -43,25 +43,26 @@
"--name=${dockerContainerName}",
"--cpus=${dockerMaxCpus}"
]
-
- // extra repo on mirror.mirantis.net, which is not supported before 2018.11.0 release
- def extraRepoSource = "deb [arch=amd64] http://mirror.mirantis.com/${distribRevision}/extra/xenial xenial main"
- try {
- def releaseNaming = 'yyyy.MM.dd'
- def repoDateUsed = new Date().parse(releaseNaming, distribRevision)
- def extraAvailableFrom = new Date().parse(releaseNaming, '2018.11.0')
- if (repoDateUsed < extraAvailableFrom) {
- extraRepoSource = "deb http://apt.mcp.mirantis.net:8085/xenial ${distribRevision} extra"
- }
- } catch (Exception e) {
- common.warningMsg(e)
- if ( !(distribRevision in [ 'nightly', 'proposed', 'testing' ] )) {
- extraRepoSource = "deb http://apt.mcp.mirantis.net:8085/xenial ${distribRevision} extra"
- }
- }
-
def dockerOptsFinal = (dockerBaseOpts + dockerExtraOpts).join(' ')
- def defaultExtraReposYaml = """
+ def extraReposConfig = null
+ if (baseRepoPreConfig) {
+ // extra repo on mirror.mirantis.net, which is not supported before 2018.11.0 release
+ def extraRepoSource = "deb [arch=amd64] http://mirror.mirantis.com/${distribRevision}/extra/xenial xenial main"
+ try {
+ def releaseNaming = 'yyyy.MM.dd'
+ def repoDateUsed = new Date().parse(releaseNaming, distribRevision)
+ def extraAvailableFrom = new Date().parse(releaseNaming, '2018.11.0')
+ if (repoDateUsed < extraAvailableFrom) {
+ extraRepoSource = "deb http://apt.mcp.mirantis.net:8085/xenial ${distribRevision} extra"
+ }
+ } catch (Exception e) {
+ common.warningMsg(e)
+ if ( !(distribRevision in [ 'nightly', 'proposed', 'testing' ] )) {
+ extraRepoSource = "deb http://apt.mcp.mirantis.net:8085/xenial ${distribRevision} extra"
+ }
+ }
+
+ def defaultExtraReposYaml = """
---
aprConfD: |-
APT::Get::AllowUnauthenticated 'true';
@@ -89,9 +90,17 @@
ubuntu-sec:
source: "deb [arch=amd64] http://mirror.mirantis.com/${distribRevision}/ubuntu xenial-security main restricted universe"
"""
-
+ // override for now
+ def extraRepoMergeStrategy = config.get('extraRepoMergeStrategy', 'override')
+ def extraRepos = config.get('extraRepos', [:])
+ def defaultRepos = readYaml text: defaultExtraReposYaml
+ if (extraRepoMergeStrategy == 'merge') {
+ extraReposConfig = common.mergeMaps(defaultRepos, extraRepos)
+ } else {
+ extraReposConfig = extraRepos ? extraRepos : defaultRepos
+ }
+ }
def img = docker.image(dockerImageName)
- def extraReposYaml = config.get('extraReposYaml', defaultExtraReposYaml)
img.pull()
@@ -110,7 +119,7 @@
rm -vf /etc/apt/sources.list.d/* || true
rm -vf /etc/apt/preferences.d/* || true
""")
- common.debianExtraRepos(extraReposYaml)
+ common.debianExtraRepos(extraReposConfig)
sh('''#!/bin/bash -xe
apt-get update
apt-get install -y python-netaddr