mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-18 05:18:24 +02:00
41dcebb3a5
* Changes: - New YamlSubstituteVariables step to substitute variables in YAML files with values from another YAML - New Tests, that check the different substitution patterns. - Added test resources, including various manifest and variables files. - Improved usage of JenkinsLoggingRule - Improved JenkinsReadYamlRule to properly reflect the mocked library's behaviour. - Added a new JenkinsWriteYamlRule. * Changes: - added a Logger that checks a config.verbose flag before it logs debug messages. - changed error handling to rethrow Yaml parsing exception in case of wrongly-formatted Yaml files. - changed JenkinsWriteYamlRule to capture Yaml file details of every invocation of writeYaml. This allows sanity checks at end of tests, even if there were multiple invocations. - adjusted tests. * Changes: - Removed javadoc-code blocks from API documentation since they are not supported. - Removed skipDeletion boolean. - Added a new deleteFile script which deletes a file if present. - Added a new JenkinsDeleteFileRule to mock deleteFile script and optionally skip deletion for tests. - Adjusted yamlSubstituteVariables script. - Adjusted tests to include new JenkinsDeleteFileRule. - Changed code that deletes an already existing output file to produce better logs. * Changes: - Turned yamlSubstituteVariables into a script that works purely based on Yaml data (not files). - Added a new cfManifestSubstituteVariables that uses yamlSubstituteVariables under the hood but works based on files. - Adjusted tests, and added new ones. * Adjusted documentation and a few log statements. * Changed documentation to no longer include javadoc code statements. * Made mocking of deletion of a file a default. Adjusted tests. * Changed signature of yamlSubstituteVariables' call method to return void. * Changes: - Fixed naming issues in deleteFile. - Renamed Logger to DebugHelper. - Fixed some documentation. * Changed implementation of deleteFile not to use java.io.File - which is evil when using it for file operations. * PROPERLY Changed implementation of deleteFile not to use java.io.File - which is evil when using it for file operations. * Changes: - Added tests for deleteFile script - Changed JenkinsFileExistsRule to also keep track of which files have been queried for existence. * Changes: - Removed java.io.File usage from cfManifestSubstituteVariables and using fileExists instead now. - Adjusted tests. * Wrapped file path inside ticks to allow spaces in file path when calling deleteFile. * Removed null checks of mandatory parameters, and resorted to ConfigurationHelper.withMandatoryProperty * Fixed a NullPointer due to weird Jenkins / Groovy behaviour. * Changes: - Turned yamlSubstituteVariables step into a utils class. - Added tests - Adjusted cfManifestSubstituteVariables to use utils class instead of step. - Adjusted tests - Adjusted APIs of DebugHelper. * Re-introduced log statement that shows what variables are being replaced and with what. * Changing API of YamlUtils to take the script and config as input. * Test * Test * Test * Test * Test * Fixing issue. * Fixing issue. * Changes: - Refactored DebugHelper and YamlUtils to make usage nicer and rely on dependency injection. - Removed Field for DebugHelper and turned it into local variable. - Adjusted classes using the above. - Adjusted tests where necessary. * Added link to CF standards to YamlUtils also. * Add docu for step cfManifestSubstituteVariables.md * Added documentation. * Added missing script parameter to documentation. Some steps document it, some don't. Right now you need it, so we document it. * Fixed some layouting and typos * Beautified exception listing. * Removed trailing whitespaces to make code climate checks pass. * Trying to get documentation generated, with all the exceptions to markup one should not use. * cosmetics. * cosmetics, part 2 * Code climate changes... * Inlined deleteFile step. * Added two more tests to properly check file deletion and output handling. * Changes: - adjusted API to take a list of variables files, as does 'cf push --vars-file' - adjusted API to allow for an optional list of variable key-value-maps as does 'cf push --vars' - reproduced conflict resolution and overriding behavior of variables files and vars lists - adjusted tests and documentation * Added missing paramter to doc comment. * Re-checked docs for missing paramters or params that have no counterpart in the method signature. * Adjusted documentation. * Removed absolute path usage from documentation. * corrected documentation. * Changed javadoc comment to plain comment. * Turned all comments to plain comments.
601 lines
34 KiB
Groovy
601 lines
34 KiB
Groovy
import org.junit.Before
|
|
import org.junit.Rule
|
|
import org.junit.Test
|
|
import org.junit.rules.ExpectedException
|
|
import org.junit.rules.RuleChain
|
|
import util.*
|
|
|
|
import static org.junit.Assert.*
|
|
import static util.JenkinsWriteYamlRule.DATA
|
|
import static util.JenkinsWriteYamlRule.SERIALIZED_YAML
|
|
|
|
public class CfManifestSubstituteVariablesTest extends BasePiperTest {
|
|
|
|
private JenkinsStepRule script = new JenkinsStepRule(this)
|
|
private JenkinsReadYamlRule readYamlRule = new JenkinsReadYamlRule(this)
|
|
private JenkinsWriteYamlRule writeYamlRule = new JenkinsWriteYamlRule(this)
|
|
private JenkinsErrorRule errorRule = new JenkinsErrorRule(this)
|
|
private JenkinsEnvironmentRule environmentRule = new JenkinsEnvironmentRule(this)
|
|
private JenkinsLoggingRule loggingRule = new JenkinsLoggingRule(this)
|
|
private ExpectedException expectedExceptionRule = ExpectedException.none()
|
|
private JenkinsFileExistsRule fileExistsRule = new JenkinsFileExistsRule(this, [])
|
|
|
|
@Rule
|
|
public RuleChain rules = Rules
|
|
.getCommonRules(this)
|
|
.around(fileExistsRule)
|
|
.around(readYamlRule)
|
|
.around(writeYamlRule)
|
|
.around(errorRule)
|
|
.around(environmentRule)
|
|
.around(loggingRule)
|
|
.around(script)
|
|
.around(expectedExceptionRule)
|
|
|
|
@Before
|
|
public void setup() {
|
|
readYamlRule.registerYaml("manifest.yml", new FileInputStream(new File("test/resources/variableSubstitution/manifest.yml")))
|
|
.registerYaml("manifest-variables.yml", new FileInputStream(new File("test/resources/variableSubstitution/manifest-variables.yml")))
|
|
.registerYaml("test/resources/variableSubstitution/manifest.yml", new FileInputStream(new File("test/resources/variableSubstitution/manifest.yml")))
|
|
.registerYaml("test/resources/variableSubstitution/manifest-variables.yml", new FileInputStream(new File("test/resources/variableSubstitution/manifest-variables.yml")))
|
|
.registerYaml("test/resources/variableSubstitution/invalid_manifest.yml", new FileInputStream(new File("test/resources/variableSubstitution/invalid_manifest.yml")))
|
|
.registerYaml("test/resources/variableSubstitution/novars_manifest.yml", new FileInputStream(new File("test/resources/variableSubstitution/novars_manifest.yml")))
|
|
.registerYaml("test/resources/variableSubstitution/multi_manifest.yml", new FileInputStream(new File("test/resources/variableSubstitution/multi_manifest.yml")))
|
|
.registerYaml("test/resources/variableSubstitution/datatypes_manifest.yml", new FileInputStream(new File("test/resources/variableSubstitution/datatypes_manifest.yml")))
|
|
.registerYaml("test/resources/variableSubstitution/datatypes_manifest-variables.yml", new FileInputStream(new File("test/resources/variableSubstitution/datatypes_manifest-variables.yml")))
|
|
.registerYaml("test/resources/variableSubstitution/manifest-variables-conflicting.yml", new FileInputStream(new File("test/resources/variableSubstitution/manifest-variables-conflicting.yml")))
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_SkipsExecution_If_ManifestNotPresent() throws Exception {
|
|
String manifestFileName = "nonexistent/manifest.yml"
|
|
String variablesFileName = "nonexistent/manifest-variables.yml"
|
|
List<String> variablesFiles = [ variablesFileName ]
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Could not find YAML file at ${manifestFileName}. Skipping variable substitution.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, script: nullScript
|
|
|
|
//Check that nothing was written
|
|
assertNull(writeYamlRule.files[manifestFileName])
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_SkipsExecution_If_VariablesFileNotPresent() throws Exception {
|
|
String manifestFileName = "test/resources/variableSubstitution/manifest.yml"
|
|
String variablesFileName = "nonexistent/manifest-variables.yml"
|
|
List<String> variablesFiles = [ variablesFileName ]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Did not find manifest variable substitution file at ${variablesFileName}.")
|
|
expectedExceptionRule.expect(hudson.AbortException)
|
|
expectedExceptionRule.expectMessage("[CFManifestSubstituteVariables] Could not find all given manifest variable substitution files. Make sure all files given as manifestVariablesFiles exist.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, script: nullScript
|
|
|
|
//Check that nothing was written
|
|
assertNull(writeYamlRule.files[manifestFileName])
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_Throws_If_manifestInvalid() throws Exception {
|
|
String manifestFileName = "test/resources/variableSubstitution/invalid_manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/invalid_manifest.yml"
|
|
List<String> variablesFiles = [ variablesFileName ]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
|
|
//check that exception is thrown and that it has the correct message.
|
|
expectedExceptionRule.expect(org.yaml.snakeyaml.scanner.ScannerException)
|
|
expectedExceptionRule.expectMessage("found character '%' that cannot start any token. (Do not use % for indentation)")
|
|
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Could not load manifest file at ${manifestFileName}.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, script: nullScript
|
|
|
|
//Check that nothing was written
|
|
assertNull(writeYamlRule.files[manifestFileName])
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_Throws_If_manifestVariablesInvalid() throws Exception {
|
|
String manifestFileName = "test/resources/variableSubstitution/manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/invalid_manifest.yml"
|
|
List<String> variablesFiles = [ variablesFileName ]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
|
|
//check that exception is thrown and that it has the correct message.
|
|
expectedExceptionRule.expect(org.yaml.snakeyaml.scanner.ScannerException)
|
|
expectedExceptionRule.expectMessage("found character '%' that cannot start any token. (Do not use % for indentation)")
|
|
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Could not load manifest variables file at ${variablesFileName}")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, script: nullScript
|
|
|
|
//Check that nothing was written
|
|
assertNull(writeYamlRule.files[manifestFileName])
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_UsesDefaultFileName_If_NoManifestSpecified() throws Exception {
|
|
// In this test, we check that the implementation will resort to the default manifest file name.
|
|
// Since the file is not present, the implementation should stop, but the log should indicate that the
|
|
// the default file name was used.
|
|
|
|
String manifestFileName = "manifest.yml" // default name should be chosen.
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Could not find YAML file at ${manifestFileName}. Skipping variable substitution.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables script: nullScript
|
|
|
|
//Check that nothing was written
|
|
assertNull(writeYamlRule.files[manifestFileName])
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_UsesDefaultFileName_If_NoVariablesFileSpecified() throws Exception {
|
|
// In this test, we check that the implementation will resort to the default manifest _variables_ file name.
|
|
// Since the file is not present, the implementation should stop, but the log should indicate that the
|
|
// the default file name was used.
|
|
|
|
String manifestFileName = "test/resources/variableSubstitution/manifest.yml"
|
|
String variablesFileName = "manifest-variables.yml" // default file name that should be chosen.
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Did not find manifest variable substitution file at ${variablesFileName}.")
|
|
.expect("[CFManifestSubstituteVariables] Could not find any default manifest variable substitution file at ${variablesFileName}, and no manifest variables list was specified. Skipping variable substitution.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, script: nullScript
|
|
|
|
//Check that nothing was written
|
|
assertNull(writeYamlRule.files[manifestFileName])
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_ReplacesVariablesProperly_InSingleYamlFiles() throws Exception {
|
|
String manifestFileName = "test/resources/variableSubstitution/manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/manifest-variables.yml"
|
|
List<String> variablesFiles = [ variablesFileName ]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Loaded manifest at ${manifestFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Loaded variables file at ${variablesFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Replaced variables in ${manifestFileName}.")
|
|
.expect("[CFManifestSubstituteVariables] Wrote output file (with variables replaced) at ${manifestFileName}.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, script: nullScript
|
|
|
|
|
|
String yamlStringAfterReplacement = writeYamlRule.files[manifestFileName].get(SERIALIZED_YAML) as String
|
|
Map<String, Object> manifestDataAfterReplacement = writeYamlRule.files[manifestFileName].get(DATA)
|
|
|
|
//Check that something was written
|
|
assertNotNull(manifestDataAfterReplacement)
|
|
|
|
// check that there are no unresolved variables left.
|
|
assertAllVariablesReplaced(yamlStringAfterReplacement)
|
|
|
|
// check that resolved variables have expected values
|
|
assertCorrectVariableResolution(manifestDataAfterReplacement)
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
private void assertAllVariablesReplaced(String yamlStringAfterReplacement) {
|
|
assertFalse(yamlStringAfterReplacement.contains("(("))
|
|
assertFalse(yamlStringAfterReplacement.contains("))"))
|
|
}
|
|
|
|
private void assertCorrectVariableResolution(Map<String, Object> manifestDataAfterReplacement) {
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("name").equals("uniquePrefix-catalog-service-odatav2-0.0.1"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("routes").get(0).get("route").equals("uniquePrefix-catalog-service-odatav2-001.cfapps.eu10.hana.ondemand.com"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("services").get(0).equals("uniquePrefix-catalog-service-odatav2-xsuaa"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("services").get(1).equals("uniquePrefix-catalog-service-odatav2-hana"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("xsuaa-instance-name").equals("uniquePrefix-catalog-service-odatav2-xsuaa"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("db_service_instance_name").equals("uniquePrefix-catalog-service-odatav2-hana"))
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_ReplacesVariablesProperly_InMultiYamlFiles() throws Exception {
|
|
String manifestFileName = "test/resources/variableSubstitution/multi_manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/manifest-variables.yml"
|
|
List<String> variablesFiles = [ variablesFileName ]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Loaded manifest at ${manifestFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Loaded variables file at ${variablesFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Replaced variables in ${manifestFileName}.")
|
|
.expect("[CFManifestSubstituteVariables] Wrote output file (with variables replaced) at ${manifestFileName}.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, script: nullScript
|
|
|
|
|
|
String yamlStringAfterReplacement = writeYamlRule.files[manifestFileName].get(SERIALIZED_YAML) as String
|
|
List<Object> manifestDataAfterReplacement = writeYamlRule.files[manifestFileName].get(DATA)
|
|
|
|
//Check that something was written
|
|
assertNotNull(manifestDataAfterReplacement)
|
|
|
|
// check that there are no unresolved variables left.
|
|
assertAllVariablesReplaced(yamlStringAfterReplacement)
|
|
|
|
//check that result still is a multi-YAML file.
|
|
assertEquals("Dumped YAML after replacement should still be a multi-YAML file.",2, manifestDataAfterReplacement.size())
|
|
|
|
// check that resolved variables have expected values
|
|
manifestDataAfterReplacement.each { yaml ->
|
|
assertCorrectVariableResolution(yaml as Map<String, Object>)
|
|
}
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_ReplacesVariablesFromListProperly_whenNoManifestVariablesFilesGiven_InMultiYamlFiles() throws Exception {
|
|
// This test replaces variables in multi-yaml files from a list of specified variables
|
|
// the the user has not specified any variable substitution files list.
|
|
|
|
String manifestFileName = "test/resources/variableSubstitution/multi_manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/manifest-variables.yml"
|
|
|
|
List<Map<String, Object>> variablesList = [
|
|
["unique-prefix" : "uniquePrefix"],
|
|
["xsuaa-instance-name" : "uniquePrefix-catalog-service-odatav2-xsuaa"],
|
|
["hana-instance-name" : "uniquePrefix-catalog-service-odatav2-hana"]
|
|
]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Loaded manifest at ${manifestFileName}!")
|
|
//.expect("[CFManifestSubstituteVariables] Loaded variables file at ${variablesFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Replaced variables in ${manifestFileName}.")
|
|
.expect("[CFManifestSubstituteVariables] Wrote output file (with variables replaced) at ${manifestFileName}.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariables: variablesList, script: nullScript
|
|
|
|
String yamlStringAfterReplacement = writeYamlRule.files[manifestFileName].get(SERIALIZED_YAML) as String
|
|
List<Object> manifestDataAfterReplacement = writeYamlRule.files[manifestFileName].get(DATA)
|
|
|
|
//Check that something was written
|
|
assertNotNull(manifestDataAfterReplacement)
|
|
|
|
// check that there are no unresolved variables left.
|
|
assertAllVariablesReplaced(yamlStringAfterReplacement)
|
|
|
|
//check that result still is a multi-YAML file.
|
|
assertEquals("Dumped YAML after replacement should still be a multi-YAML file.",2, manifestDataAfterReplacement.size())
|
|
|
|
// check that resolved variables have expected values
|
|
manifestDataAfterReplacement.each { yaml ->
|
|
assertCorrectVariableResolution(yaml as Map<String, Object>)
|
|
}
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_ReplacesVariablesFromListProperly_whenEmptyManifestVariablesFilesGiven_InMultiYamlFiles() throws Exception {
|
|
// This test replaces variables in multi-yaml files from a list of specified variables
|
|
// the the user has specified an empty list of variable substitution files.
|
|
|
|
String manifestFileName = "test/resources/variableSubstitution/multi_manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/manifest-variables.yml"
|
|
List<String> variablesFiles = []
|
|
|
|
List<Map<String, Object>> variablesList = [
|
|
["unique-prefix" : "uniquePrefix"],
|
|
["xsuaa-instance-name" : "uniquePrefix-catalog-service-odatav2-xsuaa"],
|
|
["hana-instance-name" : "uniquePrefix-catalog-service-odatav2-hana"]
|
|
]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Loaded manifest at ${manifestFileName}!")
|
|
//.expect("[CFManifestSubstituteVariables] Loaded variables file at ${variablesFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Replaced variables in ${manifestFileName}.")
|
|
.expect("[CFManifestSubstituteVariables] Wrote output file (with variables replaced) at ${manifestFileName}.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, manifestVariables: variablesList, script: nullScript
|
|
|
|
String yamlStringAfterReplacement = writeYamlRule.files[manifestFileName].get(SERIALIZED_YAML) as String
|
|
List<Object> manifestDataAfterReplacement = writeYamlRule.files[manifestFileName].get(DATA)
|
|
|
|
//Check that something was written
|
|
assertNotNull(manifestDataAfterReplacement)
|
|
|
|
// check that there are no unresolved variables left.
|
|
assertAllVariablesReplaced(yamlStringAfterReplacement)
|
|
|
|
//check that result still is a multi-YAML file.
|
|
assertEquals("Dumped YAML after replacement should still be a multi-YAML file.",2, manifestDataAfterReplacement.size())
|
|
|
|
// check that resolved variables have expected values
|
|
manifestDataAfterReplacement.each { yaml ->
|
|
assertCorrectVariableResolution(yaml as Map<String, Object>)
|
|
}
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_SkipsExecution_If_NoVariablesInManifest() throws Exception {
|
|
// This test makes sure that, if no variables are found in a manifest that need
|
|
// to be replaced, the execution is eventually skipped and the manifest remains
|
|
// untouched.
|
|
|
|
String manifestFileName = "test/resources/variableSubstitution/novars_manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/manifest-variables.yml"
|
|
List<String> variablesFiles = [ variablesFileName ]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Loaded manifest at ${manifestFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Loaded variables file at ${variablesFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] No variables were found or could be replaced in ${manifestFileName}. Skipping variable substitution.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, script: nullScript
|
|
|
|
//Check that nothing was written
|
|
assertNull(writeYamlRule.files[manifestFileName])
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_SupportsAllDataTypes() throws Exception {
|
|
// This test makes sure that, all datatypes supported by YAML are also
|
|
// properly substituted by the substituteVariables step.
|
|
// In particular this includes variables of type:
|
|
// Integer, Boolean, String, Float and inline JSON documents (which are parsed as multi-line strings)
|
|
// and complex types (like other YAML objects).
|
|
// The test also checks the differing behaviour when substituting nodes that only consist of a
|
|
// variable reference and nodes that contains several variable references or additional string constants.
|
|
|
|
String manifestFileName = "test/resources/variableSubstitution/datatypes_manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/datatypes_manifest-variables.yml"
|
|
List<String> variablesFiles = [ variablesFileName ]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Loaded manifest at ${manifestFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Loaded variables file at ${variablesFileName}!")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, script: nullScript
|
|
|
|
String yamlStringAfterReplacement = writeYamlRule.files[manifestFileName].get(SERIALIZED_YAML) as String
|
|
Map<String, Object> manifestDataAfterReplacement = writeYamlRule.files[manifestFileName].get(DATA)
|
|
|
|
//Check that something was written
|
|
assertNotNull(manifestDataAfterReplacement)
|
|
|
|
assertAllVariablesReplaced(yamlStringAfterReplacement)
|
|
assertCorrectVariableResolution(manifestDataAfterReplacement)
|
|
|
|
assertDataTypeAndSubstitutionCorrectness(manifestDataAfterReplacement)
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
private void assertDataTypeAndSubstitutionCorrectness(Map<String, Object> manifestDataAfterReplacement) {
|
|
// See datatypes_manifest.yml and datatypes_manifest-variables.yml.
|
|
// Note: For debugging consider turning on YAML writing to a file in JenkinsWriteYamlRule to see the
|
|
// actual outcome of replacing variables (for visual inspection).
|
|
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("instances").equals(1))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("instances") instanceof Integer)
|
|
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("services").get(0) instanceof String)
|
|
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("booleanVariable").equals(true))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("booleanVariable") instanceof Boolean)
|
|
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("floatVariable") == 0.25)
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("floatVariable") instanceof Double)
|
|
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("json-variable") instanceof String)
|
|
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("object-variable") instanceof Map)
|
|
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("string-variable").startsWith("true-0.25-1-"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("string-variable") instanceof String)
|
|
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("single-var-with-string-constants").equals("true-with-some-more-text"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("single-var-with-string-constants") instanceof String)
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_replacesManifestIfNoOutputGiven() throws Exception {
|
|
// Test that makes sure that the original input manifest file is replaced with
|
|
// a version that has variables replaced (by deleting the original file and
|
|
// dumping a new one with the same name).
|
|
|
|
String manifestFileName = "test/resources/variableSubstitution/datatypes_manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/datatypes_manifest-variables.yml"
|
|
List<String> variablesFiles = [ variablesFileName ]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Loaded manifest at ${manifestFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Loaded variables file at ${variablesFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Successfully deleted file '${manifestFileName}'.")
|
|
.expect("[CFManifestSubstituteVariables] Replaced variables in ${manifestFileName}.")
|
|
.expect("[CFManifestSubstituteVariables] Wrote output file (with variables replaced) at ${manifestFileName}.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, script: nullScript
|
|
|
|
String yamlStringAfterReplacement = writeYamlRule.files[manifestFileName].get(SERIALIZED_YAML) as String
|
|
Map<String, Object> manifestDataAfterReplacement = writeYamlRule.files[manifestFileName].get(DATA)
|
|
|
|
//Check that something was written
|
|
assertNotNull(manifestDataAfterReplacement)
|
|
|
|
assertAllVariablesReplaced(yamlStringAfterReplacement)
|
|
assertCorrectVariableResolution(manifestDataAfterReplacement)
|
|
|
|
assertDataTypeAndSubstitutionCorrectness(manifestDataAfterReplacement)
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_writesToOutputFileIfGiven() throws Exception {
|
|
// Test that makes sure that the output is written to the specified file and that the original input manifest
|
|
// file is NOT deleted / replaced.
|
|
|
|
String manifestFileName = "test/resources/variableSubstitution/datatypes_manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/datatypes_manifest-variables.yml"
|
|
List<String> variablesFiles = [ variablesFileName ]
|
|
String outputFileName = "output.yml"
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Loaded manifest at ${manifestFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Loaded variables file at ${variablesFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Replaced variables in ${manifestFileName}.")
|
|
.expect("[CFManifestSubstituteVariables] Wrote output file (with variables replaced) at ${outputFileName}.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, outputManifestFile: outputFileName, script: nullScript
|
|
|
|
String yamlStringAfterReplacement = writeYamlRule.files[outputFileName].get(SERIALIZED_YAML) as String
|
|
Map<String, Object> manifestDataAfterReplacement = writeYamlRule.files[outputFileName].get(DATA)
|
|
|
|
//Check that something was written
|
|
assertNotNull(manifestDataAfterReplacement)
|
|
|
|
// make sure the input file was NOT deleted.
|
|
assertFalse(loggingRule.expected.contains("[CFManifestSubstituteVariables] Successfully deleted file '${manifestFileName}'."))
|
|
|
|
assertAllVariablesReplaced(yamlStringAfterReplacement)
|
|
assertCorrectVariableResolution(manifestDataAfterReplacement)
|
|
|
|
assertDataTypeAndSubstitutionCorrectness(manifestDataAfterReplacement)
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
public void substituteVariables_resolvesConflictsProperly_InMultiYamlFiles() throws Exception {
|
|
// This test checks if the resolution and of conflicting variables and the
|
|
// overriding nature of variable lists vs. variable files lists is working properly.
|
|
|
|
String manifestFileName = "test/resources/variableSubstitution/multi_manifest.yml"
|
|
String variablesFileName = "test/resources/variableSubstitution/manifest-variables.yml"
|
|
String conflictingVariablesFileName = "test/resources/variableSubstitution/manifest-variables-conflicting.yml"
|
|
List<String> variablesFiles = [ variablesFileName, conflictingVariablesFileName ] //introducing a conflicting file whose entries should win, since it is last in the list
|
|
|
|
List<Map<String, Object>> variablesList = [
|
|
["unique-prefix" : "uniquePrefix-from-vars-list"],
|
|
["unique-prefix" : "uniquePrefix-from-vars-list-conflicting"] // introduce a conflict that should win, since it is last in the list.
|
|
]
|
|
|
|
fileExistsRule.registerExistingFile(manifestFileName)
|
|
fileExistsRule.registerExistingFile(variablesFileName)
|
|
fileExistsRule.registerExistingFile(conflictingVariablesFileName)
|
|
|
|
// check that a proper log is written.
|
|
loggingRule.expect("[CFManifestSubstituteVariables] Loaded manifest at ${manifestFileName}!")
|
|
//.expect("[CFManifestSubstituteVariables] Loaded variables file at ${variablesFileName}!")
|
|
.expect("[CFManifestSubstituteVariables] Replaced variables in ${manifestFileName}.")
|
|
.expect("[CFManifestSubstituteVariables] Wrote output file (with variables replaced) at ${manifestFileName}.")
|
|
|
|
// execute step
|
|
script.step.cfManifestSubstituteVariables manifestFile: manifestFileName, manifestVariablesFiles: variablesFiles, manifestVariables: variablesList, script: nullScript
|
|
|
|
String yamlStringAfterReplacement = writeYamlRule.files[manifestFileName].get(SERIALIZED_YAML) as String
|
|
List<Object> manifestDataAfterReplacement = writeYamlRule.files[manifestFileName].get(DATA)
|
|
|
|
//Check that something was written
|
|
assertNotNull(manifestDataAfterReplacement)
|
|
|
|
// check that there are no unresolved variables left.
|
|
assertAllVariablesReplaced(yamlStringAfterReplacement)
|
|
|
|
//check that result still is a multi-YAML file.
|
|
assertEquals("Dumped YAML after replacement should still be a multi-YAML file.",2, manifestDataAfterReplacement.size())
|
|
|
|
// check that resolved variables have expected values
|
|
manifestDataAfterReplacement.each { yaml ->
|
|
assertCorrectVariableSubstitutionUnderConflictAndWithOverriding(yaml as Map<String, Object>)
|
|
}
|
|
|
|
// check that the step was marked as a success (even if it did do nothing).
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
private void assertCorrectVariableSubstitutionUnderConflictAndWithOverriding(Map<String, Object> manifestDataAfterReplacement) {
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("name").equals("uniquePrefix-from-vars-list-conflicting-catalog-service-odatav2-0.0.1"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("routes").get(0).get("route").equals("uniquePrefix-from-vars-list-conflicting-catalog-service-odatav2-001.cfapps.eu10.hana.ondemand.com"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("services").get(0).equals("uniquePrefix-catalog-service-odatav2-xsuaa-conflicting-from-file"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("services").get(1).equals("uniquePrefix-catalog-service-odatav2-hana"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("xsuaa-instance-name").equals("uniquePrefix-catalog-service-odatav2-xsuaa-conflicting-from-file"))
|
|
assertTrue(manifestDataAfterReplacement.get("applications").get(0).get("env").get("db_service_instance_name").equals("uniquePrefix-catalog-service-odatav2-hana"))
|
|
}
|
|
}
|