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 |
:::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
:::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
::: 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
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
, thename
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 usingname: 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 your pipeline is in the same Azure DevOps project as the repository, for example a repository named
-
If you specify
type: github
, thename
value is the full name of the GitHub repo and includes the user or organization. An example isname: Microsoft/vscode
. GitHub repos require a GitHub service connection for authorization. -
If you specify
type: bitbucket
, thename
value is the full name of the Bitbucket Cloud repo and includes the user or organization. An example isname: 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"
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"
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
resources:
repositories:
- repository: common
type: github
name: Contoso/CommonTools
endpoint: MyContosoServiceConnection