2019-10-25 14:52:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< p  align = "center" >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < a  href = "https://github.com/actions/checkout" > < img  alt = "GitHub Actions status"  src = "https://github.com/actions/checkout/workflows/test-local/badge.svg" > < / a > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / p >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 05:00:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Checkout V2
  
						 
					
						
							
								
									
										
										
										
											2019-07-23 19:32:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								This action checks-out your repository under `$GITHUB_WORKSPACE` , so your workflow can access it.
							 
						 
					
						
							
								
									
										
										
										
											2019-07-23 19:32:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-02 20:40:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Only a single commit is fetched by default, for the ref/SHA that triggered the workflow. Set `fetch-depth`  to fetch more history. Refer [here ](https://help.github.com/en/articles/events-that-trigger-workflows ) to learn which commit `$GITHUB_SHA`  points to for different events.
							 
						 
					
						
							
								
									
										
										
										
											2019-08-13 14:53:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-02 20:40:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The auth token is persisted in the local git config. This enables your scripts to run authenticated git commands. The token is removed during post-job cleanup. Set `persist-credentials: false`  to opt-out.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								When Git 2.18 or higher is not in your PATH, falls back to the REST API to download the files.
							 
						 
					
						
							
								
									
										
										
										
											2019-07-23 19:32:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-06 03:10:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# What's new
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-01-02 20:40:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Improved performance 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  Fetches only a single commit by default
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 16:26:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Script authenticated git commands 
						 
					
						
							
								
									
										
										
										
											2020-01-02 20:40:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  -  Auth token persisted in the local git config
							 
						 
					
						
							
								
									
										
										
										
											2020-03-20 02:17:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Supports SSH 
						 
					
						
							
								
									
										
										
										
											2019-12-03 16:26:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Creates a local branch 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  No longer detached HEAD when checking out a branch
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Improved layout 
						 
					
						
							
								
									
										
										
										
											2019-12-12 18:49:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  -  The input `path`  is always relative to $GITHUB_WORKSPACE
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  Aligns better with container actions, where $GITHUB_WORKSPACE gets mapped in
							 
						 
					
						
							
								
									
										
										
										
											2019-12-12 18:16:16 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Fallback to REST API download 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  When Git 2.18 or higher is not in the PATH, the REST API will be used to download the files
							 
						 
					
						
							
								
									
										
										
										
											2020-01-02 20:40:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  -  When using a job container, the container's PATH is used
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 16:26:12 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Refer [here ](https://github.com/actions/checkout/blob/v1/README.md ) for previous versions.
							 
						 
					
						
							
								
									
										
										
										
											2019-07-23 19:32:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Usage
  
						 
					
						
							
								
									
										
										
										
											2019-09-05 15:42:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<!--  start usage  -->  
						 
					
						
							
								
									
										
										
										
											2019-07-23 19:32:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 05:00:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v2 
						 
					
						
							
								
									
										
										
										
											2019-07-23 19:32:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 21:47:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Repository name with owner. For example, actions/checkout
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Default: ${{ github.repository }}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    repository: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-12 18:49:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # The branch, tag or SHA to checkout. When checking out the repository that
							 
						 
					
						
							
								
									
										
										
										
											2019-12-05 04:43:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # triggered a workflow, this defaults to the reference or SHA for that event.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Otherwise, defaults to `master` .
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    ref: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-11 19:55:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Personal access token (PAT) used to fetch the repository. The PAT is configured
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # with the local git config, which enables your scripts to run authenticated git
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # commands. The post-job step removes the PAT.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #
							 
						 
					
						
							
								
									
										
										
										
											2020-03-12 15:42:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # We recommend using a service account with the least permissions necessary. Also
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # when generating a new PAT, select the least scopes necessary.
							 
						 
					
						
							
								
									
										
										
										
											2020-03-11 19:55:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    #
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # [Learn more about creating and using encrypted secrets ](https://help.github.com/en/actions/automating-your-workflow-with-github-actions/creating-and-using-encrypted-secrets )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Default: ${{ github.token }}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    token: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-12 15:42:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # SSH key used to fetch the repository. The SSH key is configured with the local
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # git config, which enables your scripts to run authenticated git commands. The
							 
						 
					
						
							
								
									
										
										
										
											2020-03-11 19:55:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # post-job step removes the SSH key.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #
							 
						 
					
						
							
								
									
										
										
										
											2020-03-12 15:42:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # We recommend using a service account with the least permissions necessary.
							 
						 
					
						
							
								
									
										
										
										
											2020-03-11 19:55:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    #
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # [Learn more about creating and using encrypted secrets ](https://help.github.com/en/actions/automating-your-workflow-with-github-actions/creating-and-using-encrypted-secrets )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ssh-key: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Known hosts in addition to the user and global host key database. The public SSH
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # keys for a host may be obtained using the utility `ssh-keyscan` . For example,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # `ssh-keyscan github.com` . The public key for github.com is always implicitly
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # added.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ssh-known-hosts: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Whether to perform strict host key checking. When true, adds the options
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # `StrictHostKeyChecking=yes`  and `CheckHostIP=no`  to the SSH command line. Use
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # the input `ssh-known-hosts`  to configure additional hosts.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ssh-strict: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Whether to configure the token or SSH key with the local git config
							 
						 
					
						
							
								
									
										
										
										
											2019-12-12 18:49:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Default: true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    persist-credentials: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Relative path under $GITHUB_WORKSPACE to place the repository
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    path: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Whether to execute `git clean -ffdx && git reset --hard HEAD`  before fetching
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    clean: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Number of commits to fetch. 0 indicates all history.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: 1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fetch-depth: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Whether to download Git-LFS files
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: false
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    lfs: ''
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 19:21:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Whether to checkout submodules: `true`  to checkout submodules or `recursive`  to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # recursively checkout submodules.
							 
						 
					
						
							
								
									
										
										
										
											2020-03-11 19:55:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    #
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # When the `ssh-key`  input is not provided, SSH URLs beginning with
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # `git@github.com:`  are converted to HTTPS.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #
							 
						 
					
						
							
								
									
										
										
										
											2020-03-05 19:21:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Default: false
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    submodules: ''
							 
						 
					
						
							
								
									
										
										
										
											2019-07-23 19:32:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<!--  end usage  -->  
						 
					
						
							
								
									
										
										
										
											2019-07-23 19:32:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Scenarios
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Checkout a different branch ](#Checkout-a-different-branch ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Checkout HEAD^ ](#Checkout-HEAD ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Checkout multiple repos (side by side) ](#Checkout-multiple-repos-side-by-side ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Checkout multiple repos (nested) ](#Checkout-multiple-repos-nested ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Checkout multiple repos (private) ](#Checkout-multiple-repos-private ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Checkout pull request HEAD commit instead of merge commit ](#Checkout-pull-request-HEAD-commit-instead-of-merge-commit ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Checkout pull request on closed event ](#Checkout-pull-request-on-closed-event ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Fetch all tags ](#Fetch-all-tags ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Fetch all branches ](#Fetch-all-branches ) 
						 
					
						
							
								
									
										
										
										
											2019-12-16 15:45:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  [Fetch all history for all tags and branches ](#Fetch-all-history-for-all-tags-and-branches ) 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Checkout a different branch
  
						 
					
						
							
								
									
										
										
										
											2019-09-05 15:42:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 05:00:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v2 
						 
					
						
							
								
									
										
										
										
											2019-09-05 15:42:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    ref: my-branch
							 
						 
					
						
							
								
									
										
										
										
											2019-09-05 15:42:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Checkout HEAD^
  
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-10-25 14:52:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 05:00:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v2 
						 
					
						
							
								
									
										
										
										
											2019-10-25 14:52:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fetch-depth: 2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  run: git checkout HEAD^ 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Checkout multiple repos (side by side)
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  uses: actions/checkout@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    path: main
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout tools repo 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  uses: actions/checkout@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    repository: my-org/my-tools
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    path: my-tools
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Checkout multiple repos (nested)
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  uses: actions/checkout@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout tools repo 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  uses: actions/checkout@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    repository: my-org/my-tools
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    path: my-tools
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Checkout multiple repos (private)
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  uses: actions/checkout@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    path: main
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout private tools 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  uses: actions/checkout@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    repository: my-org/my-private-tools
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    token: ${{ secrets.GitHub_PAT }} # `GitHub_PAT`  is a secret that contains your PAT
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    path: my-tools
							 
						 
					
						
							
								
									
										
										
										
											2019-10-25 14:52:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  - `${{ github.token }}` is scoped to the current repository, so if you want to checkout a different repository that is private you will need to provide your own [PAT](https://help.github.com/en/github/authenticating-to-github/creating-a-personal-access-token-for-the-command-line).
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Checkout pull request HEAD commit instead of merge commit
  
						 
					
						
							
								
									
										
										
										
											2019-12-04 15:12:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 05:00:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v2 
						 
					
						
							
								
									
										
										
										
											2019-12-04 15:12:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
									
										
										
										
											2019-12-10 16:17:38 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    ref: ${{ github.event.pull_request.head.sha }}
							 
						 
					
						
							
								
									
										
										
										
											2019-12-04 15:12:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Checkout pull request on closed event
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								on:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  pull_request:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    branches: [master]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    types: [opened, synchronize, closed]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								jobs:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  build:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    runs-on: ubuntu-latest
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    steps:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  uses: actions/checkout@v2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Fetch all tags
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  uses: actions/checkout@v2 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  run: git fetch --depth=1 origin +refs/tags/*:refs/tags/* 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Fetch all branches
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  uses: actions/checkout@v2 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  run: | 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    git fetch --no-tags --prune --depth=1 origin +refs/heads/*:refs/remotes/origin/*
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-16 15:45:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Fetch all history for all tags and branches
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  uses: actions/checkout@v2 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  run: | 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    git fetch --prune --unshallow
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-07-23 19:32:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# License
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The scripts and documentation in this project are released under the [MIT License ](LICENSE )