Azure DevOps Tâches de pipeline

  • Rversion finale: Xanadu
  • Mis à jour 1 août 2024
  • 13 minutes de lecture
  • Utilisez ces tâches dans votre Azure DevOps pipeline pour interagir avec le DevOps Config modèle de données.

    Important :
    À partir de la version Washington DC, DevOps Config ne sera plus disponible. L'application sera masquée et ne sera plus installée sur les nouvelles instances, mais continuera d'être prise en charge. Pour en savoir plus, consultez l'article Processus de retrait [KB0867184] dans la base de connaissances Now Support.

    Ces tâches sont fournies pour créer une définition de pipeline spécifique afin d’atteindre votre objectif.

    • ServiceNow-DevOps-Config-Agent-Upload-Config

      Chargez les données de configuration dans un déployable dans le modèle de données via Tâche d’agent.

    • ServiceNow-DevOps-Config-Agent-Get-Snapshot

      Obtenir les instantanés d’une application.

    • ServiceNow-DevOps-Config-Agent-Get-Snapshot-Name

      Extrayez le nom d’un instantané.

    • ServiceNow-DevOps-Config-Agent-Publish-Snapshot

      Publiez un instantané de vos données de configuration.

    • ServiceNow-DevOps-Config-Agent-Export-Snapshot

      Exportez un sous-ensemble de vos données de configuration.

    • ServiceNow-DevOps-Config-Agent-Register-Pipeline

      Enregistrer un ensemble de changements et/ou un instantané pour une exécution de pipeline.

    • ServiceNow-DevOps-Config-Agent-Validate-Snapshot

      Validez les données de configuration par rapport aux politiques de l’organisation.

    • ServiceNow-DevOps-Server-Change-Acceleration

      Créez une demande de changement dans le cadre du pipeline.

    ServiceNow-DevOps-Config-Agent-Upload-Config

    Tâche de chargement d’un fichier de configuration à un emplacement donné dans un modèle de données d’application.

    Cette tâche est destinée à être utilisée de manière itérative pour tous les fichiers de configuration que l’utilisateur choisit de charger dans son modèle de données d’application pendant l’exécution du pipeline.
    Remarque :
    Les fichiers préchargés doivent être dans un format compatible.
    Variables d'entrée
    connectedServiceName Spécifie la connexion du point de terminaison du DevOps pipeline.
    applicationName Spécifie l’application dans laquelle les données de configuration sont téléchargées.
    deployableName Spécifie le déployable pour l’application (requis si la cible est déployable).
    uploadTarget (en anglais seulement) Spécifie la cible du modèle de données vers laquelle les données de configuration sont téléchargées (par exemple, composant, collection, déployable).
    collectionName (Facultatif) Spécifie la collection vers laquelle les données de configuration seront téléchargées (requis si la cible est une collecte).
    namePath

    Spécifie le chemin d’accès du modèle de données vers lequel les données de configuration sont téléchargées.

    Remarque :
    Lors du chargement vers un dossier vars, vous devez commencer le chemin du nom par « vars/ » pour spécifier le chemin d’accès du dossier variable.
    configFilePath

    Spécifie le dossier source à partir duquel les données de configuration sont téléchargées vers le chemin d’accès du composant ou de l’élément déployable dans le modèle de données.

    Vide est la racine du référentiel. Utilisez des variables si les fichiers ne sont pas dans le référentiel (par exemple, $(agent.builddirectory)).

    convertPath (en anglais seulement) (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. La valeur par défaut est false.
    dataFormat (Format de données) Spécifie le format de données du config_file (par exemple, JSON,YAML,XML...).
    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.
    Validation automatique Spécifie si les données de configuration doivent être validées après le chargement (vrai/faux). La valeur par défaut est false.
    Valider automatiquement Indique s’il faut valider les données de configuration pendant la validation (vrai/faux). La valeur par défaut est vrai.
    Variable de sortie
    changesetNumber

    Enregistrement de l’ensemble de changements créé/validé pendant le chargement.

    Attribuez un nom à la tâche afin qu’elle puisse être utilisée ultérieurement dans le pipeline (par exemple, componentUpload).

    Exemple : configuration du chargement
    
    -task: ServiceNow-DevOps-Config-Agent-Upload-Config
     name: componentUpload​
     inputs:​
       connectedServiceName: 'MyServiceNowInstance'​
       applicationName: 'PaymentDemo'​
       uploadTarget: 'component'​
       namePath: 'wep-api-v1.0'
       configFilePath: 'k8s/helm/values.yml'​
       dataFormat: 'yaml'
       autoCommit: true​
       autoValidate: true​
     
    Exemple : chargements multiples (composant)
    Vous pouvez appeler la tâche de chargement plusieurs fois pour charger des données de configuration dans différents formats de fichier à partir de différents emplacements, tout en conservant la partie des téléchargements d’un seul ensemble de changements.
    • Lors du premier chargement, nommez la tâche afin que la variable de sortie changesetNumber puisse être réutilisée lors des chargements suivants.
      Chargement du fichier YAML :
      
      -task: ServiceNow-DevOps-Config-Agent-Upload-Config​
         name: componentUpload​
         inputs:​ 
           connectedServiceName: 'MyServiceNowInstance'​
           applicationName: 'PaymentDemo'​
           uploadTarget: 'component'​
           namePath: 'wep-api-v1.0'
           configFilePath: '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 du fichier JSON :
      
      -task: ServiceNow-DevOps-Config-Agent-Upload-Config
         inputs:​
           connectedServiceName: 'MyServiceNowInstance'
           applicationName: 'PaymentDemo'
           uploadTarget: 'component'
           namePath: 'wep-api-v1.0'
           configFilePath: 'featureToggles/set1.json'
           dataFormat: 'json'
           autoCommit: true​
           autoValidate: true​
           changesetNumber: '$(componentUpload.changesetNumber)'
    Exemple : chargements multiples (collection et variables)
    Vous pouvez appeler la tâche de chargement plusieurs fois pour charger des données de configuration dans différents formats de fichier à partir de différents emplacements, tout en conservant la partie des téléchargements d’un seul ensemble de changements.
    • Lors du premier chargement, assurez-vous de nommer la tâche afin que la variable de sortie changesetNumber puisse être réutilisée lors des chargements suivants.
      Chargement du fichier XML :
      
      -task: ServiceNow-DevOps-Config-Agent-Upload-Config​
         name: componentUpload​
         inputs:​ 
           connectedServiceName: 'MyServiceNowInstance'​
           applicationName: 'PaymentDemo'​
           uploadTarget: 'collection'​
           collectionName: 'release-1.0'​
           namePath: 'v1-common-configs'
           configFilePath: 'infra/v1/config.xml'​
           dataFormat: 'xml'
           autoCommit: false​
           autoValidate: false​
    • Dans les chargements suivants, référencez la variable de sortie changesetNumber du premier chargement en tant qu’entrée.
      Chargement du fichier JSON :
      
      -task: ServiceNow-DevOps-Config-Agent-Upload-Config
         inputs:​
           connectedServiceName: 'MyServiceNowInstance'
           applicationName: 'PaymentDemo'
           uploadTarget: 'deployable'
           deployableName: 'Production-EMEA'
           namePath: 'vars/dbSettings'
           configFilePath: 'infra/prodc/dbSettings.json'
           dataFormat: 'json'
           autoCommit: true​
           autoValidate: true​
           changesetNumber: '$(componentUpload.changesetNumber)'
    Remarque :
    Pour charger vers un dossier de variables, uploadTarget doit être défini sur déployable et les valeurs correctes doivent être définies pour deployableName et changesetNumber.

    ServiceNow-DevOps-Config-Agent-Get-Snapshot

    Cette tâche est destinée à être utilisée dans différents scénarios :
    • 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 le dernier instantané validé.

      Le dernier instantané validé est récupéré pour la combinaison application-déployable donnée.

    • Récupérez tous les instantanés pour tous les éléments déployables impactés.

      Lorsque les fichiers de configuration sont téléchargés dans un modèle de données d’application, le système crée des instantanés pour tous les déployables jugés impactés par le chargement. En suivant le flux de CI, en supposant que la validation du dernier appel de chargement est activée, l’étape suivante consiste à itérer dans la liste des instantanés et à s’assurer qu’ils ont tous réussi la validation.

    • Récupérez les derniers instantanés d’un 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é.

    • Affichez 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 de résultats des tests de version ADO, y compris conformes avec exception, lors de l’obtention d’un instantané.

    Variables d'entrée
    connectedServiceName Spécifie la connexion du DevOps point de terminaison du pipeline (définie dans les paramètres de connexion de service du projet).
    applicationName Spécifie l’application vers laquelle charger les données de configuration ou exporter les données.
    deployableName (Facultatif) Spécifie l’élément déployable (par l’application spécifiée) sur lequel obtenir les dernières données d’instantané.
    changesetNumber (Facultatif) Spécifie l’ID d’ensemble de changements pour l’ensemble applicable de changements de configuration.
    isValidated (en anglais seulement) (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) Indique s’il faut renvoyer le dernier instantané selon la combinaison applicationName-deployableName-changesetNumber si aucun instantané n’est généré (vrai/faux). La valeur par défaut est false.
    Variable de sortie
    objet instantané

    Objet JSON contenant les instantanés demandés.

    Attribuez un nom à la tâche afin qu’elle puisse être utilisée ultérieurement dans le pipeline (par exemple, getSnapshot).

    Exemple : instantané spécifique
    
    -task: ServiceNow-DevOps-Config-Agent-Get-Snapshot
     name: getSnapshot
     inputs:
       connectedServiceName: 'MyServiceNowInstance'
       applicationName: 'PaymentDemo'
       deployableName: 'Production'
       changesetNumber: 'Chset-16'
       isValidated: true
       continueWithLatest: true
    
    Exemple : derniers instantanés validés (pour une combinaison application-déployable donnée)
    
    -task: ServiceNow-DevOps-Config-Agent-Get-Snapshot
     name: getSnapshot
     inputs:
       connectedServiceName: 'MyServiceNowInstance'
       applicationName: 'PaymentDemo'
       deployableName: 'Production'
       isValidated: true
    
    Exemple : tous les instantanés de l’ensemble de changements
    
    -task: ServiceNow-DevOps-Config-Agent-Get-Snapshot
     name: getSnapshot
     inputs:
       connectedServiceName: 'MyServiceNowInstance'
       applicationName: 'PaymentDemo'
       changesetNumber: 'Chset-16'
    
    Exemple : afficher les résultats de validation de la politique

    Affectez une variable au chemin d’accès au fichier qui contient les résultats de validation d’instantané générés pendant la tâche ServiceNow-DevOps-Config-Agent-Get-Snapshot .

    Pour charger les résultats de validation de l’instantané dans l’exécution de votre pipeline, vous devez exploiter la tâche Publier les résultats des tests v2 native ADO, en utilisant la variable comme entrée.

    
    stages:
    - stage: Two
      jobs:
        - job: A
    	variables:
          - name: validationResultsPath
            value: 1/TEST_DATA_$(Build.DefinitionName)_$(Build.BuildNumber)_*.xml
          steps:
            - task: PublishTestResults@2
              inputs:
                 testResultsFormat: 'JUnit'
                 testResultsFiles: '$(validationResultsPath)'
                 searchFolder: '$(System.WorkFolder)'
    

    ServiceNow-DevOps-Config-Agent-Get-Snapshot-Name

    Cette tâche est utilisée en tant que suivi de la tâche ServiceNow-DevOps-Config-Agent-Get-Snapshot-Name pour obtenir le nom de l’instantané à partir d’un instantané particulier. À partir de là, le nom de l’instantané peut être utilisé comme entrée dans une tâche en aval, comme la publication de l’instantané.

    Variables d'entrée
    deployableName Spécifie l’élément déployable pour obtenir l’objet d’instantané renvoyé par la tâche ServiceNow-DevOps-Config-Agent-Get-Snapshot .
    script Spécifie le script permettant d’extraire le nom de l’instantané de l’objet de l’instantané.
    Variable de sortie
    snapshotName

    Nom de l’instantané pour le déployable.

    Attribuez un nom à la tâche afin qu’elle puisse être utilisée ultérieurement dans le pipeline (par exemple, getSnapshotName).

    Exemple : obtenir le nom de l’instantané

    Utilisez ce script pour extraire le nom de l’instantané récupéré de la tâche ServiceNow-DevOps-Config-Agent-Get-Snapshot .

    
    -task: ServiceNow-DevOps-Config-Agent-Get-Snapshot-Name
     inputs:
       deployableName: 'PRD'
       script: |
    	function run() {
            let name;
            let deployableName = process.argv[2];
            let jsonObj = $(getSnapshot.snapshotObjects);
            let size = jsonObj.result.length;
            for(let i=0; i<size; i++) {
             obj = jsonObj.result[i];
             if(obj[“deployable_id.name”].toLowerCase() == deployableName) {
               name = obj.name;
               console.log(name);
              }
             }
            }
            run();
    
    Exemple : obtenir le nom de l’instantané utilisé avec obtenir un instantané

    Appelez la tâche ServiceNow-DevOps-Config-Agent-Get-Snapshot-Name juste après la tâche ServiceNow-DevOps-Config-Agent-Get-Snapshot pour renvoyer le nom de l’instantané.

    Obtenir les instantanés (renvoie un objet JSON contenant les instantanés impactés) :
    
    -stage: Two​
     jobs:​
        -job: B​
         steps:​
            -task: ServiceNow-DevOps-Config-Agent-Get-Snapshot
             name: getSnapshot​
             inputs:​
                connectedServiceName: 'MyServiceNowInstance'​​
                applicationName: 'PaymentDemo'​
                deployableName: 'Production-2'
                changesetNumber: 'Chset-16'​
    Obtenir le nom de l’instantané (renvoie le nom de l’instantané pour un déployable spécifique) :
    
    -stage: Two​
     jobs:​
        - job: B​
          steps:​
            - task: ServiceNow-DevOps-Config-Agent-Get-Snapshot
              name: getSnapshotName​
              inputs:​
                  deployableName: 'Production-2'
                  script:|​
                  function run() {​
                   let name;​
                   let deployableName = process.argv[2]; ​
                   let jsonObj = $(getSnapshot.snapshotObjects);​
                   let size = jsonObj.result.length;​
                   for(let i=0; i<size ;i++) {​
                    obj = jsonObj.result[i];​
                    if(obj["deployable_id.name"].toLowerCase() == deployableName) {​
                     name = obj.name;​
                     console.log(name); // This standard output of inline script is given as the task output​
                    }​
                   }​
                  }​
                  run();
    
    Utilisez le nom de l’instantané retourné dans le pipeline (par exemple, publier) :
    
    -stage: Three​
     jobs:​
        -job: C​
         variables:​
           varSnapshotName: $[stageDependencies.Two.B.outputs['getSnapshotName.snapshotName']]​
         steps:​
            -task: ServiceNow-DevOps-Config-Agent-Publish-Snapshot
             inputs:​
               connectedServiceName: 'MyServiceNowInstance'
               applicationName: 'PaymentDemo'
               deployableName: 'Production-2'
               snapshotName: '$(varSnapshotName)'​

    ServiceNow-DevOps-Config-Agent-Publish-Snapshot

    Cette tâche 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.

    Variables d'entrée
    connectedServiceName Spécifie la connexion du ServiceNow point de terminaison.
    applicationName Spécifie l’application à publier.
    deployableName Spécifie l’élément déployable pour que l’application publie les données de configuration.
    snapshotName Spécifie le nom de l’instantané à publier.
    Variable de sortie
    Non applicable (renvoie vrai en cas de réussite, sinon faux).
    Exemple
    
    -task: ServiceNow-DevOps-Config-Agent-Publish-Snapshot
     inputs:
       connectedServiceName: 'MyServiceNowInstance'
       applicationName: 'PaymentDemo'
       deployableName: 'Production-2'
       snapshotName: 'Production-v23.dpl'
    

    ServiceNow-DevOps-Config-Agent-Export-Snapshot

    Cette tâche exporte un instantané pour l’application et l’élément déployable donnés. Spécifiez 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.

    Variables d'entrée
    connectedServiceName Spécifie la connexion du ServiceNow point de terminaison.
    applicationName Spécifie l’application à partir de laquelle effectuer la publication.
    deployableName Spécifie le déployable pour l’application à partir de laquelle exporter les données de configuration.
    snapshotName Spécifie le nom de l’instantané à partir duquel exporter les données de configuration.
    nom de l’exportateur Spécifie l’exportateur à appliquer à l’instantané (par exemple, UniqueCDI).
    args (Facultatif) Spécifie les arguments à utiliser avec l’exportateur.
    format d’exportation Spécifie le format d’exportation des données de l’instantané (par exemple, INI,YAML, PROPS).
    saveFile (en anglais seulement)

    Vérifie si le fichier doit être enregistré dans un référentiel Azure (vrai/faux). La valeur par défaut est false.

    Remarque :
    Autorisation/jeton OAuth approprié, l’accès au script est requis.

    Sinon, le fichier d’exportation est créé dans le répertoire de l’espace de travail du pipeline.

    Variable de sortie
    Non applicable (renvoie vrai en cas de réussite, sinon faux).
    Exemple
    
    -task: ServiceNow-DevOps-Config-Agent-Export-Snapshot
     inputs:
       connectedServiceName: 'MyServiceNowInstance'
       applicationName: 'PaymentDemo'
       deployableName: 'Production-2'
       exporterName: 'returnAllData-nowPreview'
       dataFormat: 'yaml'
       args: ''
       snapshotName: 'Production-v23.dpl'
       saveFile: true​
       fileName: 'ExporterOutput/ExportData_$(build.definitionName)_$(build.buildNumber).yaml'
       

    ServiceNow-DevOps-Config-Agent-Register-Pipeline

    Cette tâche lie un ensemble de changements et un instantané au pipeline afin qu’il puisse être suivi pendant l’exécution du pipeline. Dans Changements de vélocité DevOps, cela s’affiche dans l’interface utilisateur du pipeline.

    Variables d'entrée
    connectedServiceName Spécifie la connexion du point de terminaison du DevOps pipeline.
    applicationName Spécifie le nom de l’application.
    changesetNumber (Facultatif) Spécifie l’ID de l’ensemble de changements à associer à l’exécution du pipeline.
    snapshotName (Facultatif) Spécifie le nom de l’instantané à associer à l’exécution de pipeline.
    Variable de sortie
    Non applicable (renvoie vrai en cas de réussite, sinon faux).
    Exemple
    
    -task: ServiceNow-DevOps-Config-Agent-Publish-Snapshot
     inputs:
       connectedServiceName: 'MyServiceNowInstance'
       changesetNumber: 'Changeset-143'
    

    ServiceNow-DevOps-Config-Agent-Validate-Snapshot

    Validez les données de configuration par rapport aux politiques de votre organisation.
    Variables d'entrée
    connectedServiceName Spécifie la connexion du ServiceNow point de terminaison.
    applicationName Spécifie l’application à valider.
    deployableName Spécifie l’élément déployable (par application spécifiée) à valider.
    snapshotName (Facultatif) Spécifie le nom de l’instantané à valider.
    showResults (en anglais seulement) (Facultatif) Spécifie d’afficher les résultats de validation dans le journal de la console.
    Variable de sortie
    Non applicable (renvoie vrai en cas de réussite, sinon faux).
    Exemple
    
    -task: ServiceNow-DevOps-Config-Agent-Validate-Snapshot
     inputs:
       connectedServiceName: 'MyServiceNowInstance'
       applicationName: 'PaymentDemo'
       deployableName: 'Production-2'
       snapshotName: ''
       showResults: false
    

    ServiceNow-DevOps-Server-Change-Acceleration

    Cette tâche est requise pour que les tâches sans agent (serveur) créent automatiquement une demande de changement dans ServiceNow Gestion des changements le Azure DevOps cadre du pipeline.

    Dans DevOps Config, pour associer plusieurs instantanés du même ensemble de changements à une demande de changement, utilisez le nom de l’instantané et le nom de l’application pour suivre des données de configuration spécifiques pour un service d’application donné.

    Pour en savoir plus sur la fonctionnalité Accélération des changements, reportez-vous Accélérer votre DevOps processus de changement à la DevOps section .

    Variables d’entrée (associées à DevOps Config)
    connectedServiceName Spécifie la connexion du point de terminaison du DevOps pipeline.
    applicationName Application associée à l’instantané joint à la demande de changement.
    snapshotName Nom de l’instantané à joindre à la demande de changement.
    Exemple
    
    -stage: ChangeRequest
     jobs:
        -job: 'changerequestjob'
         pool: server
         steps:
            -task: ServiceNow-DevOps-Server-Change-Acceleration
             inputs:
                connectedServiceName: 'MyServiceNowInstance'
                applicationName: 'PaymentDemo'
                snapshotName: 'Production-v23.dpl'
    

    Exemple de pipeline YAML

    trigger:
      branches:
        include:
        - none
    stages:
    - stage: One
      displayName: Upload Configuration Data
      pool:
        vmImage: ubuntu-latest
      jobs:
      - job: A
        displayName: Upload
        steps:
        - task: ServiceNow-DevOps-Config-Agent-Upload-Config@1
          name: componentUpload
          inputs:
            connectedServiceName: 'MyServiceNowInstance'
            applicationName: 'PaymentDemo'
            uploadTarget: 'component'
            configFile: 'k8s/helm/values.yml'
            namePath: 'processor-api-v1.0'
            dataFormat: 'yaml'
            autoValidate: true
            autoCommit: true
            convertPath: true
    - stage: Two
      displayName: Get Latest Snapshot
      pool:
        vmImage: ubuntu-latest
      jobs:
      - job: B
        displayName: Get Snapshot
        variables:
        - name: varChangesetNumber
          value: $[stageDependencies.One.A.outputs['componentUpload.changesetNumber'] ]
        - name: varConfigValidationResults
            value: 1/TEST_DATA_$(Build.DefinitionName)_$(Build.BuildNumber)_*.xml
        steps:
        - task: ServiceNow-DevOps-Config-Agent-Get-Snapshot@1
          name: getSnapshot
          inputs:
            connectedServiceName: 'MyServiceNowInstance'
            applicationName: 'PaymentDemo'
            deployableName: 'Production-EMEA'
            changeSetNumber: '$(varChangesetNumber)'
            continueWithLatest: true
        - task: ServiceNow-DevOps-Config-Agent-Get-Snapshot-Name@1
          name: getSnapshotName
          inputs:
            deployableName: 'Production-EMEA'
            script: "function run() {\n  let name;\n  let deployableName = process.argv[2]; \n  let jsonObj = $(getSnapshot.snapshotObjects);\n  let size = jsonObj.result.length;\n  for(let i=0; i<size ;i++) {\n    obj = jsonObj.result[i];\n    if(obj[\"deployable_id.name\"].toLowerCase() == deployableName) {\n      name = obj.name;\n      console.log(name);   // This standard output of inline script is given as the task output\n    }\n  }\n}\nrun();\n"
        - task: PublishTestResults@2
              inputs:
                 testResultsFormat: ‘JUnit’
                 testResultsFiles: ‘$(varConfigValidationResults)’
                 searchFolder: ‘$(System.WorkFolder)’
        - task: ServiceNow-DevOps-Config-Agent-Register-Pipeline@1
          inputs:
            connectedServiceName: 'MyServiceNowInstance'
            snapshotName: '$(getSnapshotName.snapshotName)'
            applicationName: 'PaymentDemo'
    - stage: Three
      displayName: Publish Snapshot
      pool:
        vmImage: ubuntu-latest
      jobs:
      - job: C
        displayName: Publish
        variables:
        - name: varSnapshotName
          value: $[stageDependencies.Two.B.outputs['getSnapshotName.snapshotName']]
        steps:
        - task: ServiceNow-DevOps-Config-Agent-Publish-Snapshot@1
          inputs:
            connectedServiceName: 'MyServiceNowInstance'
            applicationName: 'PaymentDemo'
            deployableName: 'Production-EMEA'
            snapshotName: '$(varSnapshotName)'
    - stage: ChangeRequest
      dependsOn:
      - Two
      - Three
      jobs:
      - job: 'changerequestjob'
        timeoutInMinutes: 2
        pool:
          name: server
        variables:
        - name: varSnapshotName
          value: $[stageDependencies.Two.B.outputs['getSnapshotName.snapshotName']]
        steps:
        - task: ServiceNow-DevOps-Server-Change-Acceleration@1
          inputs:
            connectedServiceName: 'MyServiceNowInstance'
            applicationName: 'PaymentDemo'
            snapshotName: '$(varSnapshotName)'
    - stage: Four
      displayName: Export Snapshot
      dependsOn:
      - Two
      - Three
      - ChangeRequest
      pool:
        vmImage: ubuntu-latest
      variables:
      - name: varSnapshotName
        value: $[stageDependencies.Two.B.outputs['getSnapshotName.snapshotName']]
      jobs:
      - job: D
        displayName: Export
        steps:
        - task: ServiceNow-DevOps-Config-Agent-Export-Snapshot@1
          inputs:
            connectedServiceName: 'MyServiceNowInstance'
            applicationName: 'PaymentDemo'
            deployableName: 'Production-EMEA'
            exporterName: 'returnAllData-now'
            dataFormat: 'yaml'
            snapshotName: '$(varSnapshotName)'
            saveFile: true
            fileName: 'ExportData_$(build.definitionName)_$(build.buildNumber).yaml'
        - task: CmdLine@2
          inputs:
            script: |
              echo Write your commands here
              echo Hello world
              tree $(Pipeline.Workspace)