mirror of
				https://code.forgejo.org/actions/cache.git
				synced 2025-10-26 02:24:36 +00:00 
			
		
		
		
	Update tests for deleteCacheByKey.
And rebuild. Signed-off-by: Gregorio Litenstein <g.litenstein@gmail.com>
This commit is contained in:
		
							parent
							
								
									debc4e75e7
								
							
						
					
					
						commit
						4043ab8d77
					
				
					 8 changed files with 7163 additions and 4838 deletions
				
			
		|  | @ -1,6 +1,5 @@ | |||
| import * as cache from "@actions/cache"; | ||||
| import * as core from "@actions/core"; | ||||
| import { RequestError } from "@octokit/request-error"; | ||||
| import nock from "nock"; | ||||
| 
 | ||||
| import { Events, RefKey } from "../src/constants"; | ||||
|  | @ -214,7 +213,7 @@ test("getInputAsBool throws if required and value missing", () => { | |||
|     ).toThrowError(); | ||||
| }); | ||||
| 
 | ||||
| test("deleteCacheByKey returns 'HttpError: 404' when cache is not found.", async () => { | ||||
| test("deleteCacheByKey produces 'HttpError: 404' when cache is not found.", async () => { | ||||
|     const event = Events.Push; | ||||
| 
 | ||||
|     process.env["GITHUB_REPOSITORY"] = "owner/repo"; | ||||
|  | @ -232,14 +231,73 @@ test("deleteCacheByKey returns 'HttpError: 404' when cache is not found.", async | |||
|     expect(logWarningMock).toHaveBeenCalledWith( | ||||
|         expect.stringMatching(/404: Not Found/i) | ||||
|     ); | ||||
|     expect(response).toBeInstanceOf(RequestError); | ||||
|     expect(response).toMatchObject({ | ||||
|         name: "HttpError", | ||||
|         status: 404 | ||||
|     }); | ||||
|     expect(response).toBe(undefined); | ||||
| }); | ||||
| 
 | ||||
| test("deleteCacheByKey returns 'HttpError: 401' on an invalid non-mocked request.", async () => { | ||||
| test("deleteCacheByKey does not delete anything if it finds more than one entry for the given key.", async () => { | ||||
|     const event = Events.Push; | ||||
| 
 | ||||
|     process.env["GITHUB_REPOSITORY"] = "owner/repo"; | ||||
|     process.env["GITHUB_TOKEN"] = | ||||
|         "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"; | ||||
|     process.env["GITHUB_ACTION"] = "__owner___run-repo"; | ||||
|     process.env[Events.Key] = event; | ||||
|     process.env[RefKey] = ""; | ||||
|     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | ||||
|     const response = await actionUtils.deleteCacheByKey( | ||||
|         testUtils.failureCacheKey, | ||||
|         "owner", | ||||
|         "repo" | ||||
|     ); | ||||
|     expect(logWarningMock).toHaveBeenCalledWith( | ||||
|         `More than one cache entry found for key ${testUtils.failureCacheKey}` | ||||
|     ); | ||||
|     expect(response).toBe(undefined); | ||||
| }); | ||||
| 
 | ||||
| test("deleteCacheByKey does not delete anything if the key matches a cache belonging to another ref.", async () => { | ||||
|     const event = Events.Push; | ||||
| 
 | ||||
|     process.env["GITHUB_REPOSITORY"] = "owner/repo"; | ||||
|     process.env["GITHUB_TOKEN"] = | ||||
|         "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"; | ||||
|     process.env["GITHUB_ACTION"] = "__owner___run-repo"; | ||||
|     process.env[Events.Key] = event; | ||||
|     process.env[RefKey] = "ref/heads/feature"; | ||||
|     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | ||||
|     const response = await actionUtils.deleteCacheByKey( | ||||
|         testUtils.wrongRefCacheKey, | ||||
|         "owner", | ||||
|         "repo" | ||||
|     ); | ||||
|     expect(logWarningMock).toHaveBeenCalledWith( | ||||
|         `No cache entries for key ${testUtils.wrongRefCacheKey} belong to gitref ${process.env[RefKey]}.` | ||||
|     ); | ||||
|     expect(response).toBe(undefined); | ||||
| }); | ||||
| 
 | ||||
| test("deleteCacheByKey produces 'HttpError: 404' when cache is not found.", async () => { | ||||
|     const event = Events.Push; | ||||
| 
 | ||||
|     process.env["GITHUB_REPOSITORY"] = "owner/repo"; | ||||
|     process.env["GITHUB_TOKEN"] = | ||||
|         "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"; | ||||
|     process.env["GITHUB_ACTION"] = "__owner___run-repo"; | ||||
|     process.env[Events.Key] = event; | ||||
|     process.env[RefKey] = "ref/heads/feature"; | ||||
|     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | ||||
|     const response = await actionUtils.deleteCacheByKey( | ||||
|         testUtils.failureCacheKey, | ||||
|         "owner", | ||||
|         "repo" | ||||
|     ); | ||||
|     expect(logWarningMock).toHaveBeenCalledWith( | ||||
|         expect.stringMatching(/404: Not Found/i) | ||||
|     ); | ||||
|     expect(response).toBe(undefined); | ||||
| }); | ||||
| 
 | ||||
| test("deleteCacheByKey produces 'HttpError: 401' on an invalid non-mocked request.", async () => { | ||||
|     const event = Events.Push; | ||||
| 
 | ||||
|     process.env["GITHUB_REPOSITORY"] = "owner/repo"; | ||||
|  | @ -258,15 +316,11 @@ test("deleteCacheByKey returns 'HttpError: 401' on an invalid non-mocked request | |||
|     expect(logWarningMock).toHaveBeenCalledWith( | ||||
|         expect.stringMatching(/401: Bad Credentials/i) | ||||
|     ); | ||||
|     expect(response).toBeInstanceOf(RequestError); | ||||
|     expect(response).toMatchObject({ | ||||
|         name: "HttpError", | ||||
|         status: 401 | ||||
|     }); | ||||
|     expect(response).toBe(undefined); | ||||
|     nock.disableNetConnect(); | ||||
| }); | ||||
| 
 | ||||
| test("deleteCacheByKey returns matched cache data when successful.", async () => { | ||||
| test("deleteCacheByKey returns 204 / No Content when successful.", async () => { | ||||
|     const event = Events.Push; | ||||
| 
 | ||||
|     process.env["GITHUB_REPOSITORY"] = "owner/repo"; | ||||
|  | @ -276,29 +330,13 @@ test("deleteCacheByKey returns matched cache data when successful.", async () => | |||
|     process.env[Events.Key] = event; | ||||
|     process.env[RefKey] = "ref/heads/feature"; | ||||
| 
 | ||||
|     const expectedResponse = { | ||||
|         id: expect.any(Number), | ||||
|         ref: expect.any(String), | ||||
|         key: expect.any(String), | ||||
|         version: expect.any(String), | ||||
|         last_accessed_at: expect.any(String), | ||||
|         created_at: expect.any(String), | ||||
|         size_in_bytes: expect.any(Number) | ||||
|     }; | ||||
|     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | ||||
|     const response = await actionUtils.deleteCacheByKey( | ||||
|         testUtils.successCacheKey, | ||||
|         "owner", | ||||
|         "repo" | ||||
|     ); | ||||
|     expect(response).toMatchObject({ | ||||
|         data: expect.objectContaining({ | ||||
|             total_count: expect.any(Number), | ||||
|             actions_caches: expect.arrayContaining([ | ||||
|                 expect.objectContaining(expectedResponse) | ||||
|             ]) | ||||
|         }) | ||||
|     }); | ||||
|     expect(response).toBe(204); | ||||
|     expect(logWarningMock).toHaveBeenCalledTimes(0); | ||||
| }); | ||||
| 
 | ||||
|  |  | |||
|  | @ -492,7 +492,11 @@ test("save with cache hit and refresh-cache will try to delete and re-create ent | |||
|     ); | ||||
|     expect(infoMock).toHaveBeenNthCalledWith( | ||||
|         2, | ||||
|         `Succesfully deleted cache with key: ${primaryKey}` | ||||
|         expect.stringMatching( | ||||
|             new RegExp( | ||||
|                 `Succesfully deleted cache with key: ${primaryKey}, id: \\d+` | ||||
|             ) | ||||
|         ) | ||||
|     ); | ||||
|     expect(infoMock).toHaveBeenNthCalledWith( | ||||
|         3, | ||||
|  | @ -565,7 +569,11 @@ test("Granular save will use lookup to determine if cache needs to be updated or | |||
|     ); | ||||
|     expect(infoMock).toHaveBeenNthCalledWith( | ||||
|         2, | ||||
|         `Succesfully deleted cache with key: ${primaryKey}` | ||||
|         expect.stringMatching( | ||||
|             new RegExp( | ||||
|                 `Succesfully deleted cache with key: ${primaryKey}, id: \\d+` | ||||
|             ) | ||||
|         ) | ||||
|     ); | ||||
|     expect(infoMock).toHaveBeenNthCalledWith( | ||||
|         3, | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue