mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-25 14:06:27 +00:00
fix(cache): add extract revision, stop deleting skipReason (#33172)
This commit is contained in:
parent
3b9464c8fa
commit
8ae744857c
3 changed files with 43 additions and 6 deletions
1
lib/util/cache/repository/types.ts
vendored
1
lib/util/cache/repository/types.ts
vendored
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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,
|
||||||
|
|
Loading…
Reference in a new issue