Skip to content

Latest commit

 

History

History
309 lines (231 loc) · 11.5 KB

resources-repositories-repository.md

File metadata and controls

309 lines (231 loc) · 11.5 KB
title description ms.date monikerRange
resources.repositories.repository definition
A repository resource is used to reference an additional repository in your pipeline.
11/20/2024
<=azure-pipelines

resources.repositories.repository definition

:::moniker range="<=azure-pipelines"

The repository keyword lets you specify an external repository. Use a repository resource to reference an additional repository in your pipeline.

:::moniker-end

:::moniker range=">=azure-pipelines-2022.1"

repositories:
- repository: string # Required as first property. Alias for the repository.
  endpoint: string # ID of the service endpoint connecting to this repository.
  trigger: none | trigger | [ string ] # CI trigger for this repository, no CI trigger if skipped (only works for Azure Repos).
  name: string # repository name (format depends on 'type'; does not accept variables).
  ref: string # ref name to checkout; defaults to 'refs/heads/main'. The branch checked out by default whenever the resource trigger fires.
  type: string # Type of repository: git, github, githubenterprise, and bitbucket.

:::moniker-end

:::moniker range=">=azure-pipelines-2020 <=azure-pipelines-2022"

repositories:
- repository: string # Required as first property. Alias for the repository.
  endpoint: string # ID of the service endpoint connecting to this repository.
  trigger: none | trigger | [ string ] # CI trigger for this repository, no CI trigger if skipped (only works for Azure Repos).
  name: string # repository name (format depends on 'type'; does not accept variables).
  type: string # Type of repository: git, github, githubenterprise, and bitbucket.
  ref: string # ref name to checkout; defaults to 'refs/heads/main'. The branch checked out by default whenever the resource trigger fires. Does not accept variables.

:::moniker-end

:::moniker range="<=azure-pipelines-2019.1"

repositories:
- repository: string # Required as first property. Alias for the repository.
  endpoint: string # ID of the service endpoint connecting to this repository.
  name: string # repository name (format depends on 'type'; does not accept variables).
  type: string # Type of repository: git, github, githubenterprise, and bitbucket.
  ref: string # ref name to checkout; defaults to 'refs/heads/main'. The branch checked out by default whenever the resource trigger fires. Does not accept variables.

:::moniker-end

:::moniker range="<=azure-pipelines"

Definitions that reference this definition: resources.repositories

:::moniker-end

Properties

:::moniker range="<=azure-pipelines"

repository string. Required as first property.
Alias for the specified repository. Acceptable values: [-_A-Za-z0-9]*.

:::moniker-end

:::moniker range="<=azure-pipelines"

endpoint string.
ID of the service endpoint connecting to this repository.

:::moniker-end

:::moniker range=">=azure-pipelines-2020"

trigger trigger.
CI trigger for this repository, no CI trigger if omitted.

Important

  • Repository resource triggers are supported only for Azure Repos Git repositories.
  • Repository resource triggers don't support batch.

:::moniker-end

:::moniker range="<=azure-pipelines"

name string.
Repository name. Format depends on 'type'; does not accept variables.

:::moniker-end

:::moniker range=">=azure-pipelines-2022.1"

ref string.
ref name to checkout; defaults to 'refs/heads/main'. The branch checked out by default whenever the resource trigger fires. Template expressions are supported.

:::moniker-end

:::moniker range="<=azure-pipelines-2022"

ref string.
ref name to checkout; defaults to 'refs/heads/main'. The branch checked out by default whenever the resource trigger fires. Does not accept variables.

:::moniker-end

:::moniker range="<=azure-pipelines"

type string.
Type of repository: git, github, githubenterprise, and bitbucket.

:::moniker-end

Remarks

::: moniker range="<= azure-pipelines-2022"

Important

Repository resource does not allow pipeline variables in name and ref. Wildcards are supported in triggers.

::: moniker-end

::: moniker range=">= azure-pipelines-2022.1"

Template expressions are supported for the ref property (but not the name property). Wildcards are supported in triggers.

::: moniker-end

::: moniker range=">= azure-pipelines-2020"

Important

Repository resource triggers are supported for Azure Repos Git repositories only. For more information on trigger syntax, including wildcard support for branches and tags, see trigger definition and Build Azure Repos Git or TFS Git repositories.

Important

batch is not supported in repository resource triggers.

::: moniker-end

::: moniker range=">= azure-pipelines-2019 <= azure-pipelines-2019.1"

If your pipeline has templates in another repository, you must let the system know about that repository.

::: moniker-end

::: moniker range=">= azure-pipelines-2020"

If your pipeline has templates in another repository, or if you want to use multi-repo checkout with a repository that requires a service connection, you must let the system know about that repository.

::: moniker-end

Types

Pipelines support the following values for the repository type: git, github, and bitbucket. The git type refers to Azure Repos Git repos.

  • If you specify type: git, the name value refers to the name of an Azure Repos Git repository.

    • If your pipeline is in the same Azure DevOps project as the repository, for example a repository named tools, you reference it using name: tools.
    • If your pipeline is in the same Azure DevOps organization as the repository, but in a different Azure DevOps project, for example a project named ToolsProject, you must qualify the repository name with the project name: name: ToolsProject/tools.
  • If you specify type: github, the name value is the full name of the GitHub repo and includes the user or organization. An example is name: Microsoft/vscode. GitHub repos require a GitHub service connection for authorization.

  • If you specify type: bitbucket, the name value is the full name of the Bitbucket Cloud repo and includes the user or organization. An example is name: MyBitbucket/vscode. Bitbucket Cloud repos require a Bitbucket Cloud service connection for authorization.

For more information about these types, see Check out multiple repositories in your pipeline - Repository resource definition.

:::moniker range=">=azure-pipelines"

Variables

In each run, the metadata for a repository resource is available to all jobs in the form of runtime variables. The <Alias> is the identifier that you gave for your repository resource.

resources.repositories.<Alias>.name
resources.repositories.<Alias>.ref
resources.repositories.<Alias>.type
resources.repositories.<Alias>.id
resources.repositories.<Alias>.url
resources.repositories.<Alias>.version

The following example has a repository resource with an alias of common, and the repository resource variables are accessed using resources.repositories.common.*.

resources:
  repositories:
    - repository: common
      type: git
      ref: main
      name: Repo

variables:
  ref: $[ resources.repositories.common.ref ]
  name: $[ resources.repositories.common.name ]
  id: $[ resources.repositories.common.id ]
  type: $[ resources.repositories.common.type ]
  url: $[ resources.repositories.common.url ]
  version: $[ resources.repositories.common.version ]

steps:
- bash: |
    echo "name = $(name)"
    echo "ref = $(ref)"
    echo "id = $(id)"
    echo "type = $(type)"
    echo "url = $(url)"
    echo "version = $(version)"

::: moniker-end

:::moniker range=">=azure-pipelines-2020 < azure-pipelines"

Variables

In each run, the metadata for a repository resource is available to all jobs in the form of runtime variables. The <Alias> is the identifier that you gave for your repository resource.

resources.repositories.<Alias>.name
resources.repositories.<Alias>.ref
resources.repositories.<Alias>.type
resources.repositories.<Alias>.id
resources.repositories.<Alias>.url

The following example has a repository resource with an alias of common, and the repository resource variables are accessed using resources.repositories.common.*.

resources:
  repositories:
    - repository: common
      type: git
      ref: main
      name: Repo

variables:
  ref: $[ resources.repositories.common.ref ]
  name: $[ resources.repositories.common.name ]
  id: $[ resources.repositories.common.id ]
  type: $[ resources.repositories.common.type ]
  url: $[ resources.repositories.common.url ]

steps:
- bash: |
    echo "name = $(name)"
    echo "ref = $(ref)"
    echo "id = $(id)"
    echo "type = $(type)"
    echo "url = $(url)"

::: moniker-end

Examples

resources:
  repositories:
  - repository: common
    type: github
    name: Contoso/CommonTools
    endpoint: MyContosoServiceConnection

See also