From 6e84322e960a535ea14eee732d59c69f1a2ecbf0 Mon Sep 17 00:00:00 2001 From: ghe Date: Tue, 23 Mar 2021 18:57:46 +0000 Subject: [PATCH] feat: fix individual file with provenance --- .../extract-version-provenance.ts | 3 ++- .../python/handlers/pip-requirements/index.ts | 17 ++++++++++------- 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/packages/snyk-fix/src/plugins/python/handlers/pip-requirements/extract-version-provenance.ts b/packages/snyk-fix/src/plugins/python/handlers/pip-requirements/extract-version-provenance.ts index b75f98d8ee..f623979553 100644 --- a/packages/snyk-fix/src/plugins/python/handlers/pip-requirements/extract-version-provenance.ts +++ b/packages/snyk-fix/src/plugins/python/handlers/pip-requirements/extract-version-provenance.ts @@ -20,7 +20,8 @@ export async function extractProvenance( fileName: string, provenance: PythonProvenance = {}, ): Promise { - const requirementsTxt = await workspace.readFile(path.join(dir, fileName)); + const requirementsFileName = path.join(dir, fileName); + const requirementsTxt = await workspace.readFile(requirementsFileName); provenance = { ...provenance, [fileName]: parseRequirementsFile(requirementsTxt), diff --git a/packages/snyk-fix/src/plugins/python/handlers/pip-requirements/index.ts b/packages/snyk-fix/src/plugins/python/handlers/pip-requirements/index.ts index 2b457a64e7..e12c2cacf7 100644 --- a/packages/snyk-fix/src/plugins/python/handlers/pip-requirements/index.ts +++ b/packages/snyk-fix/src/plugins/python/handlers/pip-requirements/index.ts @@ -1,4 +1,5 @@ import * as debugLib from 'debug'; +import * as pathLib from 'path'; import { EntityToFix, @@ -11,7 +12,7 @@ import { MissingRemediationDataError } from '../../../../lib/errors/missing-reme import { MissingFileNameError } from '../../../../lib/errors/missing-file-name'; import { partitionByFixable } from './is-supported'; import { NoFixesCouldBeAppliedError } from '../../../../lib/errors/no-fixes-applied'; -import { parseRequirementsFile } from './update-dependencies/requirements-file-parser'; +import { extractProvenance } from './extract-version-provenance'; const debug = debugLib('snyk-fix:python:requirements.txt'); @@ -53,17 +54,19 @@ export async function fixIndividualRequirementsTxt( if (!fileName) { throw new MissingFileNameError(); } - const requirementsTxt = await entity.workspace.readFile(fileName); - const requirementsData = parseRequirementsFile(requirementsTxt); - + const { dir, base } = pathLib.parse(fileName); + const versionProvenance = await extractProvenance( + entity.workspace, + dir, + base, + ); // TODO: allow handlers per fix type (later also strategies or combine with strategies) const { updatedManifest, changes } = updateDependencies( - requirementsData, + versionProvenance[base], remediationData.pin, ); - // TODO: do this with the changes now that we only return new - if (updatedManifest === requirementsTxt) { + if (!changes.length) { debug('Manifest has not changed!'); throw new NoFixesCouldBeAppliedError(); }