Skip to content

Commit

Permalink
fix(bundling): always generate package.json when using @nx/rollup:rollup
Browse files Browse the repository at this point in the history
  • Loading branch information
jaysoo committed Jul 15, 2024
1 parent 6f50d9f commit 363cbdd
Show file tree
Hide file tree
Showing 4 changed files with 44 additions and 6 deletions.
21 changes: 21 additions & 0 deletions e2e/rollup/src/rollup-legacy.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -198,4 +198,25 @@ describe('Rollup Plugin', () => {

checkFilesExist(`dist/test/index.js`);
});

it('should always generate package.json even if the plugin is removed from rollup config file (Nx < 19.4 behavior)', () => {
const jsLib = uniq('jslib');
runCLI(`generate @nx/js:lib ${jsLib} --bundler rollup --verbose`);
updateFile(
`libs/${jsLib}/rollup.config.js`,
`module.exports = (config) => ({
...config,
// Filter out the plugin, but the @nx/rollup:rollup executor should add it back
plugins: config.plugins.filter((p) => p.name !== 'rollup-plugin-nx-generate-package-json'),
})`
);
updateJson(join('libs', jsLib, 'project.json'), (config) => {
config.targets.build.options.rollupConfig = `libs/${jsLib}/rollup.config.js`;
return config;
});

expect(() => runCLI(`build ${jsLib}`)).not.toThrow();

checkFilesExist(`dist/libs/${jsLib}/package.json`);
});
});
20 changes: 20 additions & 0 deletions packages/rollup/src/executors/rollup/rollup.impl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import {
import { loadConfigFile } from '@nx/devkit/src/utils/config-utils';
import { createAsyncIterable } from '@nx/devkit/src/utils/async-iterable';
import { withNx } from '../../plugins/with-nx/with-nx';
import { pluginName as generatePackageJsonPluginName } from '../../plugins/package-json/generate-package-json';
import { calculateProjectBuildableDependencies } from '@nx/js/src/utils/buildable-libs-utils';

export async function* rollupExecutor(
Expand Down Expand Up @@ -100,6 +101,14 @@ export async function createRollupOptions(

const rollupConfig = withNx(options, {}, dependencies);

// `generatePackageJson` is a plugin rather than being embedded into @nx/rollup:rollup.
// Make sure the plugin is always present to keep the previous before of Nx < 19.4, where it was not a plugin.
const generatePackageJsonPlugin = Array.isArray(rollupConfig.plugins)
? rollupConfig.plugins.find(
(p) => p['name'] === generatePackageJsonPluginName
)
: null;

const userDefinedRollupConfigs = options.rollupConfig.map((plugin) =>
loadConfigFile(plugin)
);
Expand All @@ -122,6 +131,17 @@ export async function createRollupOptions(
};
}
}

if (
generatePackageJsonPlugin &&
Array.isArray(finalConfig.plugins) &&
!finalConfig.plugins.some(
(p) => p['name'] === generatePackageJsonPluginName
)
) {
finalConfig.plugins.push(generatePackageJsonPlugin);
}

return finalConfig;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,14 @@ export interface GeneratePackageJsonOptions {
additionalEntryPoints?: string[];
}

export const pluginName = 'rollup-plugin-nx-generate-package-json';

export function generatePackageJson(
options: GeneratePackageJsonOptions,
packageJson: PackageJson
): Plugin {
return {
name: 'rollup-plugin-nx-generate-package-json',
name: pluginName,
writeBundle: () => {
updatePackageJson(options, packageJson);
},
Expand Down
5 changes: 0 additions & 5 deletions packages/rollup/src/plugins/with-nx/with-nx.ts
Original file line number Diff line number Diff line change
Expand Up @@ -286,15 +286,10 @@ function createTsCompilerOptions(
options: RollupWithNxPluginOptions,
dependencies?: DependentBuildableProjectNode[]
) {
const compilerOptionPaths = computeCompilerOptionsPaths(
config,
dependencies ?? []
);
const compilerOptions = {
rootDir: projectRoot,
allowJs: options.allowJs,
declaration: true,
paths: compilerOptionPaths,
};
if (config.options.module === ts.ModuleKind.CommonJS) {
compilerOptions['module'] = 'ESNext';
Expand Down

0 comments on commit 363cbdd

Please sign in to comment.