2022-10-17 13:49:29 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								[](https://github.com/actions/checkout/actions/workflows/test.yml)
							 
						 
					
						
							
								
									
										
										
										
											2019-10-25 14:52:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Checkout V4
  
						 
					
						
							
								
									
										
										
										
											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 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-13 15:07:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Only a single commit is fetched by default, for the ref/SHA that triggered the workflow. Set `fetch-depth: 0`  to fetch all history for all branches and tags. Refer [here ](https://docs.github.com/actions/using-workflows/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
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-17 15:52:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Please refer to the [release page ](https://github.com/actions/checkout/releases/latest ) for the latest release notes.
							 
						 
					
						
							
								
									
										
										
										
											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
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v4 
						 
					
						
							
								
									
										
										
										
											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.
							 
						 
					
						
							
								
									
										
										
										
											2020-06-16 17:41:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Otherwise, uses the default branch.
							 
						 
					
						
							
								
									
										
										
										
											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: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-09-22 17:30:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Partially clone against a given filter. Overrides sparse-checkout if set.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: null
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    filter: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-09 13:08:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Do a sparse checkout on given patterns. Each pattern should be separated with
							 
						 
					
						
							
								
									
										
										
										
											2023-09-22 17:30:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # new lines.
							 
						 
					
						
							
								
									
										
										
										
											2023-06-09 13:08:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Default: null
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sparse-checkout: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Specifies whether to use cone-mode when doing a sparse checkout.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sparse-checkout-cone-mode: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-07-13 01:02:24 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Number of commits to fetch. 0 indicates all history for all branches and tags.
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Default: 1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fetch-depth: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-16 20:34:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Whether to fetch tags, even if fetch-depth > 0.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: false
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fetch-tags: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 14:22:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Specifies the maximal number of fetch operations to be run in parallel at a time
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # (submodules, or remotes when the --multiple option of git-fetch is in effect). A
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # value of 0 will give some reasonable default. If unset, it defaults to 1.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: 1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fetch-parallel: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-09-01 18:19:18 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Whether to show progress status output when fetching.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    show-progress: ''
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-12-03 15:28:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # 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: ''
							 
						 
					
						
							
								
									
										
										
										
											2022-04-21 01:37:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 13:53:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Specifies how many submodules are fetched/cloned at the same time. A positive
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # integer allows up to that number of submodules fetched in parallel. A value of 0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # will give some reasonable default. If unset, it defaults to 1.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: 1
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 14:22:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    submodules-fetch-jobs: ''
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 13:53:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-21 01:37:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Add repository path as safe.directory for Git global config by running `git
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # config --global --add safe.directory < path > `
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Default: true
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    set-safe-directory: ''
							 
						 
					
						
							
								
									
										
										
										
											2022-09-26 16:34:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # The base URL for the GitHub instance that you are trying to clone from, will use
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # environment defaults to fetch from the same instance that the workflow is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # running from unless specified. Example URLs are https://github.com or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # https://my-ghes-server.example.com
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    github-server-url: ''
							 
						 
					
						
							
								
									
										
										
										
											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
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-09 13:08:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  [Fetch only the root files ](#Fetch-only-the-root-files ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Fetch only the root files and `.github` and `src` folder ](#Fetch-only-the-root-files-and-github-and-src-folder ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [Fetch only a single file ](#Fetch-only-a-single-file ) 
						 
					
						
							
								
									
										
										
										
											2020-05-27 13:54:28 +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 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  [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 ) 
						 
					
						
							
								
									
										
										
										
											2020-07-14 17:08:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  [Push a commit using the built-in token ](#Push-a-commit-using-the-built-in-token ) 
						 
					
						
							
								
									
										
										
										
											2020-05-27 13:54:28 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-09 13:08:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Fetch only the root files
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v4 
						 
					
						
							
								
									
										
										
										
											2023-06-09 13:08:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sparse-checkout: .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Fetch only the root files and `.github` and `src` folder
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v4 
						 
					
						
							
								
									
										
										
										
											2023-06-09 13:08:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sparse-checkout: |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      .github
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      src
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Fetch only a single file
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v4 
						 
					
						
							
								
									
										
										
										
											2023-06-09 13:08:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sparse-checkout: |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      README.md
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sparse-checkout-cone-mode: false
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-27 13:54:28 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Fetch all history for all tags and branches
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v4 
						 
					
						
							
								
									
										
										
										
											2020-05-27 13:54:28 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fetch-depth: 0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											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
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v4 
						 
					
						
							
								
									
										
										
										
											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
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v4 
						 
					
						
							
								
									
										
										
										
											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 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  uses: actions/checkout@v4
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    path: main
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout tools repo 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  uses: actions/checkout@v4
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    repository: my-org/my-tools
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    path: my-tools
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2022-12-16 21:06:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  - If your secondary repository is private you will need to add the option noted in [Checkout multiple repos (private)](#Checkout-multiple-repos-private)
  
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Checkout multiple repos (nested)
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  uses: actions/checkout@v4
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout tools repo 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  uses: actions/checkout@v4
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    repository: my-org/my-tools
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    path: my-tools
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2022-12-16 21:06:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								>  - If your secondary repository is private you will need to add the option noted in [Checkout multiple repos (private)](#Checkout-multiple-repos-private)
  
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Checkout multiple repos (private)
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  uses: actions/checkout@v4
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    path: main
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  name: Checkout private tools 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  uses: actions/checkout@v4
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  with:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    repository: my-org/my-private-tools
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 21:20:59 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    token: ${{ secrets.GH_PAT }} # `GH_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
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  uses: actions/checkout@v4 
						 
					
						
							
								
									
										
										
										
											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:
							 
						 
					
						
							
								
									
										
										
										
											2020-07-14 13:23:30 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    branches: [main]
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    types: [opened, synchronize, closed]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								jobs:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  build:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    runs-on: ubuntu-latest
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    steps:
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      -  uses: actions/checkout@v4
							 
						 
					
						
							
								
									
										
										
										
											2019-12-13 21:39:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-07-14 17:08:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Push a commit using the built-in token
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								on: push
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								jobs:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  build:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    runs-on: ubuntu-latest
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    steps:
							 
						 
					
						
							
								
									
										
										
										
											2023-09-05 13:21:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      -  uses: actions/checkout@v4
							 
						 
					
						
							
								
									
										
										
										
											2020-07-14 17:08:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      -  run: |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          date > generated.txt
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          git config user.name github-actions
							 
						 
					
						
							
								
									
										
										
										
											2020-07-14 20:30:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          git config user.email github-actions@github.com
							 
						 
					
						
							
								
									
										
										
										
											2020-07-14 17:08:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          git add .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          git commit -m "generated"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          git push
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-07-23 19:32:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# License
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The scripts and documentation in this project are released under the [MIT License ](LICENSE )