Configure Azure DevOps for JFrog

  • Release version: Xanadu
  • Updated July 31, 2025
  • 2 minutes to read
  • Summarize
    Summarized using AI
    This content was generated using new OpenAI-powered functionality. Results are provided on an as is basis and are not guaranteed to be accurate or complete.

    Summary of Configure Azure DevOps for JFrog

    This guide explains how to configure your Azure DevOps environment to integrate with JFrog Artifactory, enabling seamless upload and download of artifacts. By setting up this integration, you can automate artifact management within your CI/CD pipelines, ensuring efficient and consistent build processes.

    Show full answer Show less

    Configuring Azure DevOps for JFrog

    • Install the JFrog Artifactory plugin in your Azure DevOps instance.
    • Create a new service connection in your project by navigating to Project settings > Pipelines > Service connections, selecting the JFrog Artifactory plugin, and entering your JFrog instance details, including username and password credentials.

    Uploading Artifacts from Azure DevOps to JFrog

    • In your pipeline stage for uploading artifacts, add the Artifactory Generic Upload task.
    • Select the JFrog service connection and provide a file spec defining the artifacts to upload.
    • Enable Collect build info and set the build number to the Azure DevOps BuildId parameter.
    • Add the Artifactory Publish Build Info task to publish build metadata, linking it to the same build number.

    A sample YAML pipeline snippet demonstrates these steps, including specifying the artifact pattern, target repository, and build identifiers.

    Downloading Artifacts from JFrog to Azure DevOps

    • In your pipeline stage for downloading artifacts, add the Artifactory Generic Download task.
    • Use the JFrog service connection and enter a file spec to define which artifacts to download and their target location.
    • Enable Collect build info and configure the build number with the Azure DevOps BuildId.
    • Add the Artifactory Publish Build Info task to record build information.

    A sample YAML pipeline example is included, showing how to specify the artifact path in JFrog and the local target directory.

    Benefits for ServiceNow Customers

    By integrating Azure DevOps with JFrog Artifactory using this configuration, ServiceNow customers can automate artifact handling within their DevOps workflows. This ensures reliable artifact storage, traceability through build info, and simplifies managing dependencies for ServiceNow application deployments and custom development.

    Configure your Azure DevOps instance to enable upload and download of JFrog artifacts.

    The following settings are required in your Azure DevOps instance:
    1. Install the plugin JFrog Artifactory.
    2. Select your project and navigate to Project settings > Pipelines > Service connections.
    3. Select New service connection, search and select the installed JFrog Artifactory plugin, and select Next.
    4. Enter your JFrog instance details and create a service connection for JFrog.
      New JFrog Artifactory service connection.
      Note:
      The Username and Password fields must contain the credentials to your JFrog instance entered in the Server URL field.

    Upload artifacts from Azure DevOps to JFrog

    To upload artifacts:
    1. Navigate to your project pipeline.
    2. In your stage for uploading, add the task Artifactory Generic Upload for uploading artifacts.
    3. For the Artifactory Generic Upload task:
      1. Select the service connection you created for JFrog.
      2. In the Spec field, entire your file spec.
      3. Select the Collect build info check box.
      4. The Build number field should contain the BuildId parameter.
      5. Select Add.

      Artifactory Generic Upload task.

    4. Add the task Artifactory Publish Build Info for publishing build info.
    5. For the Artifactory Publish Build Info task:
      1. Select the service connection you created for JFrog.
      2. The Build number field should contain the BuildId parameter.
      3. Select Add.

      Artifactory Publish Build Info task.

    Sample pipeline to upload artifacts from Azure DevOps to JFrog

    
    trigger:
    - none
    pool: 
      vmImage: ubuntu-latest
     
    
    variables:
    - group: Variable Group
    
    stages:
      - stage: upload_artifact
        jobs:
          - job: 'upload'
            steps:
            - script: echo Hello, world!
              displayName: 'Run a one-line script'
            - task: ArtifactoryGenericUpload@2
              inputs:
                artifactoryService: 'JFrogCloud'
                specSource: 'taskConfiguration'
                fileSpec: |
                  {
                    "files": [
                      {
                        "pattern": "servicenow-app-devops.zip",
                        "target": "local-repo"
                      }
                    ]
                  }
                collectBuildInfo: true
                buildName: '$(Build.DefinitionName)'
                buildNumber: '$(Build.BuildId)'
                failNoOp: true'
            - task: ArtifactoryPublishBuildInfo@1
              inputs:
                artifactoryService: 'JFrogCloud'
                buildName: '$(Build.DefinitionName)'
                buildNumber: '$(Build.BuildId)'

    Download artifacts from JFrog to Azure DevOps

    To download artifacts:
    1. Navigate to your project pipeline.
    2. In your stage for downloading, add the task Artifactory Generic Download for downloading artifacts.
    3. For the Artifactory Generic Download task:
      1. Select the service connection you created for JFrog.
      2. In the Spec field, entire your file spec.
      3. Select the Collect build info check box.
      4. The Build number field should contain the BuildId parameter.
      5. Select Add.
    4. Add the task Artifactory Publish Build Info for publishing build info.
    5. For the Artifactory Publish Build Info task:
      1. Select the service connection you created for JFrog.
      2. The Build number field should contain the BuildId parameter.
      3. Select Add.

    Sample pipeline to download artifacts from Azure DevOps to JFrog

    
    trigger:
    - none
    pool: 
      vmImage: ubuntu-latest
     
    
    variables:
    - group: Variable Group
    
    stages:        
      - stage: download_artifact
        jobs:
          - job: 'download'
            steps:
            - task: ArtifactoryGenericDownload@3
              inputs:
                connection: 'JFrogCloud'
                specSource: 'taskConfiguration'
                fileSpec: |
                  {
                    "files": [
                      {
                        "pattern": "local-repo/servicenow-app-devops.zip",
                        "target": "/tmp/"
                      }
                    ]
                  }
                collectBuildInfo: true
                buildName: '$(Build.DefinitionName)'
                buildNumber: '$(Build.BuildId)'
                failNoOp: true
            - task: ArtifactoryPublishBuildInfo@1
              inputs:
                artifactoryService: 'JFrogCloud'
                buildName: '$(Build.DefinitionName)'
                buildNumber: '$(Build.BuildId)'