Skip to content

Commit

Permalink
fix: make the export-dynamic-plugin command more generic
Browse files Browse the repository at this point in the history
for backend plugins.

Signed-off-by: David Festal <[email protected]>
  • Loading branch information
davidfestal committed Nov 22, 2023
1 parent dacd46d commit 3f5de34
Showing 1 changed file with 20 additions and 12 deletions.
32 changes: 20 additions & 12 deletions packages/cli/src/commands/export-dynamic-plugin/backend.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,15 @@ import fs from 'fs-extra';
import { rollup } from 'rollup';
import * as semver from 'semver';

import { execSync } from 'child_process';
import path, { basename } from 'path';

import { Output } from '../../lib/builder';
import { makeRollupConfigs } from '../../lib/builder/config';
import { embedModules } from '../../lib/builder/embedPlugin';
import { buildPackage, formatErrorMessage } from '../../lib/builder/packager';
import { loadCliConfig } from '../../lib/config';
import { readEntryPoints } from '../../lib/entryPoints';
import { productionPack } from '../../lib/packager/productionPack';
import { paths } from '../../lib/paths';
import { Task } from '../../lib/tasks';
Expand All @@ -38,8 +40,8 @@ export async function backend(
opts: OptionValues,
): Promise<void> {
if (!fs.existsSync(paths.resolveTarget('src', 'dynamic'))) {
throw new Error(
`Package doesn't seem to support dynamic loading. It should have a src/dynamic folder, containing the dynamic loading entrypoints.`,
console.warn(
`Package doesn't seem to provide dynamic loading entrypoints. You might want to add dynamic loading entrypoints in a src/dynamic folder.`,
);
}

Expand All @@ -65,13 +67,18 @@ export async function backend(

const target = path.join(paths.targetDir, 'dist-dynamic');

if (
!pkg.files?.includes('dist-dynamic/*.*') ||
!pkg.files?.includes('dist-dynamic/dist/**') ||
!pkg.files?.includes('dist-dynamic/alpha/*')
) {
throw new Error(
`Package doesn't seem to support dynamic loading: its "files" property should include the following entries: ["dist-dynamic/*.*", "dist-dynamic/dist/**", "dist-dynamic/alpha/*"].`,
const requiredFiles = ['dist-dynamic/*.*', 'dist-dynamic/dist/**'];

const entryPoints = readEntryPoints(pkg);
if (entryPoints.find(e => e.mount === './alpha')) {
requiredFiles.push('dist-dynamic/alpha/*');
}

if (requiredFiles.some(f => !pkg.files?.includes(f))) {
console.warn(
`Package doesn't seem to fully support dynamic loading: its "files" property should include the following entries: [${requiredFiles
.map(f => `"${f}"`)
.join(', ')}].`,
);
}

Expand Down Expand Up @@ -332,9 +339,10 @@ export async function backend(
}

if (opts.install) {
const yarnInstall = `yarn install --production${
yarnLockExists ? ' --frozen-lockfile' : ''
}`;
const version = execSync('yarn --version').toString().trim();
const yarnInstall = version.startsWith('1.')
? `yarn install --production${yarnLockExists ? ' --frozen-lockfile' : ''}`
: `yarn install${yarnLockExists ? ' --immutable' : ''}`;

await Task.forCommand(yarnInstall, { cwd: target, optional: false });
await fs.remove(paths.resolveTarget('dist-dynamic', '.yarn'));
Expand Down

0 comments on commit 3f5de34

Please sign in to comment.