Jenkins ações do pipeline

  • Versão de lançamento: Yokohama
  • Atualizado 30 de jan. de 2025
  • 15 min. de leitura
  • Use essas ações em Jenkinspipeline para interagir com Configuração de DevOpsmodelo de dados.

    Importante:
    A partir da versão Washington DC, o Configuração de DevOps está sendo preparado para descontinuação futura. Ele ficará oculto e não será mais instalado em novas instâncias, mas continuará sendo compatível. Para obter detalhes, consulte o artigo Deprecation Process (Processo de descontinuação) [KB0867184] na Base de conhecimento do Now Support.

    Jenkins piplines declarativas e com script são compatíveis.

    Essas ações são fornecidas para criar uma definição de pipeline específica para atingir seu objetivo. Adicione um comando ao seu Jenkinsarquivo para executar essas ações.
    • SnDevOpsConfig

      Ação combinada para carregar, validar e publicar dados de configuração.

    • SnDevOpsConfigUpload

      Carregar dados de configuração para Configuração de DevOpsPor trabalho do agente.

    • SnDevOpsConfigGetSnapshots

      Recupere snapshots de um implantável específico ou de todos os implantáveis afetados.

    • SnDevOpsConfigPublish

      Publique um snapshot para a aplicação fornecida e implantável.

    • SnDevOpsConfigExport

      Exporte um snapshot para uma determinada aplicação e implantável.

    • SnDevOpsConfigRegisterPipeline

      Vincule um changeset e/ou snapshot a uma execução de pipeline.

    • SnDevOpsConfigValidate

      Valide os dados de configuração em relação às políticas da sua organização.

    • SnDevOpsChange

      Crie uma solicitação de mudança com o snapshot associado anexado.

    SnDevOpsConfig

    Carregue, valide e publique mudanças de dados de configuração em uma etapa.

    Esta ação combina ações snDevOpsConfigUpload, snDevOpsConfigGetSnapshots e snDevOpsConfigRegisterPipeline em uma ação, em vez de precisar executar cada ação separadamente.

    Variáveis de entrada
    ConfigFile Especifica o arquivo de dados de configuração a ser carregado no componente ou no caminho implantável no modelo de dados.
    applicationName Especifica a aplicação para onde os dados de configuração serão carregados.
    target Especifica o destino do modelo de dados para onde os dados de configuração serão carregados (por exemplo, componente , coleção , implantável ).
    CollectionName (Opcional) Nome da coleção para carregar (obrigatório se o destino for coleção).
    NomeDeployableName (Opcional) Nome do implantável para o qual carregar (obrigatório se o destino for implantável).
    namePath

    Especifica o caminho do nome no modelo de dados para onde os dados de configuração serão carregados.

    Nota:
    Ao carregar para uma pasta vars, você deve iniciar o caminho do nome com "vars/" para especificar o caminho da pasta variável.
    DataFormat Especifica o formato de dados do arquivo de configuração (por exemplo, JSON , AML , XML , etc.)
    AutoCOMMIT Especifica se os dados de configuração devem ser confirmados após o carregamento (verdadeiro/falso). O padrão é verdadeiro.
    AutoValidar Especifica se os dados de configuração devem ser validados durante a confirmação (verdadeiro/falso). O padrão é verdadeiro.
    Publicação automática Especifica se os dados de configuração devem ser publicados após a validação (verdadeiro/falso). O padrão é verdadeiro.
    changesetNumber

    (Opcional) Especifica o changeset (aberto) ao qual esta atividade de carregamento está associada. Se não for fornecido, um novo changeset será criado.

    Nota:
    Usado somente para vários cenários de upload.
    MarkFailed (Opcional) Falha no pipeline caso a tentativa de validação falhe (devido a um problema de back-end).
    MostrarResultados (Opcional) Mostre os resultados de validação no Jenkinslog do console de trabalho.
    ContinuoWithLatest (Opcional) Especifica se o snapshot mais recente deve ser retornado de acordo com Nome da aplicação - NomeDeployableName - ChangesetNumber combinação se nenhum snapshot for gerado (verdadeiro/falso). O padrão é falso.
    Saída
    • Se for bem-sucedido, um snapshot ou conjunto de snapshots.
    • Em caso de falha, uma mensagem de falha de API/back-end será mostrada.
    Exemplo
    • Entrada:
      
      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}"
    • Saída Saída de resposta snDevOpsConfig do Jenkins
    Exemplo - coleção
    Nota:
    Ao carregar para uma coleção, o. CollectionName o argumento é obrigatório.
    
    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'
    )
    Exemplo - implantável
    Nota:
    Ao carregar para um implantável, o. NomeDeployableName o argumento é obrigatório.
    
    snDevOpsConfig(
         applicationName: 'PaymentDemo',
         target: 'deployable',
         deployableName: 'Production',
         namePath: 'web-api-v1.0',
         configFile: 'k8s/helm/*.yml',
         dataFormat: 'yaml',
         autoCommit: 'true',
         autoValidate: 'true',
         autoPublish: 'true'
    )
    Vários uploads em uma confirmação

    Para carregar dados de configuração de diferentes locais ou carregar um conjunto de dados para vários destinos (por exemplo, um componente, um implantável) rastreados como uma confirmação única para seu modelo de dados, você pode chamar SnDevOpsConfigUpload quantas vezes forem necessárias para o primeiro conjunto de uploads e, em seguida, chame o. SnDevOpsConfig ação para o carregamento final. ​

    Aqui está um exemplo.

    • No primeiro carregamento, crie uma variável (por exemplo, changeset) e atribua o valor de retorno da etapa a ela para que ela possa ser reutilizada nos carregamentos subsequentes​.

      Carregar 1 - arquivo XML no componente:
      
      $changeset = snDevOpsConfigUpload(
           applicationName: 'PaymentDemo',
           target: 'component',
           namePath: 'paymentService-v1.0',
           configFile: 'infra/v1/config.xml',
           dataFormat: 'xml',
           autoCommit: 'false',
           autoValidate: 'false',
           autoPublish: 'false'
      )
    • Em carregamentos subsequentes (e carregamento final), use a variável como uma entrada​.

      Carregar 2 - arquivo json para a pasta vars do implantável:
      
      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'
      )
    Carregue vários formatos de dados
    Para carregar dados de configuração em diferentes formatos de arquivo, você pode chamar o. SnDevOpsConfig ação com estas especificações.
    • Certifique-se de ConfigFile o argumento está usando um curinga no caminho.
    • Não especifique o. DataFormat argumento.

    Aqui está um exemplo.

    • Digamos que tenhamos esses arquivos de configuração.

      Arquivos de upload do Jenkins de configuração DevOps

    • É assim que carregar os arquivos de configuração usando SnDevOpsConfig .
      
      snDevOpsConfig(
           applicationName: 'PaymentDemo',
           target: 'component',
           namePath: 'paymentService-v1.0',
           configFile: 'infra/v1/*',
           autoCommit: 'true',
           autoValidate: 'true',
           autoPublish: 'true'
      )

    SnDevOpsConfigUpload

    Esta ação carrega um arquivo de configuração para um determinado local em um modelo de dados da aplicação.

    Ele deve ser usado de natureza iterativa para que todos os arquivos de configuração sejam carregados no modelo de dados da aplicação durante a execução do pipeline.

    Compatível com:
    • Carregar para:
      • Um componente, coleção ou implantável.
      • A pasta de variáveis (variáveis) de um componente, coleção ou implantável.
    • Padrão regex para entrada do arquivo de configuração.
    • Capacidade de ser chamado várias vezes no mesmo pipeline.
    Variáveis de entrada
    ConfigFile Especifica o arquivo de dados de configuração a ser carregado no componente ou no caminho implantável no modelo de dados.
    applicationName Especifica a aplicação para onde os dados de configuração serão carregados.
    target Especifica o destino do modelo de dados para onde os dados de configuração serão carregados (por exemplo, componente , coleção , implantável ).
    CollectionName (Opcional) Nome da coleção para carregar (obrigatório se o destino for coleção).
    NomeDeployableName Nome do implantável para o qual carregar (obrigatório se o destino for implantável).
    namePath

    Especifica o caminho do nome no modelo de dados para onde os dados de configuração serão carregados.

    Nota:
    Ao carregar para uma pasta vars, você deve iniciar o caminho do nome com "vars/" para especificar o caminho da pasta variável.
    DataFormat Especifica o formato de dados do arquivo de configuração (por exemplo, JSON , AML , XML , etc.)
    ConvertPath (Opcional) Especifica se a estrutura de diretórios dos arquivos de configuração deve ser preservada (em relação ao espaço) e converter o diretório em caminhos no modelo de dados.
    changesetNumber

    (Opcional) Especifica o changeset (aberto) ao qual esta atividade de carregamento está associada. Se não for fornecido, um novo changeset será criado.

    Nota:
    Usado somente para vários cenários de upload.
    AutoCOMMIT Especifica se os dados de configuração devem ser confirmados após o carregamento (verdadeiro/falso). O padrão é falso.
    AutoValidar Especifica se os dados de configuração devem ser validados durante a confirmação (verdadeiro/falso). O padrão é falso.
    Variável de saída
    changesetNumber

    (Opcional) Especifica o changeset (aberto) ao qual esta atividade de carregamento está associada.

    Se um número de changeset não for fornecido, um novo changeset será criado.

    Exemplo
    • Entrada:

      Aqui está um exemplo de SnDevOpsConfigUpload ação. Para fins de ilustração, atribuiremos a resposta a uma variável, ChangeSetId , que pode ser ecoado para o log do console para cenários de depuração.

      
      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"
    • Saída:

      Além dos dados que estão sendo carregados em nosso modelo de dados em Configuração de DevOps, A saída seria semelhante a isto (usando o plug-in Oceano Azul para visualizar a saída do console).

      Saída de carregamento da configuração de configuração de DevOps

    Exemplo: Vários carregamentos (componente)
    Você pode chamar a ação de upload mais de uma vez para carregar dados de configuração em diferentes formatos de arquivo de diferentes locais, mantendo os uploads como parte de um changeset.
    • No primeiro carregamento, nomeie a ação para que a variável de saída changesetNumber possa ser reutilizada nos carregamentos subsequentes.
      Carregamento de arquivo YAML:
      
      $changeset = snDevOpsConfigUpload(
           applicationName: 'PaymentDemo',
           target: 'component',
           namePath: 'wep-api-v1.0',
           configFile: 'k8s/helm/values.yml',
           dataFormat: 'yaml',
           autoCommit: 'false',
           autoValidate: 'false'
      )
    • Em carregamentos subsequentes, referencie a variável de saída changesetNumber do primeiro carregamento como uma variável de entrada.
      3 carregamento de arquivos json:
      
      snDevOpsConfigUpload(
           applicationName: 'PaymentDemo',
           target: 'component',
           namePath: 'wep-api-v1.0',
           configFile: 'infra/*.json',
           dataFormat: 'json',
           autoCommit: 'false',
           autoValidate: 'false',
           changesetNumber: ”${changeset}”
      )
    • Na chamada final, além de fazer referência à variável de saída changesetNumber do primeiro carregamento como uma variável de entrada, defina AUTOCOMMIT e autoValidate como verdadeiro .
      Carregamento de arquivo ini:
      
      snDevOpsConfigUpload(
           applicationName: 'PaymentDemo',
           target: 'component',
           namePath: 'wep-api-v1.0',
           configFile: 'featureToggles/set1.ini',
           dataFormat: 'ini',
           autoCommit: 'true',
           autoValidate: 'true',
           changesetNumber: ”${changeset}”
      )
    Exemplo: Vários uploads (coleção e variáveis)
    Você pode chamar a ação de upload mais de uma vez para carregar dados de configuração em diferentes formatos de arquivo de diferentes locais, mantendo os uploads como parte de um changeset.
    • No primeiro carregamento, crie uma variável (por exemplo, changeset) e atribua o valor de retorno da etapa a ela para que ela possa ser reutilizada nos carregamentos subsequentes.
      Carregamento de arquivo 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'
      )
    • Em carregamentos subsequentes, use a variável como entrada.
      Carregamento de arquivo JSON:
      
      snDevOpsConfigUpload(
           applicationName: 'PaymentDemo',
           target: 'deployable',
           deployableName: 'Production',
           namePath: 'vars/dbSettings',
           configFile: 'infra/prod/dbConfig.json',
           dataFormat: 'json',
           autoCommit: 'true',
           autoValidate: 'true',
           changesetNumber: ”${changeset}”
      )
    Nota:
    Para carregar em uma pasta de variáveis, uploadTarget deve ser definido como implantável E os valores corretos devem ser definidos para deployableName e changesetNumber.

    SnDevOpsConfigGetSnapshots

    Esta ação deve ser usada em diferentes cenários:

    • Recupere todos os snapshots de todos os implantáveis afetados.

      Quando os arquivos de configuração são carregados em um modelo de dados da aplicação, o sistema criará snapshots para todos os implantáveis determinados como afetados pelo carregamento. Ao acompanhar o fluxo de IC, supondo que a última chamada de carregamento tenha a validação habilitada, a próxima etapa seria iterar pela lista de snapshots e garantir que todos tenham sido aprovados na validação.

    • Recupere um snapshot específico.

      Após o fluxo do CD, um snapshot específico é recuperado para que possa ser publicado e exportado para ser consumido downstream (por exemplo, para provisionar infraestrutura ou aplicação).

    • Recupere os snapshots mais recentes para um implantável de uma aplicação caso um carregamento não gere snapshots.

      Um conjunto de dados de configuração está disponível para implantação em um ambiente para uma combinação application-implantable-changeset quando nenhuma mudança de configuração é feita.

    • Mostrar resultados de validação de política em uma execução de pipeline.

      Exiba os resultados da validação de política como resultados de testes na página Resultados de testes de compilação do Jenkins, incluindo Conformidade com exceção, ao obter um snapshot.

    Definições de entrada
    applicationName Especifica a aplicação para carregar dados de configuração ou exportar dados.
    NomeDeployableName (Opcional) Especifica o implantável para a aplicação na qual obter os dados de snapshot mais recentes.
    changesetNumber (Opcional) Especifica o ID do changeset para o conjunto de mudanças de configuração em que o usuário está interessado.
    IsValidado (Opcional) Especifica se devem retornar somente snapshots aprovados ou passados com exceção (verdadeiro/falso). O padrão é verdadeiro.
    ContinuoWithLatest (Opcional) Especifica se o snapshot mais recente deve ser retornado de acordo com Nome da aplicação - NomeDeployableName - ChangesetNumber combinação se nenhum snapshot for gerado (verdadeiro/falso). O padrão é falso.
    Saída
    • Se for bem-sucedido, um snapshot ou conjunto de snapshots.
    • Em caso de falha, uma mensagem de falha de API/back-end será mostrada.
    Exemplo
    • Snapshot específico (especificado):
      
      $snapshots = snDevOpsConfigGetSnapshots(
           applicationName: 'PaymentDemo',
           deployableName: 'Production',
           changesetNumber: 'Chset-16',
           isValidated: 'true',
           continueWithLatest: 'true'
      )
    • Snapshot validado mais recente (retorna o snapshot mais recente da combinação de aplicação e implantável):
      
      $snapshots = snDevOpsConfigGetSnapshots(
           applicationName: 'PaymentDemo',
           deployableName: 'Production',
           isValidated: 'true'
      )
    • Todos os snapshots do changeset (retorna todos os snapshots da combinação de aplicação e implantável):
      
      $snapshots = snDevOpsConfigGetSnapshots(
           applicationName: 'PaymentDemo',
           changesetNumber: 'Chset-16'
      )
    • Mostrar resultados de validação de política em uma execução de pipeline.
      1. Atribua uma variável ao caminho do arquivo que contém os resultados de validação de snapshot gerados durante SnDevOpsConfigGetSnapshots ação.
      2. Ligue para Ação JUnit para carregar os resultados de validação de snapshot na seção de teste de execução de 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
          }
      }
      

    SnDevOpsConfigPublish

    Esta ação publica um snapshot para a aplicação fornecida e implantável. A partir daqui, o snapshot pode ser consumido por meio do processo de exportação.

    Definições de entrada
    applicationName Especifica a aplicação da qual publicar dados de configuração.
    NomeDeployableName Especifica o implantável para a aplicação da qual publicar os dados de configuração.
    nomeSnapshot Especifica o nome do snapshot a ser publicado.
    Saída
    • Se bem-sucedido, verdadeiro.
    • Caso contrário, falso.
    Exemplo
    
    snDevOpsConfigPublish(
         applicationName: 'PaymentDemo',
         deployableName: 'Production',
         snapshotName: 'Production-v23.dpl',
    )

    SnDevOpsConfigExport

    Esta ação exporta um snapshot para a aplicação fornecida e implantável.

    O usuário deve especificar o exportador, os argumentos relevantes do exportador, o formato de exportação (por exemplo, YAML, JSON etc.) e o local de saída dos dados de configuração exportados.

    A partir daqui, os dados de configuração podem ser usados diretamente como uma entrada para uma ferramenta de implantação ou provisionamento downstream no pipeline.

    Argumentos de entrada
    applicationName Especifica a aplicação da qual exportar dados.
    NomeDeployableName Especifica a configuração implantável para a aplicação da qual exportar dados.
    nomeSnapshot

    (Opcional) Especifica o snapshot do qual exportar os dados.

    Se um snapshot não for especificado, o snapshot mais recente para o implantável será usado.

    Nome da exportação Especifica o exportador a ser aplicado ao snapshot (por exemplo, UniqueCDIs ).
    ExportarArgs (Opcional) Especifica argumentos a serem usados junto com o exportador.
    Formato de exportação Especifica o formato para exportar os dados do snapshot (por exemplo, INI , AML , PROPS ).
    nomeArquivo

    Especifica o arquivo para o qual exportar dados (presume-se que esteja no espaço).

    Se um nome de arquivo não for especificado, uma concatenação do nome da aplicação e do nome implantável (mais a extensão de arquivo) será usada por padrão.

    Saída
    • Se bem-sucedido, verdadeiro.
    • Caso contrário, falso.
    Exemplo
    
    snDevOpsConfigExport(
         applicationName: 'PaymentDemo',
         deployableName: 'Production',
         snapshotName: 'Production-v23.dpl',
         exporterFormat: 'yaml',
         exporterName: 'returnAllData-now',
         exporterArgs: '',
         fileName: 'exported_file-Production-20220302.yml'
    )

    SnDevOpsConfigRegisterPipeline

    Esta ação vincula um changeset e/ou snapshot ao pipeline para que ele possa ser rastreado durante a execução do pipeline. Em Velocidade de mudança para DevOps, Isso é mostrado na IU do pipeline.

    Consulte Acelerando seu DevOpsprocesso de mudançapara obter mais informações sobre DevOpsRecurso de aceleração de mudança.

    Argumentos de entrada
    applicationName Especifica o nome da aplicação.
    changesetNumber

    (Opcional) Especifica o changeset a ser associado à execução do pipeline.

    Nota:
    Especifique changesetNumber ou snapshotName, mas não ambos.
    nomeSnapshot

    (Opcional) Especifica o nome do snapshot a ser associado à execução do pipeline.

    Nota:
    Especifique changesetNumber ou snapshotName, mas não ambos.
    Saída
    • Se bem-sucedido, verdadeiro.
    • Caso contrário, falso.
    Exemplo
    • Entrada:

      Aqui está um exemplo de SnDevOpsConfigRegisterPipeline ação. Para fins de ilustração, atribuiremos a resposta a uma variável, ChangeSetRegResult , que pode ser ecoado para o log do console para cenários de depuração.

      
      changeSetRegResult = snDevOpsConfigRegisterPipeline(
           applicationName: "PaymentDemo",
           changesetNumber: "Chset-122"
      )
      
      echo "Pipeline registration result: ${changeSetRegResult}"
    • Saída:

      Além dos dados que estão sendo carregados em nosso modelo de dados em Configuração de DevOps, A saída seria semelhante a isto (usando o plug-in Oceano Azul para visualizar a saída do console).

      Saída do pipeline do registro de configuração de DevOps

    SnDevOpsConfigValidate

    Valide os dados de configuração em relação às políticas da sua organização.

    Argumentos de entrada
    applicationName Aplicação a ser validada.
    NomeDeployableName Implantável para que a aplicação valide.
    nomeSnapshot (Opcional) Nome do snapshot a ser validado.
    MarkFailed (Opcional) Falha no pipeline caso a tentativa de validação falhe (devido a um problema de back-end).
    MostrarResultados (Opcional) Mostre os resultados de validação no Jenkinslog do console de trabalho.
    Saída
    • Se bem-sucedido, nenhuma saída.
    • Em caso de falha, uma mensagem de falha de API/back-end será mostrada.
    Exemplo
    • Snapshot específico (especificado):
      
      snDevOpsConfigValidate(
           applicationName: 'PaymentDemo',
           deployableName: 'Production',
           snapshotName: 'Production-v23.dpl',
      )
    • Snapshot mais recente (recupera e valida o snapshot mais recente para combinação de aplicação e implantável):
      
      $changeset = snDevOpsConfigValidate(
           applicationName: 'PaymentDemo',
           deployableName: 'Production'
      )

    SnDevOpsChange

    Crie uma solicitação de mudança e anexe um snapshot para referência.

    Consulte Acelerando seu DevOpsprocesso de mudançapara obter mais informações sobre DevOpsRecurso de aceleração de mudança.

    Argumentos de entrada
    applicationName Especifica o nome da aplicação.
    nomeSnapshot Especifica o nome do snapshot a ser associado à solicitação de mudança.
    Exemplo
    
    snDevOpsChange(
         applicationName: 'PaymentDemo',
         snapshotName: 'Production-v23.dpl'
    )

    Exemplo de pipeline do 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
            }
        }
    }