From a496155e3e85a456118263408ad4a5e8b4e9756c Mon Sep 17 00:00:00 2001 From: Mitchell Hentges Date: Fri, 23 Sep 2022 16:56:38 +0200 Subject: [PATCH] Use sha1 instead of sha256 for hashing MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This should be more performant while still being FIPS compliant (see #12722). sha1 isn't as secure as sha256, but since the usage context is just "has this file changed? 🤔", this should be an acceptable degredation. pu Signed-off-by: Mitchell Hentges --- packages/babel-jest/src/index.ts | 2 +- packages/jest-circus/src/__mocks__/testUtils.ts | 2 +- packages/jest-config/src/__tests__/normalize.test.ts | 2 +- packages/jest-config/src/color.ts | 2 +- packages/jest-config/src/normalize.ts | 2 +- packages/jest-create-cache-key-function/src/index.ts | 4 ++-- packages/jest-haste-map/src/index.ts | 4 ++-- packages/jest-transform/src/ScriptTransformer.ts | 8 ++++---- 8 files changed, 13 insertions(+), 13 deletions(-) diff --git a/packages/babel-jest/src/index.ts b/packages/babel-jest/src/index.ts index cc51dbc4ea0d..151df90cad8b 100644 --- a/packages/babel-jest/src/index.ts +++ b/packages/babel-jest/src/index.ts @@ -78,7 +78,7 @@ function getCacheKeyFromConfig( const configPath = [babelOptions.config ?? '', babelOptions.babelrc ?? '']; - return createHash('sha256') + return createHash('sha1') .update(THIS_FILE) .update('\0', 'utf8') .update(JSON.stringify(babelOptions.options)) diff --git a/packages/jest-circus/src/__mocks__/testUtils.ts b/packages/jest-circus/src/__mocks__/testUtils.ts index 300159fd3e71..e68db421baa3 100644 --- a/packages/jest-circus/src/__mocks__/testUtils.ts +++ b/packages/jest-circus/src/__mocks__/testUtils.ts @@ -31,7 +31,7 @@ interface Result extends ExecaSyncReturnValue { } export const runTest = (source: string) => { - const filename = createHash('sha256') + const filename = createHash('sha1') .update(source) .digest('hex') .substring(0, 32); diff --git a/packages/jest-config/src/__tests__/normalize.test.ts b/packages/jest-config/src/__tests__/normalize.test.ts index 60176360650d..f5fc31b6cb14 100644 --- a/packages/jest-config/src/__tests__/normalize.test.ts +++ b/packages/jest-config/src/__tests__/normalize.test.ts @@ -72,7 +72,7 @@ afterEach(() => { it('picks an id based on the rootDir', async () => { const rootDir = '/root/path/foo'; - const expected = createHash('sha256') + const expected = createHash('sha1') .update('/root/path/foo') .update(String(Infinity)) .digest('hex') diff --git a/packages/jest-config/src/color.ts b/packages/jest-config/src/color.ts index dcb0534805cb..37595329be0c 100644 --- a/packages/jest-config/src/color.ts +++ b/packages/jest-config/src/color.ts @@ -25,7 +25,7 @@ export const getDisplayNameColor = (seed?: string): Color => { return 'white'; } - const hash = createHash('sha256'); + const hash = createHash('sha1'); hash.update(seed); const num = hash.digest().readUInt32LE(0); return colors[num % colors.length]; diff --git a/packages/jest-config/src/normalize.ts b/packages/jest-config/src/normalize.ts index d20a36437d1b..c69dfac5c61c 100644 --- a/packages/jest-config/src/normalize.ts +++ b/packages/jest-config/src/normalize.ts @@ -301,7 +301,7 @@ const normalizeMissingOptions = ( projectIndex: number, ): Config.InitialOptionsWithRootDir => { if (!options.id) { - options.id = createHash('sha256') + options.id = createHash('sha1') .update(options.rootDir) // In case we load config from some path that has the same root dir .update(configPath || '') diff --git a/packages/jest-create-cache-key-function/src/index.ts b/packages/jest-create-cache-key-function/src/index.ts index 835edc088885..4c056f30e0d8 100644 --- a/packages/jest-create-cache-key-function/src/index.ts +++ b/packages/jest-create-cache-key-function/src/index.ts @@ -49,7 +49,7 @@ function getGlobalCacheKey(files: Array, values: Array) { ] .reduce( (hash, chunk) => hash.update('\0', 'utf8').update(chunk || ''), - createHash('sha256'), + createHash('sha1'), ) .digest('hex') .substring(0, 32); @@ -62,7 +62,7 @@ function getCacheKeyFunction(globalCacheKey: string): GetCacheKeyFunction { const inferredOptions = options || configString; const {config, instrument} = inferredOptions; - return createHash('sha256') + return createHash('sha1') .update(globalCacheKey) .update('\0', 'utf8') .update(sourceText) diff --git a/packages/jest-haste-map/src/index.ts b/packages/jest-haste-map/src/index.ts index 1ab221bbe82a..5c3458c96686 100644 --- a/packages/jest-haste-map/src/index.ts +++ b/packages/jest-haste-map/src/index.ts @@ -295,7 +295,7 @@ class HasteMap extends EventEmitter implements IHasteMap { } private async setupCachePath(options: Options): Promise { - const rootDirHash = createHash('sha256') + const rootDirHash = createHash('sha1') .update(options.rootDir) .digest('hex') .substring(0, 32); @@ -344,7 +344,7 @@ class HasteMap extends EventEmitter implements IHasteMap { id: string, ...extra: Array ): string { - const hash = createHash('sha256').update(extra.join('')); + const hash = createHash('sha1').update(extra.join('')); return path.join( tmpdir, `${id.replace(/\W/g, '-')}-${hash.digest('hex').substring(0, 32)}`, diff --git a/packages/jest-transform/src/ScriptTransformer.ts b/packages/jest-transform/src/ScriptTransformer.ts index 695584fdf79b..82df9931f7fa 100644 --- a/packages/jest-transform/src/ScriptTransformer.ts +++ b/packages/jest-transform/src/ScriptTransformer.ts @@ -117,14 +117,14 @@ class ScriptTransformer { transformerCacheKey: string | undefined, ): string { if (transformerCacheKey != null) { - return createHash('sha256') + return createHash('sha1') .update(transformerCacheKey) .update(CACHE_VERSION) .digest('hex') .substring(0, 32); } - return createHash('sha256') + return createHash('sha1') .update(fileData) .update(transformOptions.configString) .update(transformOptions.instrument ? 'instrument' : '') @@ -882,7 +882,7 @@ const stripShebang = (content: string) => { * could get corrupted, out-of-sync, etc. */ function writeCodeCacheFile(cachePath: string, code: string) { - const checksum = createHash('sha256') + const checksum = createHash('sha1') .update(code) .digest('hex') .substring(0, 32); @@ -901,7 +901,7 @@ function readCodeCacheFile(cachePath: string): string | null { return null; } const code = content.substring(33); - const checksum = createHash('sha256') + const checksum = createHash('sha1') .update(code) .digest('hex') .substring(0, 32);