occam-verify-cli 1.0.16 → 1.0.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -49,8 +49,13 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
|
|
|
49
49
|
callback(error, success);
|
|
50
50
|
return;
|
|
51
51
|
}
|
|
52
|
-
var releaseContextFromDependency = context.releaseContextFromDependency, dependencyString = dependency.asString();
|
|
53
|
-
|
|
52
|
+
var releaseContextFromDependency = context.releaseContextFromDependency, dependencyString = dependency.asString(), dependentNamesLength = dependentNames.length;
|
|
53
|
+
if (dependentNamesLength === 0) {
|
|
54
|
+
log.info("Creating the '".concat(releaseName, "' context..."));
|
|
55
|
+
} else {
|
|
56
|
+
var lastDependentName = last(dependentNames), dependentName = lastDependentName; ///
|
|
57
|
+
log.info("Creating the '".concat(releaseName, "' context given the '").concat(dependentName, "' dependant's '").concat(dependencyString, "' dependency..."));
|
|
58
|
+
}
|
|
54
59
|
releaseContextFromDependency(dependency, context, function(error, releaseContext) {
|
|
55
60
|
if (error) {
|
|
56
61
|
callback(error);
|
|
@@ -69,7 +74,6 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
|
|
|
69
74
|
return;
|
|
70
75
|
}
|
|
71
76
|
releaseContextMap[releaseName] = releaseContext;
|
|
72
|
-
log.info("...created the '".concat(releaseName, "' context."));
|
|
73
77
|
createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, function(error, success) {
|
|
74
78
|
if (error) {
|
|
75
79
|
callback(error);
|
|
@@ -80,6 +84,7 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
|
|
|
80
84
|
callback(error, success);
|
|
81
85
|
return;
|
|
82
86
|
}
|
|
87
|
+
log.debug("...created the '".concat(releaseName, "' context."));
|
|
83
88
|
callback(error, success);
|
|
84
89
|
});
|
|
85
90
|
}, context);
|
|
@@ -94,9 +99,9 @@ function initialiseReleaseContext(dependency, context) {
|
|
|
94
99
|
if (!releaseContextInitialised) {
|
|
95
100
|
initialiseDependencyReleaseContexts(dependency, releaseContext, context);
|
|
96
101
|
var log1 = context.log, releaseContexts = retrieveReleaseContexts(releaseContext, releaseContextMap);
|
|
97
|
-
log1.
|
|
102
|
+
log1.info("Initialising the '".concat(dependencyName, "' context..."));
|
|
98
103
|
releaseContext.initialise(releaseContexts);
|
|
99
|
-
log1.
|
|
104
|
+
log1.debug("...initialised the '".concat(dependencyName, "' context."));
|
|
100
105
|
}
|
|
101
106
|
}
|
|
102
107
|
}
|
|
@@ -199,4 +204,4 @@ function initialiseDependencyReleaseContexts(dependency, releaseContext, context
|
|
|
199
204
|
});
|
|
200
205
|
}
|
|
201
206
|
|
|
202
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/releaseContext.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nconst { last } = arrayUtilities;\n\nfunction createReleaseContext(dependency, dependentNames, context, callback) {\n  const { log, releaseContextMap } = context,\n        dependencyName = dependency.getName(),\n        releaseName = dependencyName, ///\n        releaseContext = releaseContextMap[releaseName] || null;\n\n  if (releaseContext !== null) {\n    const error = null,\n          releaseMatchesDependency = checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context);\n\n    let success;\n\n    if (releaseMatchesDependency) {\n      log.debug(`Already created the '${releaseName}' context.`);\n\n      success = true;\n    } else {\n      success = false;\n    }\n\n    callback(error, success);\n\n    return;\n  }\n\n  const { releaseContextFromDependency } = context,\n        dependencyString = dependency.asString();\n\n  log.debug(`Creating the '${releaseName}' context given the '${dependencyString}' dependency...`);\n\n  releaseContextFromDependency(dependency, context, (error, releaseContext) => {\n    if (error) {\n      callback(error);\n\n      return;\n    }\n\n    const releaseContextCreated = checkReleaseContextCreated(releaseContext, dependency, context);\n\n    if (!releaseContextCreated) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      return;\n    }\n\n    const releaseMatchesDependency = checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context);\n\n    if (!releaseMatchesDependency) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      return;\n    }\n\n    releaseContextMap[releaseName] = releaseContext;\n\n    log.info(`...created the '${releaseName}' context.`);\n\n    createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, (error, success) => {\n      if (error) {\n        callback(error);\n\n        return;\n      }\n\n      if (!success) {\n        log.warning(`...unable to create the '${releaseName}' context.`);\n\n        callback(error, success);\n\n        return;\n      }\n\n      callback(error, success);\n    });\n  }, context);\n}\n\nfunction initialiseReleaseContext(dependency, context) {\n  const { releaseContextMap } = context,\n        dependencyName = dependency.getName(),\n        releaseName = dependencyName, ///\n        releaseContext = releaseContextMap[releaseName] || null;\n\n  if (releaseContext === null) {\n    const { log } = context;\n\n    log.warning(`Unable to initialise the '${dependencyName}' context because it has not been created.`);\n  } else {\n    const releaseContextInitialised = releaseContext.isInitialised();\n\n    if (!releaseContextInitialised) {\n      initialiseDependencyReleaseContexts(dependency, releaseContext, context);\n\n      const { log } = context,\n            releaseContexts = retrieveReleaseContexts(releaseContext, releaseContextMap);\n\n      log.debug(`Initialising the '${dependencyName}' context...`);\n\n      releaseContext.initialise(releaseContexts);\n\n      log.info(`...initialised the '${dependencyName}' context.`);\n    }\n  }\n}\n\nexport default {\n  createReleaseContext,\n  initialiseReleaseContext\n};\n\nfunction retrieveReleaseContexts(releaseContext, releaseContextMap) {\n  const releaseContexts = [],\n        remainingReleaseContext = releaseContext,  ///\n        remainingReleaseContexts = [\n          remainingReleaseContext\n        ];\n\n  let remainingReleaseContextsLength = remainingReleaseContexts.length;\n\n  while (remainingReleaseContextsLength > 0) {\n    const remainingReleaseContext = remainingReleaseContexts.shift(),\n          releaseContext = remainingReleaseContext;  ///\n\n    releaseContexts.push(releaseContext);\n\n    const dependencies = releaseContext.getDependencies();\n\n    dependencies.forEachDependency((dependency) => {\n      const dependencyName = dependency.getName(),\n            releaseName = dependencyName, ///\n            releaseContext = releaseContextMap[releaseName],\n            releaseContextsIncludesReleaseContext = releaseContexts.includes(releaseContext),\n            remainingReleaseContextsIncludesReleaseContext = remainingReleaseContexts.includes(releaseContext);\n\n      if (!releaseContextsIncludesReleaseContext && !remainingReleaseContextsIncludesReleaseContext) {\n        const remainingReleaseContext = releaseContext; ///\n\n        remainingReleaseContexts.push(remainingReleaseContext);\n      }\n    });\n\n    remainingReleaseContextsLength = remainingReleaseContexts.length;\n  }\n\n  return releaseContexts;\n}\n\nfunction checkReleaseContextCreated(releaseContext, dependency, context) {\n  const releaseContextCreated = (releaseContext !== null);\n\n  if (!releaseContextCreated) {\n    const { log } = context,\n          dependencyName = dependency.getName(),\n          releaseName = dependencyName; ///\n\n    log.warning(`The '${releaseName}' context could not be created. Perhaps the 'meta.json' file is missing or invalid. Or there could be a dependency mismatch.`);\n  }\n\n  return releaseContextCreated;\n}\n\nfunction checkCyclicDependencyExists(dependency, dependentNames, context) {\n  const dependencyName = dependency.getName(),\n        dependentNamesIncludesDependencyName = dependentNames.includes(dependencyName),\n        cyclicDependencyExists = dependentNamesIncludesDependencyName;  ///\n\n  if (cyclicDependencyExists) {\n    const { log } = context,\n          firstDependentName = first(dependentNames),\n          dependencyNames = [  ///\n            ...dependentNames,\n            firstDependentName\n          ],\n          dependencyNamesString = dependencyNames.join(`' -> '`);\n\n    log.warning(`There is a cyclic dependency: '${dependencyNamesString}'.`);\n  }\n\n  return cyclicDependencyExists;\n}\n\nfunction checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context) {\n  let releaseMatchesDependency = true;\n\n  const entries = releaseContext.getEntries(),\n        shortenedVersion = dependency.getShortedVersion();\n\n  if (shortenedVersion !== null) {\n    const entriesMatchShortenedVersion = entries.matchShortenedVersion(shortenedVersion);\n\n    if (!entriesMatchShortenedVersion) {\n      const { log } = context,\n            version = releaseContext.getVersion(),\n            lastDependentName = last(dependentNames),\n            dependentName = lastDependentName,  ///\n            versionString = version.toString(),\n            dependencyString = dependency.asString();\n\n      log.warning(`Version mismatch: The '${dependentName}' dependent requires the '${dependencyString}' dependency but a context with version '${versionString}' was provided.`);\n\n      releaseMatchesDependency = false;\n    }\n  }\n\n  return releaseMatchesDependency;\n}\n\nfunction createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, callback) {\n  const dependencyName = dependency.getName(),\n        dependencies = releaseContext.getDependencies();\n\n  dependentNames = [ ...dependentNames, dependencyName ];  ///\n\n  dependencies.asynchronousForEachDependency((dependency, next, done) => {\n    const cyclicDependencyExists = checkCyclicDependencyExists(dependency, dependentNames);\n\n    if (cyclicDependencyExists) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      callback = null;\n\n      done();\n\n      return;\n    }\n\n    createReleaseContext(dependency, dependentNames, context, (error, success) => {\n      if (error) {\n        callback(error);\n\n        callback = null;\n\n        done();\n\n        return;\n      }\n\n      if (!success) {\n        callback(error, success);\n\n        callback = null;\n\n        done();\n\n        return;\n      }\n\n      next();\n    });\n  }, done);\n\n  function done() {\n    if (callback !== null) {\n      const error = null,\n            success = true;\n\n      callback(error, success);\n    }\n  }\n}\n\nfunction initialiseDependencyReleaseContexts(dependency, releaseContext, context) {\n  const dependencies = releaseContext.getDependencies();\n\n  dependencies.forEachDependency((dependency) => {  ///\n    initialiseReleaseContext(dependency, context);\n  });\n}\n"],"names":["last","arrayUtilities","createReleaseContext","dependency","dependentNames","context","callback","log","releaseContextMap","dependencyName","getName","releaseName","releaseContext","error","releaseMatchesDependency","checkReleaseMatchesDependency","success","debug","releaseContextFromDependency","dependencyString","asString","releaseContextCreated","checkReleaseContextCreated","info","createDependencyReleaseContexts","warning","initialiseReleaseContext","releaseContextInitialised","isInitialised","initialiseDependencyReleaseContexts","releaseContexts","retrieveReleaseContexts","initialise","remainingReleaseContext","remainingReleaseContexts","remainingReleaseContextsLength","length","shift","push","dependencies","getDependencies","forEachDependency","releaseContextsIncludesReleaseContext","includes","remainingReleaseContextsIncludesReleaseContext","checkCyclicDependencyExists","dependentNamesIncludesDependencyName","cyclicDependencyExists","firstDependentName","first","dependencyNames","dependencyNamesString","join","entries","getEntries","shortenedVersion","getShortedVersion","entriesMatchShortenedVersion","matchShortenedVersion","version","getVersion","lastDependentName","dependentName","versionString","toString","asynchronousForEachDependency","next","done"],"mappings":"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"}
|
|
207
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/releaseContext.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nconst { last } = arrayUtilities;\n\nfunction createReleaseContext(dependency, dependentNames, context, callback) {\n  const { log, releaseContextMap } = context,\n        dependencyName = dependency.getName(),\n        releaseName = dependencyName, ///\n        releaseContext = releaseContextMap[releaseName] || null;\n\n  if (releaseContext !== null) {\n    const error = null,\n          releaseMatchesDependency = checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context);\n\n    let success;\n\n    if (releaseMatchesDependency) {\n      log.debug(`Already created the '${releaseName}' context.`);\n\n      success = true;\n    } else {\n      success = false;\n    }\n\n    callback(error, success);\n\n    return;\n  }\n\n  const { releaseContextFromDependency } = context,\n        dependencyString = dependency.asString(),\n        dependentNamesLength = dependentNames.length;\n\n  if (dependentNamesLength === 0) {\n    log.info(`Creating the '${releaseName}' context...`);\n  } else {\n    const lastDependentName = last(dependentNames),\n          dependentName = lastDependentName;  ///\n\n    log.info(`Creating the '${releaseName}' context given the '${dependentName}' dependant's '${dependencyString}' dependency...`);\n  }\n\n  releaseContextFromDependency(dependency, context, (error, releaseContext) => {\n    if (error) {\n      callback(error);\n\n      return;\n    }\n\n    const releaseContextCreated = checkReleaseContextCreated(releaseContext, dependency, context);\n\n    if (!releaseContextCreated) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      return;\n    }\n\n    const releaseMatchesDependency = checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context);\n\n    if (!releaseMatchesDependency) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      return;\n    }\n\n    releaseContextMap[releaseName] = releaseContext;\n\n    createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, (error, success) => {\n      if (error) {\n        callback(error);\n\n        return;\n      }\n\n      if (!success) {\n        log.warning(`...unable to create the '${releaseName}' context.`);\n\n        callback(error, success);\n\n        return;\n      }\n\n      log.debug(`...created the '${releaseName}' context.`);\n\n      callback(error, success);\n    });\n  }, context);\n}\n\nfunction initialiseReleaseContext(dependency, context) {\n  const { releaseContextMap } = context,\n        dependencyName = dependency.getName(),\n        releaseName = dependencyName, ///\n        releaseContext = releaseContextMap[releaseName] || null;\n\n  if (releaseContext === null) {\n    const { log } = context;\n\n    log.warning(`Unable to initialise the '${dependencyName}' context because it has not been created.`);\n  } else {\n    const releaseContextInitialised = releaseContext.isInitialised();\n\n    if (!releaseContextInitialised) {\n      initialiseDependencyReleaseContexts(dependency, releaseContext, context);\n\n      const { log } = context,\n            releaseContexts = retrieveReleaseContexts(releaseContext, releaseContextMap);\n\n      log.info(`Initialising the '${dependencyName}' context...`);\n\n      releaseContext.initialise(releaseContexts);\n\n      log.debug(`...initialised the '${dependencyName}' context.`);\n    }\n  }\n}\n\nexport default {\n  createReleaseContext,\n  initialiseReleaseContext\n};\n\nfunction retrieveReleaseContexts(releaseContext, releaseContextMap) {\n  const releaseContexts = [],\n        remainingReleaseContext = releaseContext,  ///\n        remainingReleaseContexts = [\n          remainingReleaseContext\n        ];\n\n  let remainingReleaseContextsLength = remainingReleaseContexts.length;\n\n  while (remainingReleaseContextsLength > 0) {\n    const remainingReleaseContext = remainingReleaseContexts.shift(),\n          releaseContext = remainingReleaseContext;  ///\n\n    releaseContexts.push(releaseContext);\n\n    const dependencies = releaseContext.getDependencies();\n\n    dependencies.forEachDependency((dependency) => {\n      const dependencyName = dependency.getName(),\n            releaseName = dependencyName, ///\n            releaseContext = releaseContextMap[releaseName],\n            releaseContextsIncludesReleaseContext = releaseContexts.includes(releaseContext),\n            remainingReleaseContextsIncludesReleaseContext = remainingReleaseContexts.includes(releaseContext);\n\n      if (!releaseContextsIncludesReleaseContext && !remainingReleaseContextsIncludesReleaseContext) {\n        const remainingReleaseContext = releaseContext; ///\n\n        remainingReleaseContexts.push(remainingReleaseContext);\n      }\n    });\n\n    remainingReleaseContextsLength = remainingReleaseContexts.length;\n  }\n\n  return releaseContexts;\n}\n\nfunction checkReleaseContextCreated(releaseContext, dependency, context) {\n  const releaseContextCreated = (releaseContext !== null);\n\n  if (!releaseContextCreated) {\n    const { log } = context,\n          dependencyName = dependency.getName(),\n          releaseName = dependencyName; ///\n\n    log.warning(`The '${releaseName}' context could not be created. Perhaps the 'meta.json' file is missing or invalid. Or there could be a dependency mismatch.`);\n  }\n\n  return releaseContextCreated;\n}\n\nfunction checkCyclicDependencyExists(dependency, dependentNames, context) {\n  const dependencyName = dependency.getName(),\n        dependentNamesIncludesDependencyName = dependentNames.includes(dependencyName),\n        cyclicDependencyExists = dependentNamesIncludesDependencyName;  ///\n\n  if (cyclicDependencyExists) {\n    const { log } = context,\n          firstDependentName = first(dependentNames),\n          dependencyNames = [  ///\n            ...dependentNames,\n            firstDependentName\n          ],\n          dependencyNamesString = dependencyNames.join(`' -> '`);\n\n    log.warning(`There is a cyclic dependency: '${dependencyNamesString}'.`);\n  }\n\n  return cyclicDependencyExists;\n}\n\nfunction checkReleaseMatchesDependency(releaseContext, dependency, dependentNames, context) {\n  let releaseMatchesDependency = true;\n\n  const entries = releaseContext.getEntries(),\n        shortenedVersion = dependency.getShortedVersion();\n\n  if (shortenedVersion !== null) {\n    const entriesMatchShortenedVersion = entries.matchShortenedVersion(shortenedVersion);\n\n    if (!entriesMatchShortenedVersion) {\n      const { log } = context,\n            version = releaseContext.getVersion(),\n            lastDependentName = last(dependentNames),\n            dependentName = lastDependentName,  ///\n            versionString = version.toString(),\n            dependencyString = dependency.asString();\n\n      log.warning(`Version mismatch: The '${dependentName}' dependent requires the '${dependencyString}' dependency but a context with version '${versionString}' was provided.`);\n\n      releaseMatchesDependency = false;\n    }\n  }\n\n  return releaseMatchesDependency;\n}\n\nfunction createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, callback) {\n  const dependencyName = dependency.getName(),\n        dependencies = releaseContext.getDependencies();\n\n  dependentNames = [ ...dependentNames, dependencyName ];  ///\n\n  dependencies.asynchronousForEachDependency((dependency, next, done) => {\n    const cyclicDependencyExists = checkCyclicDependencyExists(dependency, dependentNames);\n\n    if (cyclicDependencyExists) {\n      const error = null,\n            success = false;\n\n      callback(error, success);\n\n      callback = null;\n\n      done();\n\n      return;\n    }\n\n    createReleaseContext(dependency, dependentNames, context, (error, success) => {\n      if (error) {\n        callback(error);\n\n        callback = null;\n\n        done();\n\n        return;\n      }\n\n      if (!success) {\n        callback(error, success);\n\n        callback = null;\n\n        done();\n\n        return;\n      }\n\n      next();\n    });\n  }, done);\n\n  function done() {\n    if (callback !== null) {\n      const error = null,\n            success = true;\n\n      callback(error, success);\n    }\n  }\n}\n\nfunction initialiseDependencyReleaseContexts(dependency, releaseContext, context) {\n  const dependencies = releaseContext.getDependencies();\n\n  dependencies.forEachDependency((dependency) => {  ///\n    initialiseReleaseContext(dependency, context);\n  });\n}\n"],"names":["last","arrayUtilities","createReleaseContext","dependency","dependentNames","context","callback","log","releaseContextMap","dependencyName","getName","releaseName","releaseContext","error","releaseMatchesDependency","checkReleaseMatchesDependency","success","debug","releaseContextFromDependency","dependencyString","asString","dependentNamesLength","length","info","lastDependentName","dependentName","releaseContextCreated","checkReleaseContextCreated","createDependencyReleaseContexts","warning","initialiseReleaseContext","releaseContextInitialised","isInitialised","initialiseDependencyReleaseContexts","releaseContexts","retrieveReleaseContexts","initialise","remainingReleaseContext","remainingReleaseContexts","remainingReleaseContextsLength","shift","push","dependencies","getDependencies","forEachDependency","releaseContextsIncludesReleaseContext","includes","remainingReleaseContextsIncludesReleaseContext","checkCyclicDependencyExists","dependentNamesIncludesDependencyName","cyclicDependencyExists","firstDependentName","first","dependencyNames","dependencyNamesString","join","entries","getEntries","shortenedVersion","getShortedVersion","entriesMatchShortenedVersion","matchShortenedVersion","version","getVersion","versionString","toString","asynchronousForEachDependency","next","done"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -30,9 +30,17 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
|
|
|
30
30
|
}
|
|
31
31
|
|
|
32
32
|
const { releaseContextFromDependency } = context,
|
|
33
|
-
dependencyString = dependency.asString()
|
|
33
|
+
dependencyString = dependency.asString(),
|
|
34
|
+
dependentNamesLength = dependentNames.length;
|
|
34
35
|
|
|
35
|
-
|
|
36
|
+
if (dependentNamesLength === 0) {
|
|
37
|
+
log.info(`Creating the '${releaseName}' context...`);
|
|
38
|
+
} else {
|
|
39
|
+
const lastDependentName = last(dependentNames),
|
|
40
|
+
dependentName = lastDependentName; ///
|
|
41
|
+
|
|
42
|
+
log.info(`Creating the '${releaseName}' context given the '${dependentName}' dependant's '${dependencyString}' dependency...`);
|
|
43
|
+
}
|
|
36
44
|
|
|
37
45
|
releaseContextFromDependency(dependency, context, (error, releaseContext) => {
|
|
38
46
|
if (error) {
|
|
@@ -65,8 +73,6 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
|
|
|
65
73
|
|
|
66
74
|
releaseContextMap[releaseName] = releaseContext;
|
|
67
75
|
|
|
68
|
-
log.info(`...created the '${releaseName}' context.`);
|
|
69
|
-
|
|
70
76
|
createDependencyReleaseContexts(dependency, releaseContext, dependentNames, context, (error, success) => {
|
|
71
77
|
if (error) {
|
|
72
78
|
callback(error);
|
|
@@ -82,6 +88,8 @@ function createReleaseContext(dependency, dependentNames, context, callback) {
|
|
|
82
88
|
return;
|
|
83
89
|
}
|
|
84
90
|
|
|
91
|
+
log.debug(`...created the '${releaseName}' context.`);
|
|
92
|
+
|
|
85
93
|
callback(error, success);
|
|
86
94
|
});
|
|
87
95
|
}, context);
|
|
@@ -106,11 +114,11 @@ function initialiseReleaseContext(dependency, context) {
|
|
|
106
114
|
const { log } = context,
|
|
107
115
|
releaseContexts = retrieveReleaseContexts(releaseContext, releaseContextMap);
|
|
108
116
|
|
|
109
|
-
log.
|
|
117
|
+
log.info(`Initialising the '${dependencyName}' context...`);
|
|
110
118
|
|
|
111
119
|
releaseContext.initialise(releaseContexts);
|
|
112
120
|
|
|
113
|
-
log.
|
|
121
|
+
log.debug(`...initialised the '${dependencyName}' context.`);
|
|
114
122
|
}
|
|
115
123
|
}
|
|
116
124
|
}
|