From 507026625b798360523aed78d32d37151e1a57e9 Mon Sep 17 00:00:00 2001 From: Azlam <43767972+azlam-abdulsalam@users.noreply.github.com> Date: Tue, 9 Jan 2024 17:36:16 +1100 Subject: [PATCH] fix(diff):various fixes in diff to support branch compare - Mimic files changed in PR by most ci/cd systems using .. - Ignore packages with no tags unless they are modified --- .../src/core/package/diff/PackageDiffImpl.ts | 36 +++++++++++++++---- 1 file changed, 29 insertions(+), 7 deletions(-) diff --git a/packages/sfp-cli/src/core/package/diff/PackageDiffImpl.ts b/packages/sfp-cli/src/core/package/diff/PackageDiffImpl.ts index 89a954c1b..21fe44c24 100644 --- a/packages/sfp-cli/src/core/package/diff/PackageDiffImpl.ts +++ b/packages/sfp-cli/src/core/package/diff/PackageDiffImpl.ts @@ -57,7 +57,7 @@ export default class PackageDiffImpl { try { if(this.diffOptions?.useBranchCompare) { - modified_files = await git.diff(['--name-only', `${this.diffOptions.baseBranch}...${this.diffOptions.branch}`]); + modified_files = await git.diff(['--name-only', `${this.diffOptions.baseBranch}..${this.diffOptions.branch}`]); } else { @@ -107,12 +107,34 @@ export default class PackageDiffImpl { return { isToBeBuilt: false, reason: `No changes found`, tag: tag }; } else { - SFPLogger.log( - `Tag missing for ${this.sfdx_package}...marking package for build anyways`, - LoggerLevel.TRACE, - this.logger - ); - return { isToBeBuilt: true, reason: `Previous version not found` }; + + if(this.diffOptions?.useBranchCompare) + { + let modified_files = await git.diff(['--name-only', `${this.diffOptions.baseBranch}..${this.diffOptions.branch}`]); + // Check whether the package has been modified + for (let filename of modified_files) { + + let normalizedPkgPath = path.normalize(pkgDescriptor.path); + let normalizedFilename = path.normalize(filename); + + let relativePath = path.relative(normalizedPkgPath, normalizedFilename); + + if (!relativePath.startsWith('..')) { + SFPLogger.log(`Found change(s) in ${filename}`, LoggerLevel.TRACE, this.logger); + return { isToBeBuilt: true, reason: `Found change(s) in package`, tag: tag }; + } + } + return { isToBeBuilt: false, reason: `No changes found`, tag: tag }; + + } + else { + SFPLogger.log( + `Tag missing for ${this.sfdx_package}...marking package for build anyways`, + LoggerLevel.TRACE, + this.logger + ); + return { isToBeBuilt: true, reason: `Previous version not found` }; + } } }