Actions de pipeline Jenkins
Utilisez ces actions dans votre pipeline Jenkins pour interagir avec le modèle de données DevOps Config.
Les pipelines Jenkins scriptés et déclaratifs sont pris en charge.
- snDevOpsConfig
Action combinée pour charger, valider et publier des données de configuration.
- snDevOpsConfigUpload
Charger les données de configuration dans DevOps Config via la Tâche d'agent.
- snDevOpsConfigGetSnapshots
Récupérer les instantanés pour un élément déployable ou pour tous les éléments déployables impactés.
- snDevOpsConfigPublish
Publier un instantané pour l'application et l'élément déployable donnés.
- snDevOpsConfigExport
Exporter un instantané pour une application et un élément déployable donnés.
- snDevOpsConfigRegisterPipeline
Lier un ensemble de changements et/ou un instantané à une exécution de pipeline.
- snDevOpsConfigValidate
Valider les données de configuration par rapport aux politiques de votre organisation.
- snDevOpsChange
Créer une demande de changement avec l'instantané associé joint.
snDevOpsConfig
Charger, valider et publier les changements de données de configuration en une seule étape.
Cette action combine les actions snDevOpsConfigUpload, snDevOpsConfigGetSnapshots et snDevOpsConfigRegisterPipeline en une seule action, plutôt que d'avoir à exécuter chaque action séparément.
- Variables d'entrée
configFile Spécifie le fichier de données de configuration à charger vers le chemin d'accès du composant ou de l'élément déployable dans le modèle de données. applicationName Spécifie l'application dans laquelle les données de configuration seront chargées. target Spécifie la cible du modèle de données vers laquelle les données de configuration seront chargées (par exemple, composant, collection, élément déployable). collectionName (Facultatif) Nom de la collection vers laquelle charger (requis si la cible est une collection). deployableName (Facultatif) Nom de l'élément déployable vers lequel charger (requis si la cible est un élément déployable). namePath Spécifie le chemin d'accès du nom dans le modèle de données vers lequel les données de configuration seront chargées.
Remarque :Lors du chargement vers un dossier vars, vous devez commencer le nom du chemin par « vars/ » pour spécifier le chemin d'accès du dossier variable.dataFormat Spécifie le format d'exportation des données du fichier de configuration (par exemple, JSON, YAML, XML, etc.) autoCommit Spécifie si les données de configuration doivent être validées après le chargement (vrai/faux). La valeur par défaut est vrai. autoValidate Spécifie si les données de configuration doivent être validées pendant la validation (vrai/faux). La valeur par défaut est vrai. autoPublish Spécifie si les données de configuration doivent être publiées après validation (vrai/faux). La valeur par défaut est vrai. changesetNumber (Facultatif) Spécifie l'ensemble de changements (ouvert) auquel cette activité de chargement est associée. S'il n'est pas fourni, un nouvel ensemble de changements est créé.
Remarque :Utilisé uniquement pour plusieurs scénarios de chargement.markFailed (Facultatif) Fait échouer le pipeline en cas d'échec de la tentative de validation (en raison d'un problème back-end). showResults (Facultatif) Affichez les résultats de validation dans le journal de la console Jenkins. continueWithLatest (Facultatif) Spécifie s'il faut renvoyer le dernier instantané selon la combinaison applicatioName-deployableName-changesetNumber si aucun instantané n'est généré (vrai/faux). Par défaut, la valeur est faux. - Sortie
- En cas de réussite, un instantané ou un ensemble d'instantanés.
- En cas d'échec, un message d'échec d'API/back-end s'affiche.
- Exemple
- Entrée :
snapshotObj = snDevOpsConfig( applicationName: "PaymentDemo", configFile: "config/application/Collection/Collection2/*.json", target: "collection", collectionName: "release-1.0", namePath: "settings/infrastructure/database", dataFormat: "json", autoCommit: 'true', autoValidate: 'true', autoPublish: 'true', continueWithLatest: 'true', markFailed: 'true', showResults: 'false' ) echo"*************************\n ${snapshotObj}" - Sortie :
- Entrée :
- Exemple : collection
- Remarque :Lors du chargement vers une collection, l'argument collectionName est requis.
snDevOpsConfig( applicationName: 'PaymentDemo', target: 'collection', collectionName: 'release-1.0', namePath: 'web-api-v1.0', configFile: 'k8s/helm/*.yml', dataFormat: 'yaml', autoCommit: 'true', autoValidate: 'true', autoPublish: 'true' ) - Exemple : élément déployable
- Remarque :Lors du chargement vers un élément déployable, l'argument deployableName est requis.
snDevOpsConfig( applicationName: 'PaymentDemo', target: 'deployable', deployableName: 'Production', namePath: 'web-api-v1.0', configFile: 'k8s/helm/*.yml', dataFormat: 'yaml', autoCommit: 'true', autoValidate: 'true', autoPublish: 'true' ) - Chargements multiples en une seule validation
Pour charger des données de configuration à partir de différents emplacements, ou pour charger un ensemble de données vers plusieurs cibles (par exemple, un composant, un élément déployable) suivies comme une validation unique vers votre modèle de données, vous pouvez appeler l'action snDevOpsConfigUpload autant de fois que nécessaire pour le premier ensemble de chargements, puis appeler l'action snDevOpsConfig pour le chargement final.
Voici un exemple.
Lors du premier chargement, créez une variable (par exemple, $changeset) et affectez-lui la valeur de retour de l'étape afin qu'elle puisse être réutilisée lors des chargements suivants.
Chargement 1 - fichier XML vers le composant :$changeset = snDevOpsConfigUpload( applicationName: 'PaymentDemo', target: 'component', namePath: 'paymentService-v1.0', configFile: 'infra/v1/config.xml', dataFormat: 'xml', autoCommit: 'false', autoValidate: 'false', autoPublish: 'false' )Lors des chargements suivants (et du chargement final), utilisez la variable comme entrée.
Chargement 2 - fichier JSON vers le dossier vars de l'élément déployable :snDevOpsConfig( applicationName: 'PaymentDemo', target: 'deployable', deployableName: 'Production', namePath: 'vars/dbSettings', configFile: 'infra/prod/dbConfig.json', dataFormat: 'json', changesetNumber: ”${changeset}”, autoCommit: 'false', autoValidate: 'false', autoPublish: 'false', continueWithLatest: 'true' )
- Charger plusieurs formats de données
- Pour charger des données de configuration dans différents formats de fichier, vous pouvez appeler l'action snDevOpsConfig avec ces spécifications.
- Assurez-vous que l'argument configFile utilise un caractère générique dans le chemin d'accès.
- Ne spécifiez pas l'argument dataFormat.
Voici un exemple.
- Supposons que nous avons ces fichiers de configuration.
- Voici comment charger les fichiers de configuration à l'aide de snDevOpsConfig.
snDevOpsConfig( applicationName: 'PaymentDemo', target: 'component', namePath: 'paymentService-v1.0', configFile: 'infra/v1/*', autoCommit: 'true', autoValidate: 'true', autoPublish: 'true' )
snDevOpsConfigUpload
Cette action charge un fichier de configuration à un emplacement donné dans un modèle de données d'application.
Elle est destinée à être utilisée de manière itérative pour tous les fichiers de configuration à charger dans le modèle de données d'application pendant l'exécution du pipeline.
- Charger vers :
- Un composant, une collection ou un élément déployable.
- Dossier de variables (vars) d'un composant, d'une collection ou d'un élément déployable.
- Schéma regex pour l'entrée du fichier de configuration.
- Possibilité d'être appelé plusieurs fois dans le même pipeline.
- Variables d'entrée
configFile Spécifie le fichier de données de configuration à charger vers le chemin d'accès du composant ou de l'élément déployable dans le modèle de données. applicationName Spécifie l'application dans laquelle les données de configuration seront chargées. target Spécifie la cible du modèle de données vers laquelle les données de configuration seront chargées (par exemple, composant, collection, élément déployable). collectionName (Facultatif) Nom de la collection vers laquelle charger (requis si la cible est une collection). deployableName Nom de l'élément déployable vers lequel charger (requis si la cible est un élément déployable). namePath Spécifie le chemin d'accès du nom dans le modèle de données vers lequel les données de configuration seront chargées.
Remarque :Lors du chargement vers un dossier vars, vous devez commencer le nom du chemin par « vars/ » pour spécifier le chemin d'accès du dossier variable.dataFormat Spécifie le format d'exportation des données du fichier de configuration (par exemple, JSON, YAML, XML, etc.) convertPath (Facultatif) Spécifie s'il faut conserver la structure des répertoires des fichiers de configuration (par rapport à l'espace de travail) et convertir les répertoires en chemins d'accès dans le modèle de données. changesetNumber (Facultatif) Spécifie l'ensemble de changements (ouvert) auquel cette activité de chargement est associée. S'il n'est pas fourni, un nouvel ensemble de changements est créé.
Remarque :Utilisé uniquement pour plusieurs scénarios de chargement.autoCommit Spécifie si les données de configuration doivent être validées après le chargement (vrai/faux). Par défaut, la valeur est faux. autoValidate Spécifie si les données de configuration doivent être validées pendant la validation (vrai/faux). Par défaut, la valeur est faux. - Variable de sortie
changesetNumber (Facultatif) Spécifie l'ensemble de changements (ouvert) auquel cette activité de chargement est associée.
Si un numéro d'ensemble de changements n'est pas fourni, un nouvel ensemble de changements est créé.
- Exemple
- Entrée :
Voici un exemple de l'action snDevOpsConfigUpload. À des fins d'illustration, nous allons affecter la réponse à une variable, changeSetId, qui pourrait être répercutée dans notre journal de console pour les scénarios de débogage.
changeSetId = snDevOpsConfigUpload( applicationName: "PaymentDemo", target: 'component', namePath: "web-api-v1.0", configFile: "k8s/helm/values.yml", dataFormat: "json", autoCommit: 'true', autoValidate: 'true' ) echo "Changeset: $changeSetId created" - Sortie :
En plus des données chargées dans notre modèle de données dans DevOps Config, la sortie ressemblerait à ceci (en utilisant le module d'extension Blue Ocean pour visualiser la sortie de la console).
- Entrée :
- Exemple : chargements multiples (composant)
- Vous pouvez appeler l'action de chargement plusieurs fois pour charger des données de configuration dans différents formats de fichiers à partir de différents emplacements, tout en conservant la partie des chargements d'un ensemble de changements.
- Lors du premier chargement, nommez l'action afin que la variable de sortie changesetNumber puisse être réutilisée lors des chargements suivants.Chargement du fichier YAML :
$changeset = snDevOpsConfigUpload( applicationName: 'PaymentDemo', target: 'component', namePath: 'wep-api-v1.0', configFile: 'k8s/helm/values.yml', dataFormat: 'yaml', autoCommit: 'false', autoValidate: 'false' ) - Dans les chargements suivants, référencez la variable de sortie changesetNumber du premier chargement en tant que variable d'entrée.Chargement de 3 fichiers JSON :
snDevOpsConfigUpload( applicationName: 'PaymentDemo', target: 'component', namePath: 'wep-api-v1.0', configFile: 'infra/*.json', dataFormat: 'json', autoCommit: 'false', autoValidate: 'false', changesetNumber: ”${changeset}” ) - Lors de l'appel final, en plus de référencer la variable de sortie changesetNumber du premier chargement en tant que variable d'entrée, définissez autoCommit et autoValidate sur vrai.Chargement du fichier INI :
snDevOpsConfigUpload( applicationName: 'PaymentDemo', target: 'component', namePath: 'wep-api-v1.0', configFile: 'featureToggles/set1.ini', dataFormat: 'ini', autoCommit: 'true', autoValidate: 'true', changesetNumber: ”${changeset}” )
- Lors du premier chargement, nommez l'action afin que la variable de sortie changesetNumber puisse être réutilisée lors des chargements suivants.
- Exemple : chargements multiples (collection et variables)
- Vous pouvez appeler l'action de chargement plusieurs fois pour charger des données de configuration dans différents formats de fichiers à partir de différents emplacements, tout en conservant la partie des chargements d'un ensemble de changements.
- Lors du premier chargement, créez une variable (par exemple, $changeset) et affectez-lui la valeur de retour de l'étape afin qu'elle puisse être réutilisée lors des chargements suivants.Chargement du fichier XML :
$changeset = snDevOpsConfigUpload( applicationName: 'PaymentDemo', target: 'collection', collectionName: 'release-v1.0', namePath: 'v1-common-configs', configFile: 'infra/v1/config.xml', dataFormat: 'xml', autoCommit: 'false', autoValidate: 'false' ) - Lors des chargements suivants, utilisez la variable comme entrée.Chargement du fichier JSON :
snDevOpsConfigUpload( applicationName: 'PaymentDemo', target: 'deployable', deployableName: 'Production', namePath: 'vars/dbSettings', configFile: 'infra/prod/dbConfig.json', dataFormat: 'json', autoCommit: 'true', autoValidate: 'true', changesetNumber: ”${changeset}” )
Remarque :Pour charger vers un dossier de variables, uploadTarget doit être défini sur élément déployable et les valeurs correctes doivent être définies pour deployableName et changesetNumber. - Lors du premier chargement, créez une variable (par exemple, $changeset) et affectez-lui la valeur de retour de l'étape afin qu'elle puisse être réutilisée lors des chargements suivants.
snDevOpsConfigGetSnapshots
Cette action est destinée à être utilisée dans différents scénarios :
- Récupérer tous les instantanés pour tous les éléments déployables impactés.
Lorsque les fichiers de configuration sont chargés dans un modèle de données d'application, le système crée des instantanés pour tous les éléments déployables jugés impactés par le chargement. En supposant que la validation du dernier appel de chargement est activée, l'étape suivante dans le flux de CI consiste à itérer dans la liste des instantanés et à s'assurer qu'ils ont tous réussi la validation.
- Récupérer un instantané spécifique.
À la suite du flux CD, un instantané spécifique est récupéré afin qu'il puisse être publié, puis exporté pour être consommé en aval (par exemple, pour mettre en service une infrastructure ou une application).
- Récupérer les derniers instantanés d'un élément déployable d'une application dans le cas où un chargement ne génère aucun instantané.
Un ensemble de données de configuration peut être déployé dans un environnement pour une combinaison application-déployable-ensemble de changements lorsqu'aucun changement de configuration n'est apporté.
- Afficher les résultats de validation de politique dans une exécution de pipeline.
Affichez les résultats de validation de politique sous forme de résultats de tests sur la page Résultats des tests de version Jenkins, y compris conformes avec exception, lors de l'obtention d'un instantané.
- Définitions d'entrées
applicationName Spécifie l'application vers laquelle charger ou exporter les données de configuration. deployableName (Facultatif) Spécifie l'élément déployable pour l'application sur lequel obtenir les dernières données d'instantané. changesetNumber (Facultatif) Spécifie l'ID d'ensemble de changements pour l'ensemble des changements de configuration qui intéressent l'utilisateur. isValidated (Facultatif) Spécifie s'il faut renvoyer uniquement les instantanés qui sont réussis ou réussis avec une exception (vrai/faux). La valeur par défaut est vrai. continueWithLatest (Facultatif) Spécifie s'il faut renvoyer le dernier instantané selon la combinaison applicatioName-deployableName-changesetNumber si aucun instantané n'est généré (vrai/faux). Par défaut, la valeur est faux. - Sortie
- En cas de réussite, un instantané ou un ensemble d'instantanés.
- En cas d'échec, un message d'échec d'API/back-end s'affiche.
- Exemple
- Instantané spécifique (spécifié) :
$snapshots = snDevOpsConfigGetSnapshots( applicationName: 'PaymentDemo', deployableName: 'Production', changesetNumber: 'Chset-16', isValidated: 'true', continueWithLatest: 'true' ) - Dernier instantané validé (renvoie le dernier instantané pour la combinaison d'application et d'élément déployable) :
$snapshots = snDevOpsConfigGetSnapshots( applicationName: 'PaymentDemo', deployableName: 'Production', isValidated: 'true' ) - Tous les instantanés de l'ensemble de changements (renvoie tous les instantanés pour la combinaison d'application et d'élément déployable) :
$snapshots = snDevOpsConfigGetSnapshots( applicationName: 'PaymentDemo', changesetNumber: 'Chset-16' ) - Afficher les résultats de validation de politique dans une exécution de pipeline.
- Affectez une variable au chemin d'accès au fichier qui contient les résultats de validation d'instantané générés pendant l'action snDevOpsConfigGetSnapshots.
- Appelez l'action JUnit pour charger les résultats de validation de l'instantané dans la section de test d'exécution du pipeline.
stage('Validate') { steps { script { changeSetResults = snDevOpsConfigGetSnapshots( … ) if (!changeSetResults) { echo "No snapshots were created" } else { def changeSetResultsObject = readJSON text: changeSetResults changeSetResultsObject.each { snapshotName = it.name snapshotObject = it } // STEP 1 validationResultsPath = "${snapshotName}_${currentBuild.projectName}_${currentBuild.number}.xml" } } } } post { always { // STEP 2 junit testResults: "${validationResultsPath}", skipPublishingChecks: true } }
- Instantané spécifique (spécifié) :
snDevOpsConfigPublish
Cette action publie un instantané pour l'application et l'élément déployable donnés. À partir de là, l'instantané peut être consommé via le processus d'exportation.
- Définitions d'entrées
applicationName Spécifie l'application à partir de laquelle publier les données de configuration. deployableName Spécifie l'élément déployable pour l'application à partir de laquelle publier les données de configuration. snapshotName Spécifie le nom de l'instantané à publier. - Sortie
- En cas de réussite, vrai.
- Sinon, faux.
- Exemple
snDevOpsConfigPublish( applicationName: 'PaymentDemo', deployableName: 'Production', snapshotName: 'Production-v23.dpl', )
snDevOpsConfigExport
Cette action exporte un instantané pour l'application et l'élément déployable.
L'utilisateur doit spécifier l'exportateur, les arguments pertinents de l'exportateur, le format d'exportation (par exemple, YAML, JSON...) et l'emplacement de sortie des données de configuration exportées.
À partir de là, les données de configuration peuvent être utilisées directement en tant qu'entrée pour un outil de déploiement ou de provisionnement en aval du pipeline.
- Arguments d'entrée
applicationName Spécifie l'application à partir de laquelle exporter les données. deployableName Spécifie l'élément déployable de la configuration pour l'application à partir de laquelle exporter des données. snapshotName (Facultatif) Spécifie l'instantané à partir duquel exporter des données.
Si aucun instantané n'est spécifié, le dernier instantané de l'élément déployable est utilisé.
exporterName Spécifie l'exportateur à appliquer à l'instantané (par exemple, UniqueCDI). exporterArgs (Facultatif) Spécifie les arguments à utiliser avec l'exportateur. exportFormat Spécifie le format d'exportation des données de l'instantané (par exemple, INI,YAML, PROPS). fileName Spécifie le fichier vers lequel exporter les données (en supposant qu'il se trouve dans l'espace de travail).
Si aucun nom de fichier n'est spécifié, une concaténation du nom de l'application et du nom de l'élément déployable (plus l'extension du fichier) est utilisée par défaut.
- Sortie
- En cas de réussite, vrai.
- Sinon, faux.
- Exemple
snDevOpsConfigExport( applicationName: 'PaymentDemo', deployableName: 'Production', snapshotName: 'Production-v23.dpl', exporterFormat: 'yaml', exporterName: 'returnAllData-now', exporterArgs: '', fileName: 'exported_file-Production-20220302.yml' )
snDevOpsConfigRegisterPipeline
Cette action lie un ensemble de changements et/ou un instantané au pipeline afin qu'il puisse être suivi pendant l'exécution du pipeline. Dans Vélocité de changement DevOps, cela s'affiche dans l'interface utilisateur du pipeline.
Pour plus d'informations sur la fonctionnalité Accélération des changements DevOps, consultez Accélérer votre processus de changement DevOps.
- Arguments d'entrée
applicationName Spécifie le nom de l'application. changesetNumber (Facultatif) Spécifie l'ensemble de changements à associer à l'exécution du pipeline.
Remarque :Spécifiez changesetNumber ou snapshotName, mais pas les deux.snapshotName (Facultatif) Spécifie le nom de l'instantané à associer à l'exécution du pipeline.
Remarque :Spécifiez changesetNumber ou snapshotName, mais pas les deux.- Sortie
- En cas de réussite, vrai.
- Sinon, faux.
- Exemple
- Entrée :
Voici un exemple de l'action snDevOpsConfigRegisterPipeline. À des fins d'illustration, nous allons affecter la réponse à une variable, changeSetRegResult, qui pourrait être répercutée dans notre journal de console pour les scénarios de débogage.
changeSetRegResult = snDevOpsConfigRegisterPipeline( applicationName: "PaymentDemo", changesetNumber: "Chset-122" ) echo "Pipeline registration result: ${changeSetRegResult}" - Sortie :
En plus des données chargées dans notre modèle de données dans DevOps Config, la sortie ressemblerait à ceci (en utilisant le module d'extension Blue Ocean pour visualiser la sortie de la console).
- Entrée :
snDevOpsConfigValidate
Valider les données de configuration par rapport aux politiques de votre organisation.
- Arguments d'entrée
applicationName Application à valider. deployableName Élément déployable pour l'application à valider. snapshotName (Facultatif) Nom de l'instantané à valider. markFailed (Facultatif) Fait échouer le pipeline en cas d'échec de la tentative de validation (en raison d'un problème back-end). showResults (Facultatif) Affichez les résultats de validation dans le journal de la console Jenkins. - Sortie
- En cas de réussite, pas de sortie.
- En cas d'échec, un message d'échec d'API/back-end s'affiche.
- Exemple
- Instantané spécifique (spécifié) :
snDevOpsConfigValidate( applicationName: 'PaymentDemo', deployableName: 'Production', snapshotName: 'Production-v23.dpl', ) - Dernier instantané (récupère et valide le dernier instantané pour la combinaison d'application et d'élément déployable) :
$changeset = snDevOpsConfigValidate( applicationName: 'PaymentDemo', deployableName: 'Production' )
- Instantané spécifique (spécifié) :
snDevOpsChange
Créez une demande de changement et joignez un instantané pour référence.
Pour plus d'informations sur la fonctionnalité Accélération des changements DevOps, consultez Accélérer votre processus de changement DevOps.
- Arguments d'entrée
applicationName Spécifie le nom de l'application. snapshotName Spécifie le nom de l'instantané à associer à la demande de changement. - Exemple
snDevOpsChange( applicationName: 'PaymentDemo', snapshotName: 'Production-v23.dpl' )
Exemple de pipeline Jenkins
pipeline {
environment {
buildArtifactsPath = "build_artifacts/${currentBuild.number}"
validationResultsPath = ""
}
agent any
stages {
// Initialize pipeline
stage('Initialize') {
steps {
script {
// DevOps Config application related information
appName = 'PaymentDemo'
deployableName = 'Production'
componentName = "web-api-v1.0"
collectionName = "release-1.0"
// Configuration file information
exportFormat = 'yaml'
configFilePath = "k8s/helm/values.yml"
// Exporter related information
exporterName = 'returnAllData-nowPreview'
exporterArgs = ''
// Jenkins variables declared to be used in pipeline
exportFileName = "${buildArtifactsPath}/export_file-${appName}-${deployableName}-${currentBuild.number}.${exportFormat}"
changeSetId = ""
snapshotName = ""
snapshotObject = ""
isSnapshotValidateionRequired = false
isSnapshotPublisingRequired = false
}
}
}
// Validate configuration data changes
stage('Validate') {
parallel {
stage('Config') {
stages('Config Steps') {
// Upload configuration data to DevOps Config
stage('Upload, Validate, & Publish') {
steps {
sh "echo uploading and auto-validating configuration file: ${configFilePath}"
script {
changeSetResults = snDevOpsConfig(
applicationName: "${appName}",
target: 'component',
namePath: "${componentName}",
configFile: "${configFilePath}",
dataFormat: "${configFileFormat}",
autoCommit: 'true',
autoValidate: 'true',
autoPublish: 'true',
isValidated: 'true',
continueWithLatest: 'true',
markFailed: 'true'
)
echo "Snapshots generated, validated, and published: ${changeSetResults}"
def changeSetResultsObject = readJSON text: changeSetResults
changeSetResultsObject.each {
snapshotName = it.name
snapshotObject = it
}
validationResultsPath = "${snapshotName}_${currentBuild.projectName}_${currentBuild.number}*.xml"
}
}
}
// Export published snapshot to be used by downstream deployment tools
stage('Export') {
steps {
script {
// create build artifacts dir to store export file
sh "mkdir -p ${buildArtifactsPath}"
exportResponse = snDevOpsConfigExport(
applicationName: "${appName}",
snapshotName: "${snapshotObject.name}",
deployableName: "${deployableName}",
exporterFormat: "${exportFormat}",
fileName: "${exportFileName}",
exporterName: "${exporterName}",
exporterArgs: "${exporterArgs}"
)
}
}
}
}
}
}
}
// Create change request and attach snapshot for reference
stage('Change Management') {
steps {
script {
// Trigger change request
snDevOpsChange(
applicationName: "${appName}",
snapshotName: "${snapshotName}"
)
}
}
}
}
// NOTE: attach snapshot validation results to run (if the snapshot fails validation)
post {
always {
// attach policy validation results
junit testResults: "${validationResultsPath}", skipPublishingChecks: true
}
}
}