mirror of https://github.com/actions/checkout.git
				
				
				
			Merge branch 'main' into partial-fetch-filter-option
						commit
						edb1935aaa
					
				|  | @ -24,10 +24,10 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v3 |       - uses: actions/checkout@v3 | ||||||
| 
 | 
 | ||||||
|       - name: Set Node.js 16.x |       - name: Set Node.js 20.x | ||||||
|         uses: actions/setup-node@v1 |         uses: actions/setup-node@v1 | ||||||
|         with: |         with: | ||||||
|           node-version: 16.x |           node-version: 20.x | ||||||
| 
 | 
 | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         run: npm ci |         run: npm ci | ||||||
|  |  | ||||||
|  | @ -13,7 +13,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/setup-node@v1 |       - uses: actions/setup-node@v1 | ||||||
|         with: |         with: | ||||||
|           node-version: 16.x |           node-version: 20.x | ||||||
|       - uses: actions/checkout@v3 |       - uses: actions/checkout@v3 | ||||||
|       - run: npm ci |       - run: npm ci | ||||||
|       - run: npm run build |       - run: npm run build | ||||||
|  |  | ||||||
|  | @ -11,6 +11,7 @@ on: | ||||||
|         type: choice |         type: choice | ||||||
|         description: The major version to update |         description: The major version to update | ||||||
|         options: |         options: | ||||||
|  |           - v4 | ||||||
|           - v3 |           - v3 | ||||||
|           - v2 |           - v2 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,5 +1,13 @@ | ||||||
| # Changelog | # Changelog | ||||||
| 
 | 
 | ||||||
|  | ## v4.0.0 | ||||||
|  | - [Support fetching without the --progress option](https://github.com/actions/checkout/pull/1067) | ||||||
|  | - [Update to node20](https://github.com/actions/checkout/pull/1436) | ||||||
|  | 
 | ||||||
|  | ## v3.6.0 | ||||||
|  | - [Fix: Mark test scripts with Bash'isms to be run via Bash](https://github.com/actions/checkout/pull/1377) | ||||||
|  | - [Add option to fetch tags even if fetch-depth > 0](https://github.com/actions/checkout/pull/579) | ||||||
|  | 
 | ||||||
| ## v3.5.3 | ## v3.5.3 | ||||||
| - [Fix: Checkout fail in self-hosted runners when faulty submodule are checked-in](https://github.com/actions/checkout/pull/1196) | - [Fix: Checkout fail in self-hosted runners when faulty submodule are checked-in](https://github.com/actions/checkout/pull/1196) | ||||||
| - [Fix typos found by codespell](https://github.com/actions/checkout/pull/1287) | - [Fix typos found by codespell](https://github.com/actions/checkout/pull/1287) | ||||||
|  |  | ||||||
							
								
								
									
										47
									
								
								README.md
								
								
								
								
							
							
						
						
									
										47
									
								
								README.md
								
								
								
								
							|  | @ -1,6 +1,6 @@ | ||||||
| [](https://github.com/actions/checkout/actions/workflows/test.yml) | [](https://github.com/actions/checkout/actions/workflows/test.yml) | ||||||
| 
 | 
 | ||||||
| # Checkout V3 | # Checkout V4 | ||||||
| 
 | 
 | ||||||
| This action checks-out your repository under `$GITHUB_WORKSPACE`, so your workflow can access it. | This action checks-out your repository under `$GITHUB_WORKSPACE`, so your workflow can access it. | ||||||
| 
 | 
 | ||||||
|  | @ -12,14 +12,15 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| 
 | 
 | ||||||
| # What's new | # What's new | ||||||
| 
 | 
 | ||||||
| - Updated to the node16 runtime by default | - Updated default runtime to node20 | ||||||
|   - This requires a minimum [Actions Runner](https://github.com/actions/runner/releases/tag/v2.285.0) version of v2.285.0 to run, which is by default available in GHES 3.4 or later. |   - This requires a minimum Actions Runner version of [v2.308.0](https://github.com/actions/runner/releases/tag/v2.308.0). | ||||||
|  | - Added support for fetching without the `--progress` option | ||||||
| 
 | 
 | ||||||
| # Usage | # Usage | ||||||
| 
 | 
 | ||||||
| <!-- start usage --> | <!-- start usage --> | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     # Repository name with owner. For example, actions/checkout |     # Repository name with owner. For example, actions/checkout | ||||||
|     # Default: ${{ github.repository }} |     # Default: ${{ github.repository }} | ||||||
|  | @ -91,6 +92,14 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
|     # Default: 1 |     # Default: 1 | ||||||
|     fetch-depth: '' |     fetch-depth: '' | ||||||
| 
 | 
 | ||||||
|  |     # Whether to fetch tags, even if fetch-depth > 0. | ||||||
|  |     # Default: false | ||||||
|  |     fetch-tags: '' | ||||||
|  | 
 | ||||||
|  |     # Whether to show progress status output when fetching. | ||||||
|  |     # Default: true | ||||||
|  |     show-progress: '' | ||||||
|  | 
 | ||||||
|     # Whether to download Git-LFS files |     # Whether to download Git-LFS files | ||||||
|     # Default: false |     # Default: false | ||||||
|     lfs: '' |     lfs: '' | ||||||
|  | @ -135,7 +144,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| ## Fetch only the root files | ## Fetch only the root files | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     sparse-checkout: . |     sparse-checkout: . | ||||||
| ``` | ``` | ||||||
|  | @ -143,7 +152,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| ## Fetch only the root files and `.github` and `src` folder | ## Fetch only the root files and `.github` and `src` folder | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     sparse-checkout: | |     sparse-checkout: | | ||||||
|       .github |       .github | ||||||
|  | @ -153,7 +162,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| ## Fetch only a single file | ## Fetch only a single file | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     sparse-checkout: | |     sparse-checkout: | | ||||||
|       README.md |       README.md | ||||||
|  | @ -163,7 +172,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| ## Fetch all history for all tags and branches | ## Fetch all history for all tags and branches | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     fetch-depth: 0 |     fetch-depth: 0 | ||||||
| ``` | ``` | ||||||
|  | @ -171,7 +180,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| ## Checkout a different branch | ## Checkout a different branch | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     ref: my-branch |     ref: my-branch | ||||||
| ``` | ``` | ||||||
|  | @ -179,7 +188,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| ## Checkout HEAD^ | ## Checkout HEAD^ | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     fetch-depth: 2 |     fetch-depth: 2 | ||||||
| - run: git checkout HEAD^ | - run: git checkout HEAD^ | ||||||
|  | @ -189,12 +198,12 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| - name: Checkout | - name: Checkout | ||||||
|   uses: actions/checkout@v3 |   uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     path: main |     path: main | ||||||
| 
 | 
 | ||||||
| - name: Checkout tools repo | - name: Checkout tools repo | ||||||
|   uses: actions/checkout@v3 |   uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     repository: my-org/my-tools |     repository: my-org/my-tools | ||||||
|     path: my-tools |     path: my-tools | ||||||
|  | @ -205,10 +214,10 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| - name: Checkout | - name: Checkout | ||||||
|   uses: actions/checkout@v3 |   uses: actions/checkout@v4 | ||||||
| 
 | 
 | ||||||
| - name: Checkout tools repo | - name: Checkout tools repo | ||||||
|   uses: actions/checkout@v3 |   uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     repository: my-org/my-tools |     repository: my-org/my-tools | ||||||
|     path: my-tools |     path: my-tools | ||||||
|  | @ -219,12 +228,12 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| - name: Checkout | - name: Checkout | ||||||
|   uses: actions/checkout@v3 |   uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     path: main |     path: main | ||||||
| 
 | 
 | ||||||
| - name: Checkout private tools | - name: Checkout private tools | ||||||
|   uses: actions/checkout@v3 |   uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     repository: my-org/my-private-tools |     repository: my-org/my-private-tools | ||||||
|     token: ${{ secrets.GH_PAT }} # `GH_PAT` is a secret that contains your PAT |     token: ${{ secrets.GH_PAT }} # `GH_PAT` is a secret that contains your PAT | ||||||
|  | @ -237,7 +246,7 @@ When Git 2.18 or higher is not in your PATH, falls back to the REST API to downl | ||||||
| ## Checkout pull request HEAD commit instead of merge commit | ## Checkout pull request HEAD commit instead of merge commit | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/checkout@v3 | - uses: actions/checkout@v4 | ||||||
|   with: |   with: | ||||||
|     ref: ${{ github.event.pull_request.head.sha }} |     ref: ${{ github.event.pull_request.head.sha }} | ||||||
| ``` | ``` | ||||||
|  | @ -253,7 +262,7 @@ jobs: | ||||||
|   build: |   build: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v3 |       - uses: actions/checkout@v4 | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| ## Push a commit using the built-in token | ## Push a commit using the built-in token | ||||||
|  | @ -264,7 +273,7 @@ jobs: | ||||||
|   build: |   build: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v3 |       - uses: actions/checkout@v4 | ||||||
|       - run: | |       - run: | | ||||||
|           date > generated.txt |           date > generated.txt | ||||||
|           git config user.name github-actions |           git config user.name github-actions | ||||||
|  |  | ||||||
|  | @ -806,6 +806,8 @@ async function setup(testName: string): Promise<void> { | ||||||
|     sparseCheckout: [], |     sparseCheckout: [], | ||||||
|     sparseCheckoutConeMode: true, |     sparseCheckoutConeMode: true, | ||||||
|     fetchDepth: 1, |     fetchDepth: 1, | ||||||
|  |     fetchTags: false, | ||||||
|  |     showProgress: true, | ||||||
|     lfs: false, |     lfs: false, | ||||||
|     submodules: false, |     submodules: false, | ||||||
|     nestedSubmodules: false, |     nestedSubmodules: false, | ||||||
|  |  | ||||||
|  | @ -88,3 +88,291 @@ describe('git-auth-helper tests', () => { | ||||||
|     expect(branches.sort()).toEqual(['foo'].sort()) |     expect(branches.sort()).toEqual(['foo'].sort()) | ||||||
|   }) |   }) | ||||||
| }) | }) | ||||||
|  | 
 | ||||||
|  | describe('Test fetchDepth and fetchTags options', () => { | ||||||
|  |   beforeEach(async () => { | ||||||
|  |     jest.spyOn(fshelper, 'fileExistsSync').mockImplementation(jest.fn()) | ||||||
|  |     jest.spyOn(fshelper, 'directoryExistsSync').mockImplementation(jest.fn()) | ||||||
|  |     mockExec.mockImplementation((path, args, options) => { | ||||||
|  |       console.log(args, options.listeners.stdout) | ||||||
|  | 
 | ||||||
|  |       if (args.includes('version')) { | ||||||
|  |         options.listeners.stdout(Buffer.from('2.18')) | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       return 0 | ||||||
|  |     }) | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   afterEach(() => { | ||||||
|  |     jest.restoreAllMocks() | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   it('should call execGit with the correct arguments when fetchDepth is 0 and fetchTags is true', async () => { | ||||||
|  |     jest.spyOn(exec, 'exec').mockImplementation(mockExec) | ||||||
|  |     const workingDirectory = 'test' | ||||||
|  |     const lfs = false | ||||||
|  |     const doSparseCheckout = false | ||||||
|  |     git = await commandManager.createCommandManager( | ||||||
|  |       workingDirectory, | ||||||
|  |       lfs, | ||||||
|  |       doSparseCheckout | ||||||
|  |     ) | ||||||
|  | 
 | ||||||
|  |     const refSpec = ['refspec1', 'refspec2'] | ||||||
|  |     const options = { | ||||||
|  |       filter: 'filterValue', | ||||||
|  |       fetchDepth: 0, | ||||||
|  |       fetchTags: true | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     await git.fetch(refSpec, options) | ||||||
|  | 
 | ||||||
|  |     expect(mockExec).toHaveBeenCalledWith( | ||||||
|  |       expect.any(String), | ||||||
|  |       [ | ||||||
|  |         '-c', | ||||||
|  |         'protocol.version=2', | ||||||
|  |         'fetch', | ||||||
|  |         '--prune', | ||||||
|  |         '--no-recurse-submodules', | ||||||
|  |         '--filter=filterValue', | ||||||
|  |         'origin', | ||||||
|  |         'refspec1', | ||||||
|  |         'refspec2' | ||||||
|  |       ], | ||||||
|  |       expect.any(Object) | ||||||
|  |     ) | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   it('should call execGit with the correct arguments when fetchDepth is 0 and fetchTags is false', async () => { | ||||||
|  |     jest.spyOn(exec, 'exec').mockImplementation(mockExec) | ||||||
|  | 
 | ||||||
|  |     const workingDirectory = 'test' | ||||||
|  |     const lfs = false | ||||||
|  |     const doSparseCheckout = false | ||||||
|  |     git = await commandManager.createCommandManager( | ||||||
|  |       workingDirectory, | ||||||
|  |       lfs, | ||||||
|  |       doSparseCheckout | ||||||
|  |     ) | ||||||
|  |     const refSpec = ['refspec1', 'refspec2'] | ||||||
|  |     const options = { | ||||||
|  |       filter: 'filterValue', | ||||||
|  |       fetchDepth: 0, | ||||||
|  |       fetchTags: false | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     await git.fetch(refSpec, options) | ||||||
|  | 
 | ||||||
|  |     expect(mockExec).toHaveBeenCalledWith( | ||||||
|  |       expect.any(String), | ||||||
|  |       [ | ||||||
|  |         '-c', | ||||||
|  |         'protocol.version=2', | ||||||
|  |         'fetch', | ||||||
|  |         '--no-tags', | ||||||
|  |         '--prune', | ||||||
|  |         '--no-recurse-submodules', | ||||||
|  |         '--filter=filterValue', | ||||||
|  |         'origin', | ||||||
|  |         'refspec1', | ||||||
|  |         'refspec2' | ||||||
|  |       ], | ||||||
|  |       expect.any(Object) | ||||||
|  |     ) | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   it('should call execGit with the correct arguments when fetchDepth is 1 and fetchTags is false', async () => { | ||||||
|  |     jest.spyOn(exec, 'exec').mockImplementation(mockExec) | ||||||
|  | 
 | ||||||
|  |     const workingDirectory = 'test' | ||||||
|  |     const lfs = false | ||||||
|  |     const doSparseCheckout = false | ||||||
|  |     git = await commandManager.createCommandManager( | ||||||
|  |       workingDirectory, | ||||||
|  |       lfs, | ||||||
|  |       doSparseCheckout | ||||||
|  |     ) | ||||||
|  |     const refSpec = ['refspec1', 'refspec2'] | ||||||
|  |     const options = { | ||||||
|  |       filter: 'filterValue', | ||||||
|  |       fetchDepth: 1, | ||||||
|  |       fetchTags: false | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     await git.fetch(refSpec, options) | ||||||
|  | 
 | ||||||
|  |     expect(mockExec).toHaveBeenCalledWith( | ||||||
|  |       expect.any(String), | ||||||
|  |       [ | ||||||
|  |         '-c', | ||||||
|  |         'protocol.version=2', | ||||||
|  |         'fetch', | ||||||
|  |         '--no-tags', | ||||||
|  |         '--prune', | ||||||
|  |         '--no-recurse-submodules', | ||||||
|  |         '--filter=filterValue', | ||||||
|  |         '--depth=1', | ||||||
|  |         'origin', | ||||||
|  |         'refspec1', | ||||||
|  |         'refspec2' | ||||||
|  |       ], | ||||||
|  |       expect.any(Object) | ||||||
|  |     ) | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   it('should call execGit with the correct arguments when fetchDepth is 1 and fetchTags is true', async () => { | ||||||
|  |     jest.spyOn(exec, 'exec').mockImplementation(mockExec) | ||||||
|  | 
 | ||||||
|  |     const workingDirectory = 'test' | ||||||
|  |     const lfs = false | ||||||
|  |     const doSparseCheckout = false | ||||||
|  |     git = await commandManager.createCommandManager( | ||||||
|  |       workingDirectory, | ||||||
|  |       lfs, | ||||||
|  |       doSparseCheckout | ||||||
|  |     ) | ||||||
|  |     const refSpec = ['refspec1', 'refspec2'] | ||||||
|  |     const options = { | ||||||
|  |       filter: 'filterValue', | ||||||
|  |       fetchDepth: 1, | ||||||
|  |       fetchTags: true | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     await git.fetch(refSpec, options) | ||||||
|  | 
 | ||||||
|  |     expect(mockExec).toHaveBeenCalledWith( | ||||||
|  |       expect.any(String), | ||||||
|  |       [ | ||||||
|  |         '-c', | ||||||
|  |         'protocol.version=2', | ||||||
|  |         'fetch', | ||||||
|  |         '--prune', | ||||||
|  |         '--no-recurse-submodules', | ||||||
|  |         '--filter=filterValue', | ||||||
|  |         '--depth=1', | ||||||
|  |         'origin', | ||||||
|  |         'refspec1', | ||||||
|  |         'refspec2' | ||||||
|  |       ], | ||||||
|  |       expect.any(Object) | ||||||
|  |     ) | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   it('should call execGit with the correct arguments when showProgress is true', async () => { | ||||||
|  |     jest.spyOn(exec, 'exec').mockImplementation(mockExec) | ||||||
|  | 
 | ||||||
|  |     const workingDirectory = 'test' | ||||||
|  |     const lfs = false | ||||||
|  |     const doSparseCheckout = false | ||||||
|  |     git = await commandManager.createCommandManager( | ||||||
|  |       workingDirectory, | ||||||
|  |       lfs, | ||||||
|  |       doSparseCheckout | ||||||
|  |     ) | ||||||
|  |     const refSpec = ['refspec1', 'refspec2'] | ||||||
|  |     const options = { | ||||||
|  |       filter: 'filterValue', | ||||||
|  |       showProgress: true | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     await git.fetch(refSpec, options) | ||||||
|  | 
 | ||||||
|  |     expect(mockExec).toHaveBeenCalledWith( | ||||||
|  |       expect.any(String), | ||||||
|  |       [ | ||||||
|  |         '-c', | ||||||
|  |         'protocol.version=2', | ||||||
|  |         'fetch', | ||||||
|  |         '--no-tags', | ||||||
|  |         '--prune', | ||||||
|  |         '--no-recurse-submodules', | ||||||
|  |         '--progress', | ||||||
|  |         '--filter=filterValue', | ||||||
|  |         'origin', | ||||||
|  |         'refspec1', | ||||||
|  |         'refspec2' | ||||||
|  |       ], | ||||||
|  |       expect.any(Object) | ||||||
|  |     ) | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   it('should call execGit with the correct arguments when fetchDepth is 42 and showProgress is true', async () => { | ||||||
|  |     jest.spyOn(exec, 'exec').mockImplementation(mockExec) | ||||||
|  | 
 | ||||||
|  |     const workingDirectory = 'test' | ||||||
|  |     const lfs = false | ||||||
|  |     const doSparseCheckout = false | ||||||
|  |     git = await commandManager.createCommandManager( | ||||||
|  |       workingDirectory, | ||||||
|  |       lfs, | ||||||
|  |       doSparseCheckout | ||||||
|  |     ) | ||||||
|  |     const refSpec = ['refspec1', 'refspec2'] | ||||||
|  |     const options = { | ||||||
|  |       filter: 'filterValue', | ||||||
|  |       fetchDepth: 42, | ||||||
|  |       showProgress: true | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     await git.fetch(refSpec, options) | ||||||
|  | 
 | ||||||
|  |     expect(mockExec).toHaveBeenCalledWith( | ||||||
|  |       expect.any(String), | ||||||
|  |       [ | ||||||
|  |         '-c', | ||||||
|  |         'protocol.version=2', | ||||||
|  |         'fetch', | ||||||
|  |         '--no-tags', | ||||||
|  |         '--prune', | ||||||
|  |         '--no-recurse-submodules', | ||||||
|  |         '--progress', | ||||||
|  |         '--filter=filterValue', | ||||||
|  |         '--depth=42', | ||||||
|  |         'origin', | ||||||
|  |         'refspec1', | ||||||
|  |         'refspec2' | ||||||
|  |       ], | ||||||
|  |       expect.any(Object) | ||||||
|  |     ) | ||||||
|  |   }) | ||||||
|  | 
 | ||||||
|  |   it('should call execGit with the correct arguments when fetchTags is true and showProgress is true', async () => { | ||||||
|  |     jest.spyOn(exec, 'exec').mockImplementation(mockExec) | ||||||
|  | 
 | ||||||
|  |     const workingDirectory = 'test' | ||||||
|  |     const lfs = false | ||||||
|  |     const doSparseCheckout = false | ||||||
|  |     git = await commandManager.createCommandManager( | ||||||
|  |       workingDirectory, | ||||||
|  |       lfs, | ||||||
|  |       doSparseCheckout | ||||||
|  |     ) | ||||||
|  |     const refSpec = ['refspec1', 'refspec2'] | ||||||
|  |     const options = { | ||||||
|  |       filter: 'filterValue', | ||||||
|  |       fetchTags: true, | ||||||
|  |       showProgress: true | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     await git.fetch(refSpec, options) | ||||||
|  | 
 | ||||||
|  |     expect(mockExec).toHaveBeenCalledWith( | ||||||
|  |       expect.any(String), | ||||||
|  |       [ | ||||||
|  |         '-c', | ||||||
|  |         'protocol.version=2', | ||||||
|  |         'fetch', | ||||||
|  |         '--prune', | ||||||
|  |         '--no-recurse-submodules', | ||||||
|  |         '--progress', | ||||||
|  |         '--filter=filterValue', | ||||||
|  |         'origin', | ||||||
|  |         'refspec1', | ||||||
|  |         'refspec2' | ||||||
|  |       ], | ||||||
|  |       expect.any(Object) | ||||||
|  |     ) | ||||||
|  |   }) | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | @ -83,6 +83,8 @@ describe('input-helper tests', () => { | ||||||
|     expect(settings.sparseCheckout).toBe(undefined) |     expect(settings.sparseCheckout).toBe(undefined) | ||||||
|     expect(settings.sparseCheckoutConeMode).toBe(true) |     expect(settings.sparseCheckoutConeMode).toBe(true) | ||||||
|     expect(settings.fetchDepth).toBe(1) |     expect(settings.fetchDepth).toBe(1) | ||||||
|  |     expect(settings.fetchTags).toBe(false) | ||||||
|  |     expect(settings.showProgress).toBe(true) | ||||||
|     expect(settings.lfs).toBe(false) |     expect(settings.lfs).toBe(false) | ||||||
|     expect(settings.ref).toBe('refs/heads/some-ref') |     expect(settings.ref).toBe('refs/heads/some-ref') | ||||||
|     expect(settings.repositoryName).toBe('some-repo') |     expect(settings.repositoryName).toBe('some-repo') | ||||||
|  |  | ||||||
|  | @ -68,6 +68,12 @@ inputs: | ||||||
|   fetch-depth: |   fetch-depth: | ||||||
|     description: 'Number of commits to fetch. 0 indicates all history for all branches and tags.' |     description: 'Number of commits to fetch. 0 indicates all history for all branches and tags.' | ||||||
|     default: 1 |     default: 1 | ||||||
|  |   fetch-tags: | ||||||
|  |     description: 'Whether to fetch tags, even if fetch-depth > 0.' | ||||||
|  |     default: false | ||||||
|  |   show-progress: | ||||||
|  |     description: 'Whether to show progress status output when fetching.' | ||||||
|  |     default: true | ||||||
|   lfs: |   lfs: | ||||||
|     description: 'Whether to download Git-LFS files' |     description: 'Whether to download Git-LFS files' | ||||||
|     default: false |     default: false | ||||||
|  | @ -87,6 +93,6 @@ inputs: | ||||||
|     description: 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 |     description: 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 | ||||||
|     required: false |     required: false | ||||||
| runs: | runs: | ||||||
|   using: node16 |   using: node20 | ||||||
|   main: dist/index.js |   main: dist/index.js | ||||||
|   post: dist/index.js |   post: dist/index.js | ||||||
|  |  | ||||||
|  | @ -637,10 +637,13 @@ class GitCommandManager { | ||||||
|     fetch(refSpec, options) { |     fetch(refSpec, options) { | ||||||
|         return __awaiter(this, void 0, void 0, function* () { |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|             const args = ['-c', 'protocol.version=2', 'fetch']; |             const args = ['-c', 'protocol.version=2', 'fetch']; | ||||||
|             if (!refSpec.some(x => x === refHelper.tagsRefSpec)) { |             if (!refSpec.some(x => x === refHelper.tagsRefSpec) && !options.fetchTags) { | ||||||
|                 args.push('--no-tags'); |                 args.push('--no-tags'); | ||||||
|             } |             } | ||||||
|             args.push('--prune', '--progress', '--no-recurse-submodules'); |             args.push('--prune', '--no-recurse-submodules'); | ||||||
|  |             if (options.showProgress) { | ||||||
|  |                 args.push('--progress'); | ||||||
|  |             } | ||||||
|             if (options.filter) { |             if (options.filter) { | ||||||
|                 args.push(`--filter=${options.filter}`); |                 args.push(`--filter=${options.filter}`); | ||||||
|             } |             } | ||||||
|  | @ -718,8 +721,8 @@ class GitCommandManager { | ||||||
|     } |     } | ||||||
|     log1(format) { |     log1(format) { | ||||||
|         return __awaiter(this, void 0, void 0, function* () { |         return __awaiter(this, void 0, void 0, function* () { | ||||||
|             var args = format ? ['log', '-1', format] : ['log', '-1']; |             const args = format ? ['log', '-1', format] : ['log', '-1']; | ||||||
|             var silent = format ? false : true; |             const silent = format ? false : true; | ||||||
|             const output = yield this.execGit(args, false, silent); |             const output = yield this.execGit(args, false, silent); | ||||||
|             return output.stdout; |             return output.stdout; | ||||||
|         }); |         }); | ||||||
|  | @ -1260,6 +1263,7 @@ function getSource(settings) { | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
|                 fetchOptions.fetchDepth = settings.fetchDepth; |                 fetchOptions.fetchDepth = settings.fetchDepth; | ||||||
|  |                 fetchOptions.fetchTags = settings.fetchTags; | ||||||
|                 const refSpec = refHelper.getRefSpec(settings.ref, settings.commit); |                 const refSpec = refHelper.getRefSpec(settings.ref, settings.commit); | ||||||
|                 yield git.fetch(refSpec, fetchOptions); |                 yield git.fetch(refSpec, fetchOptions); | ||||||
|             } |             } | ||||||
|  | @ -1741,6 +1745,14 @@ function getInputs() { | ||||||
|             result.fetchDepth = 0; |             result.fetchDepth = 0; | ||||||
|         } |         } | ||||||
|         core.debug(`fetch depth = ${result.fetchDepth}`); |         core.debug(`fetch depth = ${result.fetchDepth}`); | ||||||
|  |         // Fetch tags
 | ||||||
|  |         result.fetchTags = | ||||||
|  |             (core.getInput('fetch-tags') || 'false').toUpperCase() === 'TRUE'; | ||||||
|  |         core.debug(`fetch tags = ${result.fetchTags}`); | ||||||
|  |         // Show fetch progress
 | ||||||
|  |         result.showProgress = | ||||||
|  |             (core.getInput('show-progress') || 'true').toUpperCase() === 'TRUE'; | ||||||
|  |         core.debug(`show progress = ${result.showProgress}`); | ||||||
|         // LFS
 |         // LFS
 | ||||||
|         result.lfs = (core.getInput('lfs') || 'false').toUpperCase() === 'TRUE'; |         result.lfs = (core.getInput('lfs') || 'false').toUpperCase() === 'TRUE'; | ||||||
|         core.debug(`lfs = ${result.lfs}`); |         core.debug(`lfs = ${result.lfs}`); | ||||||
|  |  | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							|  | @ -1,6 +1,6 @@ | ||||||
| { | { | ||||||
|   "name": "checkout", |   "name": "checkout", | ||||||
|   "version": "3.5.3", |   "version": "4.0.0", | ||||||
|   "description": "checkout action", |   "description": "checkout action", | ||||||
|   "main": "lib/main.js", |   "main": "lib/main.js", | ||||||
|   "scripts": { |   "scripts": { | ||||||
|  | @ -37,7 +37,7 @@ | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@types/jest": "^27.0.2", |     "@types/jest": "^27.0.2", | ||||||
|     "@types/node": "^12.7.12", |     "@types/node": "^20.5.3", | ||||||
|     "@types/uuid": "^3.4.6", |     "@types/uuid": "^3.4.6", | ||||||
|     "@typescript-eslint/eslint-plugin": "^5.45.0", |     "@typescript-eslint/eslint-plugin": "^5.45.0", | ||||||
|     "@typescript-eslint/parser": "^5.45.0", |     "@typescript-eslint/parser": "^5.45.0", | ||||||
|  |  | ||||||
|  | @ -33,6 +33,8 @@ export interface IGitCommandManager { | ||||||
|     options: { |     options: { | ||||||
|       filter?: string |       filter?: string | ||||||
|       fetchDepth?: number |       fetchDepth?: number | ||||||
|  |       fetchTags?: boolean | ||||||
|  |       showProgress?: boolean | ||||||
|     } |     } | ||||||
|   ): Promise<void> |   ): Promise<void> | ||||||
|   getDefaultBranch(repositoryUrl: string): Promise<string> |   getDefaultBranch(repositoryUrl: string): Promise<string> | ||||||
|  | @ -240,14 +242,22 @@ class GitCommandManager { | ||||||
| 
 | 
 | ||||||
|   async fetch( |   async fetch( | ||||||
|     refSpec: string[], |     refSpec: string[], | ||||||
|     options: {filter?: string; fetchDepth?: number} |     options: { | ||||||
|  |       filter?: string | ||||||
|  |       fetchDepth?: number | ||||||
|  |       fetchTags?: boolean | ||||||
|  |       showProgress?: boolean | ||||||
|  |     } | ||||||
|   ): Promise<void> { |   ): Promise<void> { | ||||||
|     const args = ['-c', 'protocol.version=2', 'fetch'] |     const args = ['-c', 'protocol.version=2', 'fetch'] | ||||||
|     if (!refSpec.some(x => x === refHelper.tagsRefSpec)) { |     if (!refSpec.some(x => x === refHelper.tagsRefSpec) && !options.fetchTags) { | ||||||
|       args.push('--no-tags') |       args.push('--no-tags') | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     args.push('--prune', '--progress', '--no-recurse-submodules') |     args.push('--prune', '--no-recurse-submodules') | ||||||
|  |     if (options.showProgress) { | ||||||
|  |       args.push('--progress') | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     if (options.filter) { |     if (options.filter) { | ||||||
|       args.push(`--filter=${options.filter}`) |       args.push(`--filter=${options.filter}`) | ||||||
|  | @ -333,8 +343,8 @@ class GitCommandManager { | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   async log1(format?: string): Promise<string> { |   async log1(format?: string): Promise<string> { | ||||||
|     var args = format ? ['log', '-1', format] : ['log', '-1'] |     const args = format ? ['log', '-1', format] : ['log', '-1'] | ||||||
|     var silent = format ? false : true |     const silent = format ? false : true | ||||||
|     const output = await this.execGit(args, false, silent) |     const output = await this.execGit(args, false, silent) | ||||||
|     return output.stdout |     return output.stdout | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  | @ -153,7 +153,12 @@ export async function getSource(settings: IGitSourceSettings): Promise<void> { | ||||||
| 
 | 
 | ||||||
|     // Fetch
 |     // Fetch
 | ||||||
|     core.startGroup('Fetching the repository') |     core.startGroup('Fetching the repository') | ||||||
|     const fetchOptions: {filter?: string; fetchDepth?: number} = {} |     const fetchOptions: { | ||||||
|  |       filter?: string | ||||||
|  |       fetchDepth?: number | ||||||
|  |       fetchTags?: boolean | ||||||
|  |       showProgress?: boolean | ||||||
|  |     } = {} | ||||||
| 
 | 
 | ||||||
|     if (settings.filter) { |     if (settings.filter) { | ||||||
|       fetchOptions.filter = settings.filter |       fetchOptions.filter = settings.filter | ||||||
|  | @ -177,6 +182,7 @@ export async function getSource(settings: IGitSourceSettings): Promise<void> { | ||||||
|       } |       } | ||||||
|     } else { |     } else { | ||||||
|       fetchOptions.fetchDepth = settings.fetchDepth |       fetchOptions.fetchDepth = settings.fetchDepth | ||||||
|  |       fetchOptions.fetchTags = settings.fetchTags | ||||||
|       const refSpec = refHelper.getRefSpec(settings.ref, settings.commit) |       const refSpec = refHelper.getRefSpec(settings.ref, settings.commit) | ||||||
|       await git.fetch(refSpec, fetchOptions) |       await git.fetch(refSpec, fetchOptions) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -49,6 +49,16 @@ export interface IGitSourceSettings { | ||||||
|    */ |    */ | ||||||
|   fetchDepth: number |   fetchDepth: number | ||||||
| 
 | 
 | ||||||
|  |   /** | ||||||
|  |    * Fetch tags, even if fetchDepth > 0 (default: false) | ||||||
|  |    */ | ||||||
|  |   fetchTags: boolean | ||||||
|  | 
 | ||||||
|  |   /** | ||||||
|  |    * Indicates whether to use the --progress option when fetching | ||||||
|  |    */ | ||||||
|  |   showProgress: boolean | ||||||
|  | 
 | ||||||
|   /** |   /** | ||||||
|    * Indicates whether to fetch LFS objects |    * Indicates whether to fetch LFS objects | ||||||
|    */ |    */ | ||||||
|  |  | ||||||
|  | @ -104,6 +104,16 @@ export async function getInputs(): Promise<IGitSourceSettings> { | ||||||
|   } |   } | ||||||
|   core.debug(`fetch depth = ${result.fetchDepth}`) |   core.debug(`fetch depth = ${result.fetchDepth}`) | ||||||
| 
 | 
 | ||||||
|  |   // Fetch tags
 | ||||||
|  |   result.fetchTags = | ||||||
|  |     (core.getInput('fetch-tags') || 'false').toUpperCase() === 'TRUE' | ||||||
|  |   core.debug(`fetch tags = ${result.fetchTags}`) | ||||||
|  | 
 | ||||||
|  |   // Show fetch progress
 | ||||||
|  |   result.showProgress = | ||||||
|  |     (core.getInput('show-progress') || 'true').toUpperCase() === 'TRUE' | ||||||
|  |   core.debug(`show progress = ${result.showProgress}`) | ||||||
|  | 
 | ||||||
|   // LFS
 |   // LFS
 | ||||||
|   result.lfs = (core.getInput('lfs') || 'false').toUpperCase() === 'TRUE' |   result.lfs = (core.getInput('lfs') || 'false').toUpperCase() === 'TRUE' | ||||||
|   core.debug(`lfs = ${result.lfs}`) |   core.debug(`lfs = ${result.lfs}`) | ||||||
|  |  | ||||||
|  | @ -120,7 +120,7 @@ function updateUsage( | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| updateUsage( | updateUsage( | ||||||
|   'actions/checkout@v3', |   'actions/checkout@v4', | ||||||
|   path.join(__dirname, '..', '..', 'action.yml'), |   path.join(__dirname, '..', '..', 'action.yml'), | ||||||
|   path.join(__dirname, '..', '..', 'README.md') |   path.join(__dirname, '..', '..', 'README.md') | ||||||
| ) | ) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue