Skip to content

Commit

Permalink
fix: do not copy public dir for node target by default (#4281)
Browse files Browse the repository at this point in the history
  • Loading branch information
9aoy authored Dec 30, 2024
1 parent d5d9be1 commit 0f1504d
Show file tree
Hide file tree
Showing 6 changed files with 86 additions and 10 deletions.
46 changes: 46 additions & 0 deletions e2e/cases/server/public-dir/publicDir.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -191,6 +191,14 @@ test('should copy publicDir to the environment distDir when multiple environment
},
},
},
node: {
output: {
target: 'node',
distPath: {
root: 'dist-build-node',
},
},
},
},
},
});
Expand All @@ -207,6 +215,44 @@ test('should copy publicDir to the environment distDir when multiple environment
filename.includes('dist-build-web-2/test-temp-file.txt'),
),
).toBeTruthy();
expect(
filenames.some((filename) =>
filename.includes('dist-build-node/test-temp-file.txt'),
),
).toBeFalsy();
});

test('should copy publicDir to the node distDir when copyOnBuild is specified as true', async () => {
await fse.outputFile(join(__dirname, 'public', 'test-temp-file.txt'), 'a');

const rsbuild = await build({
cwd,
rsbuildConfig: {
server: {
publicDir: {
copyOnBuild: true,
},
},
environments: {
node: {
output: {
target: 'node',
distPath: {
root: 'dist-build-node-1',
},
},
},
},
},
});
const files = await rsbuild.unwrapOutputJSON();
const filenames = Object.keys(files);

expect(
filenames.some((filename) =>
filename.includes('dist-build-node-1/test-temp-file.txt'),
),
).toBeTruthy();
});

test('should copy publicDir to root dist when environment dist path has a parent-child relationship', async () => {
Expand Down
8 changes: 5 additions & 3 deletions packages/core/src/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -679,16 +679,18 @@ export function stringifyConfig(config: unknown, verbose?: boolean): string {
return stringify(config, { verbose });
}

type NormalizePublicDirOptions = PublicDirOptions &
Required<Omit<PublicDirOptions, 'copyOnBuild'>>;

export const normalizePublicDirs = (
publicDir?: PublicDir,
): Required<PublicDirOptions>[] => {
): NormalizePublicDirOptions[] => {
if (publicDir === false) {
return [];
}

const defaultConfig: Required<PublicDirOptions> = {
const defaultConfig: NormalizePublicDirOptions = {
name: 'public',
copyOnBuild: true,
watch: false,
};

Expand Down
8 changes: 6 additions & 2 deletions packages/core/src/plugins/server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ export const pluginServer = (): RsbuildPlugin => ({
for (const publicDir of publicDirs) {
const { name, copyOnBuild } = publicDir;

if (!copyOnBuild || !name) {
if (copyOnBuild === false || !name) {
continue;
}

Expand All @@ -47,7 +47,11 @@ export const pluginServer = (): RsbuildPlugin => ({
}

const distPaths = dedupeNestedPaths(
Object.values(environments).map((e) => e.distPath),
Object.values(environments)
.filter(
(e) => copyOnBuild === true || e.config.output.target !== 'node',
)
.map((e) => e.distPath),
);

try {
Expand Down
2 changes: 1 addition & 1 deletion packages/core/src/types/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -322,7 +322,7 @@ export type PublicDirOptions = {
name?: string;
/**
* Whether to copy files from the publicDir to the distDir on production build
* @default true
* @default target !== 'node'
*/
copyOnBuild?: boolean;
/**
Expand Down
16 changes: 14 additions & 2 deletions website/docs/en/config/server/public-dir.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ type PublicDir = false | PublicDirOptions | PublicDirOptions[];
```js
const defaultValue = {
name: 'public',
copyOnBuild: true,
copyOnBuild: target !== 'node',
};
```

Expand Down Expand Up @@ -62,7 +62,7 @@ export default {
### copyOnBuild

- **Type:** `boolean`
- **Default:** `true`
- **Default:** `target !== 'node'`

Whether to copy files from the publicDir to the distDir on production build.

Expand All @@ -80,6 +80,18 @@ export default {

Note that setting the value of `copyOnBuild` to false means that when you run `rsbuild preview` for a production preview, you will not be able to access the corresponding static resources.

By default, the public directory is not copied in the node target environment. If you need to copy files from the public directory to the distDir in the node target environment, you can manually enable `copyOnBuild`:

```ts
export default {
server: {
publicDir: {
copyOnBuild: true,
},
},
};
```

:::tip
During dev builds, if you need to copy some static assets to the output directory, you can use the [output.copy](/config/output/copy) option instead.
:::
Expand Down
16 changes: 14 additions & 2 deletions website/docs/zh/config/server/public-dir.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ type PublicDir = false | PublicDirOptions | PublicDirOptions[];
```js
const defaultValue = {
name: 'public',
copyOnBuild: true,
copyOnBuild: target !== 'node',
watch: false,
};
```
Expand Down Expand Up @@ -63,7 +63,7 @@ export default {
### copyOnBuild

- **类型:** `boolean`
- **默认值:** `true`
- **默认值:** `target !== 'node'`

在生产构建时,是否将文件从 public 目录复制到构建产物目录。

Expand All @@ -81,6 +81,18 @@ export default {

需要注意的是,将 `copyOnBuild` 的值为 false 后,如果执行 `rsbuild preview` 进行生产环境预览,将无法访问对应的静态资源文件。

默认情况下,node 环境下不会进行复制。如果你需要在 node 环境下将文件从 public 目录复制到构建产物目录,可手动开启 `copyOnBuild`

```ts
export default {
server: {
publicDir: {
copyOnBuild: true,
},
},
};
```

:::tip
在 dev 构建时,如果你需要拷贝一些静态资源到构建产物目录,可以使用 [output.copy](/config/output/copy) 选项代替。
:::
Expand Down

0 comments on commit 0f1504d

Please sign in to comment.