mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-06 04:13:55 +02:00
8169d56ef7
Co-authored-by: Christopher Fenner <26137398+CCFenner@users.noreply.github.com>
202 lines
8.2 KiB
Groovy
202 lines
8.2 KiB
Groovy
import static com.sap.piper.Prerequisites.checkScript
|
|
|
|
import com.sap.piper.ConfigurationHelper
|
|
import com.sap.piper.GenerateDocumentation
|
|
import com.sap.piper.GitUtils
|
|
import com.sap.piper.Utils
|
|
import com.sap.piper.integration.CloudFoundry
|
|
|
|
import groovy.text.GStringTemplateEngine
|
|
import groovy.transform.Field
|
|
|
|
@Field String STEP_NAME = getClass().getName()
|
|
|
|
@Field Set GENERAL_CONFIG_KEYS = STEP_CONFIG_KEYS
|
|
|
|
@Field Set STEP_CONFIG_KEYS = [
|
|
/** @see dockerExecute */
|
|
'dockerImage',
|
|
/** @see dockerExecute*/
|
|
'dockerEnvVars',
|
|
/** @see dockerExecute */
|
|
'dockerOptions',
|
|
/** @see dockerExecute*/
|
|
'dockerWorkspace',
|
|
/**
|
|
* Defines the behavior, in case tests fail.
|
|
* @possibleValues `true`, `false`
|
|
*/
|
|
'failOnError',
|
|
/**
|
|
* Only if `testRepository` is provided: Branch of testRepository, defaults to master.
|
|
*/
|
|
'gitBranch',
|
|
/**
|
|
* Only if `testRepository` is provided: Credentials for a protected testRepository
|
|
* @possibleValues Jenkins credentials id
|
|
*/
|
|
'gitSshKeyCredentialsId',
|
|
/**
|
|
* The test collection that should be executed. This could also be a file pattern.
|
|
*/
|
|
'newmanCollection',
|
|
/**
|
|
* Specify an environment file path or URL. Environments provide a set of variables that one can use within collections.
|
|
* see also [Newman docs](https://github.com/postmanlabs/newman#newman-run-collection-file-source-options)
|
|
*/
|
|
'newmanEnvironment',
|
|
/**
|
|
* Specify the file path or URL for global variables. Global variables are similar to environment variables but have a lower precedence and can be overridden by environment variables having the same name.
|
|
* see also [Newman docs](https://github.com/postmanlabs/newman#newman-run-collection-file-source-options)
|
|
*/
|
|
'newmanGlobals',
|
|
/**
|
|
* The shell command that will be executed inside the docker container to install Newman.
|
|
*/
|
|
'newmanInstallCommand',
|
|
/**
|
|
* The newman command that will be executed inside the docker container.
|
|
*/
|
|
'newmanRunCommand',
|
|
/**
|
|
* If specific stashes should be considered for the tests, you can pass this via this parameter.
|
|
*/
|
|
'stashContent',
|
|
/**
|
|
* Define an additional repository where the test implementation is located.
|
|
* For protected repositories the `testRepository` needs to contain the ssh git url.
|
|
*/
|
|
'testRepository',
|
|
/**
|
|
* Define name array of cloud foundry apps deployed for which secrets (clientid and clientsecret) will be appended
|
|
* to the newman command that overrides the environment json entries
|
|
* (--env-var <appName_clientid>=${clientid} & --env-var <appName_clientsecret>=${clientsecret})
|
|
*/
|
|
'cfAppsWithSecrets',
|
|
'cloudFoundry',
|
|
/**
|
|
* Cloud Foundry API endpoint.
|
|
* @parentConfigKey cloudFoundry
|
|
*/
|
|
'apiEndpoint',
|
|
/**
|
|
* Credentials to be used for deployment.
|
|
* @parentConfigKey cloudFoundry
|
|
*/
|
|
'credentialsId',
|
|
/**
|
|
* Cloud Foundry target organization.
|
|
* @parentConfigKey cloudFoundry
|
|
*/
|
|
'org',
|
|
/**
|
|
* Cloud Foundry target space.
|
|
* @parentConfigKey cloudFoundry
|
|
*/
|
|
'space',
|
|
/**
|
|
* Print more detailed information into the log.
|
|
* @possibleValues `true`, `false`
|
|
*/
|
|
'verbose'
|
|
]
|
|
|
|
@Field Map CONFIG_KEY_COMPATIBILITY = [cloudFoundry: [apiEndpoint: 'cfApiEndpoint', credentialsId: 'cfCredentialsId', org: 'cfOrg', space: 'cfSpace']]
|
|
|
|
@Field Set PARAMETER_KEYS = STEP_CONFIG_KEYS
|
|
|
|
/**
|
|
* This script executes [Postman](https://www.getpostman.com) tests from a collection via the [Newman](https://www.getpostman.com/docs/v6/postman/collection_runs/command_line_integration_with_newman) command line tool.
|
|
*/
|
|
@GenerateDocumentation
|
|
void call(Map parameters = [:]) {
|
|
handlePipelineStepErrors(stepName: STEP_NAME, stepParameters: parameters) {
|
|
|
|
def script = checkScript(this, parameters) ?: this
|
|
def utils = parameters?.juStabUtils ?: new Utils()
|
|
String stageName = parameters.stageName ?: env.STAGE_NAME
|
|
|
|
// load default & individual configuration
|
|
Map config = ConfigurationHelper.newInstance(this)
|
|
.loadStepDefaults([:], stageName)
|
|
.mixinGeneralConfig(script.commonPipelineEnvironment, GENERAL_CONFIG_KEYS)
|
|
.mixinStepConfig(script.commonPipelineEnvironment, STEP_CONFIG_KEYS)
|
|
.mixinStageConfig(script.commonPipelineEnvironment, stageName, STEP_CONFIG_KEYS)
|
|
.mixin(parameters, PARAMETER_KEYS, CONFIG_KEY_COMPATIBILITY)
|
|
.use()
|
|
|
|
new Utils().pushToSWA([
|
|
step: STEP_NAME,
|
|
stepParamKey1: 'scriptMissing',
|
|
stepParam1: parameters?.script == null
|
|
], config)
|
|
|
|
config.stashContent = config.testRepository
|
|
?[GitUtils.handleTestRepository(this, config)]
|
|
:utils.unstashAll(config.stashContent)
|
|
|
|
List collectionList = findFiles(glob: config.newmanCollection)?.toList()
|
|
if (collectionList.isEmpty()) {
|
|
error "[${STEP_NAME}] No collection found with pattern '${config.newmanCollection}'"
|
|
} else {
|
|
echo "[${STEP_NAME}] Found files ${collectionList}"
|
|
}
|
|
|
|
dockerExecute(
|
|
script: script,
|
|
dockerImage: config.dockerImage,
|
|
dockerEnvVars: config.dockerEnvVars,
|
|
dockerOptions: config.dockerOptions,
|
|
dockerWorkspace: config.dockerWorkspace,
|
|
stashContent: config.stashContent
|
|
) {
|
|
sh returnStatus: true, script: """
|
|
node --version
|
|
npm --version
|
|
"""
|
|
sh "NPM_CONFIG_PREFIX=~/.npm-global ${config.newmanInstallCommand}"
|
|
for(String collection : collectionList){
|
|
def collectionDisplayName = collection.toString().replace(File.separatorChar,(char)'_').tokenize('.').first()
|
|
// resolve templates
|
|
def command = GStringTemplateEngine.newInstance()
|
|
.createTemplate(config.newmanRunCommand)
|
|
.make([
|
|
config: config.plus([newmanCollection: collection]),
|
|
collectionDisplayName: collectionDisplayName
|
|
]).toString()
|
|
def command_secrets = ''
|
|
if(config.cfAppsWithSecrets){
|
|
CloudFoundry cfUtils = new CloudFoundry(script);
|
|
config.cfAppsWithSecrets.each { appName ->
|
|
def xsuaaCredentials = cfUtils.getXsuaaCredentials(config.cloudFoundry.apiEndpoint,
|
|
config.cloudFoundry.org,
|
|
config.cloudFoundry.space,
|
|
config.cloudFoundry.credentialsId,
|
|
appName,
|
|
config.verbose ? true : false ) //to avoid config.verbose as "null" if undefined in yaml and since function parameter boolean
|
|
command_secrets += " --env-var ${appName}_clientid=${xsuaaCredentials.clientid} --env-var ${appName}_clientsecret=${xsuaaCredentials.clientsecret}"
|
|
echo "Exposing client id and secret for ${appName}: as ${appName}_clientid and ${appName}_clientsecret to newman"
|
|
}
|
|
}
|
|
|
|
if(!config.failOnError) command += ' --suppress-exit-code'
|
|
try {
|
|
if (config.cfAppsWithSecrets && command_secrets){
|
|
echo "PATH=\$PATH:~/.npm-global/bin newman ${command} **env/secrets**"
|
|
sh """
|
|
set +x
|
|
PATH=\$PATH:~/.npm-global/bin newman ${command} ${command_secrets}
|
|
"""
|
|
}
|
|
else{
|
|
sh "PATH=\$PATH:~/.npm-global/bin newman ${command}"
|
|
}
|
|
}
|
|
catch (e) {
|
|
error "[${STEP_NAME}] ERROR: The execution of the newman tests failed, see the log for details."
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|