fix(cache): add extract revision, stop deleting skipReason (#33172)

This commit is contained in:
Rhys Arkins 2024-12-17 17:41:41 +01:00 committed by GitHub
parent 3b9464c8fa
commit 8ae744857c
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 43 additions and 6 deletions

View file

@ -8,6 +8,7 @@ import type { RepoInitConfig } from '../../../workers/repository/init/types';
import type { PrBlockedBy } from '../../../workers/types'; import type { PrBlockedBy } from '../../../workers/types';
export interface BaseBranchCache { export interface BaseBranchCache {
revision?: number;
sha: string; // branch commit sha sha: string; // branch commit sha
configHash: string; // object hash of config configHash: string; // object hash of config
extractionFingerprints: Record<string, string | undefined>; // matching manager fingerprints extractionFingerprints: Record<string, string | undefined>; // matching manager fingerprints

View file

@ -6,7 +6,13 @@ import { fingerprint } from '../../../util/fingerprint';
import type { LongCommitSha } from '../../../util/git/types'; import type { LongCommitSha } from '../../../util/git/types';
import { generateFingerprintConfig } from '../extract/extract-fingerprint-config'; import { generateFingerprintConfig } from '../extract/extract-fingerprint-config';
import * as _branchify from '../updates/branchify'; import * as _branchify from '../updates/branchify';
import { extract, isCacheExtractValid, lookup, update } from './extract-update'; import {
EXTRACT_CACHE_REVISION,
extract,
isCacheExtractValid,
lookup,
update,
} from './extract-update';
const createVulnerabilitiesMock = jest.fn(); const createVulnerabilitiesMock = jest.fn();
@ -97,6 +103,7 @@ describe('workers/repository/process/extract-update', () => {
repositoryCache.getCache.mockReturnValueOnce({ repositoryCache.getCache.mockReturnValueOnce({
scan: { scan: {
master: { master: {
revision: EXTRACT_CACHE_REVISION,
sha: '123test', sha: '123test',
configHash: fingerprint(generateFingerprintConfig(config)), configHash: fingerprint(generateFingerprintConfig(config)),
extractionFingerprints: {}, extractionFingerprints: {},
@ -150,6 +157,7 @@ describe('workers/repository/process/extract-update', () => {
beforeEach(() => { beforeEach(() => {
cachedExtract = { cachedExtract = {
revision: EXTRACT_CACHE_REVISION,
sha: 'sha', sha: 'sha',
configHash: undefined as never, configHash: undefined as never,
extractionFingerprints: {}, extractionFingerprints: {},
@ -162,6 +170,18 @@ describe('workers/repository/process/extract-update', () => {
expect(logger.logger.debug).toHaveBeenCalledTimes(0); expect(logger.logger.debug).toHaveBeenCalledTimes(0);
}); });
it('returns false if no revision', () => {
delete cachedExtract.revision;
expect(isCacheExtractValid('sha', 'hash', cachedExtract)).toBe(false);
expect(logger.logger.debug).toHaveBeenCalledTimes(1);
});
it('returns false if revision mismatch', () => {
cachedExtract.revision = -1;
expect(isCacheExtractValid('sha', 'hash', cachedExtract)).toBe(false);
expect(logger.logger.debug).toHaveBeenCalledTimes(1);
});
it('partial cache', () => { it('partial cache', () => {
expect(isCacheExtractValid('sha', 'hash', cachedExtract)).toBe(false); expect(isCacheExtractValid('sha', 'hash', cachedExtract)).toBe(false);
expect(logger.logger.debug).toHaveBeenCalledTimes(0); expect(logger.logger.debug).toHaveBeenCalledTimes(0);

View file

@ -18,6 +18,9 @@ import { Vulnerabilities } from './vulnerabilities';
import type { WriteUpdateResult } from './write'; import type { WriteUpdateResult } from './write';
import { writeUpdates } from './write'; import { writeUpdates } from './write';
// Increment this if needing to cache bust ALL extract caches
export const EXTRACT_CACHE_REVISION = 1;
export interface ExtractResult { export interface ExtractResult {
branches: BranchConfig[]; branches: BranchConfig[];
branchList: string[]; branchList: string[];
@ -69,7 +72,23 @@ export function isCacheExtractValid(
configHash: string, configHash: string,
cachedExtract?: BaseBranchCache, cachedExtract?: BaseBranchCache,
): boolean { ): boolean {
if (!(cachedExtract?.sha && cachedExtract.configHash)) { if (!cachedExtract) {
return false;
}
if (!cachedExtract.revision) {
logger.debug('Cached extract is missing revision, so cannot be used');
return false;
}
if (cachedExtract.revision !== EXTRACT_CACHE_REVISION) {
logger.debug(
`Extract cache revision has changed (old=${cachedExtract.revision}, new=${EXTRACT_CACHE_REVISION})`,
);
return false;
}
if (!(cachedExtract.sha && cachedExtract.configHash)) {
return false; return false;
} }
if (cachedExtract.sha !== baseBranchSha) { if (cachedExtract.sha !== baseBranchSha) {
@ -128,10 +147,6 @@ export async function extract(
for (const file of files) { for (const file of files) {
for (const dep of file.deps) { for (const dep of file.deps) {
delete dep.updates; delete dep.updates;
if (dep.skipStage && dep.skipStage !== 'extract') {
delete dep.skipReason;
delete dep.skipStage;
}
} }
} }
} }
@ -146,6 +161,7 @@ export async function extract(
const { extractionFingerprints } = extractResult; const { extractionFingerprints } = extractResult;
// TODO: fix types (#22198) // TODO: fix types (#22198)
cache.scan[baseBranch!] = { cache.scan[baseBranch!] = {
revision: EXTRACT_CACHE_REVISION,
sha: baseBranchSha!, sha: baseBranchSha!,
configHash, configHash,
extractionFingerprints, extractionFingerprints,