nx/packages/gradle/src/utils/get-project-report-lines.ts
Emily Xiong b8ee838e23
fix(gradle): log gradlew output for verbose (#29966)
<!-- Please make sure you have read the submission guidelines before
posting an PR -->
<!--
https://github.com/nrwl/nx/blob/master/CONTRIBUTING.md#-submitting-a-pr
-->

<!-- Please make sure that your commit message follows our format -->
<!-- Example: `fix(nx): must begin with lowercase` -->

<!-- If this is a particularly complex change or feature addition, you
can request a dedicated Nx release for this pull request branch. Mention
someone from the Nx team or the `@nrwl/nx-pipelines-reviewers` and they
will confirm if the PR warrants its own release for testing purposes,
and generate it for you if appropriate. -->

## Current Behavior
<!-- This is the behavior we have today -->

## Expected Behavior
<!-- This is the behavior we should expect with the changes in this PR
-->

## Related Issue(s)
<!-- Please link the issue being fixed so it gets closed when this is
merged. -->

Fixes #
2025-02-12 20:33:40 -05:00

103 lines
3.2 KiB
TypeScript

import { AggregateCreateNodesError, logger, output } from '@nx/devkit';
import { execGradleAsync } from './exec-gradle';
import { existsSync } from 'fs';
import { dirname, join } from 'path';
import { execSync } from 'child_process';
export const fileSeparator = process.platform.startsWith('win')
? 'file:///'
: 'file://';
export const newLineSeparator = process.platform.startsWith('win')
? '\r\n'
: '\n';
/**
* This function executes the gradle projectReportAll task and returns the output as an array of lines.
* @param gradlewFile the absolute path to the gradlew file
* @returns project report lines
*/
export async function getProjectReportLines(
gradlewFile: string
): Promise<string[]> {
let projectReportBuffer: Buffer;
// if there is no build.gradle or build.gradle.kts file, we cannot run the projectReport nor projectReportAll task
if (
!existsSync(join(dirname(gradlewFile), 'build.gradle')) &&
!existsSync(join(dirname(gradlewFile), 'build.gradle.kts'))
) {
logger.warn(
`Could not find build file near ${gradlewFile}. Please run 'nx generate @nx/gradle:init' to generate the necessary tasks.`
);
return [];
}
try {
projectReportBuffer = await execGradleAsync(gradlewFile, [
'projectReportAll',
process.env.NX_VERBOSE_LOGGING === 'true' ? '--info' : '',
]);
} catch (e: Buffer | Error | any) {
if (e.toString()?.includes('ERROR: JAVA_HOME')) {
throw new AggregateCreateNodesError(
[
[
gradlewFile,
new Error(
`Could not find Java. Please install Java and try again: https://www.java.com/en/download/help/index_installing.html.\n\r${e.toString()}`
),
],
],
[]
);
} else if (e.toString()?.includes(`Task 'projectReportAll' not found`)) {
try {
projectReportBuffer = await execGradleAsync(gradlewFile, [
'projectReport',
]);
logger.warn(
`Could not run 'projectReportAll' task. Ran 'projectReport' instead. Please run 'nx generate @nx/gradle:init' to generate the necessary tasks.\n\r${e.toString()}`
);
} catch (e) {
throw new AggregateCreateNodesError(
[
[
gradlewFile,
new Error(
`Could not run 'projectReportAll' or 'projectReport' task. Please run 'nx generate @nx/gradle:init' to generate the necessary tasks.\n\r${e.toString()}`
),
],
],
[]
);
}
} else {
throw new AggregateCreateNodesError(
[
[
gradlewFile,
new Error(
`Could not run 'projectReportAll' or 'projectReport' Gradle task. Please install Gradle and try again: https://gradle.org/install/.\r\n${e.toString()}`
),
],
],
[]
);
}
}
const projectReportLines = projectReportBuffer
.toString()
.split(newLineSeparator)
.filter((line) => line.trim() !== '');
if (process.env.NX_VERBOSE_LOGGING === 'true') {
output.log({
title: `Successfully ran projectReportAll or projectRerport task using ${gradlewFile}`,
bodyLines: projectReportLines,
});
}
return projectReportLines;
}