Compare commits
3 Commits
v0.0.2
...
3d34ecc9f9
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
3d34ecc9f9 | ||
|
|
a3022b4770 | ||
|
|
92ab71df30 |
22
examples/workspace/BUILD.bazel
Normal file
22
examples/workspace/BUILD.bazel
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
load("//bun:defs.bzl", "bun_bundle", "ts_library")
|
||||||
|
|
||||||
|
package(default_visibility = ["//visibility:public"])
|
||||||
|
|
||||||
|
exports_files([
|
||||||
|
"README.md",
|
||||||
|
"package.json",
|
||||||
|
"packages/pkg-a/package.json",
|
||||||
|
"packages/pkg-b/package.json",
|
||||||
|
])
|
||||||
|
|
||||||
|
ts_library(
|
||||||
|
name = "pkg_a_lib",
|
||||||
|
srcs = ["packages/pkg-a/index.ts"],
|
||||||
|
)
|
||||||
|
|
||||||
|
bun_bundle(
|
||||||
|
name = "pkg_b_bundle",
|
||||||
|
entry_points = ["packages/pkg-b/main.ts"],
|
||||||
|
deps = [":pkg_a_lib"],
|
||||||
|
target = "bun",
|
||||||
|
)
|
||||||
14
examples/workspace/README.md
Normal file
14
examples/workspace/README.md
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
# workspace example
|
||||||
|
|
||||||
|
Minimal Bun workspace-style layout with two packages:
|
||||||
|
|
||||||
|
- `@workspace/pkg-a`: exports a string helper
|
||||||
|
- `@workspace/pkg-b`: imports from `pkg-a` and prints the message
|
||||||
|
|
||||||
|
The workspace root also defines a Bun `catalog` pin for `lodash`, and both packages consume it via `"lodash": "catalog:"` to keep versions consistent across packages.
|
||||||
|
|
||||||
|
This example demonstrates building a target from a workspace-shaped directory tree with Bazel:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
bazel build //examples/workspace:pkg_b_bundle
|
||||||
|
```
|
||||||
10
examples/workspace/package.json
Normal file
10
examples/workspace/package.json
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"name": "workspace-root",
|
||||||
|
"private": true,
|
||||||
|
"workspaces": [
|
||||||
|
"packages/*"
|
||||||
|
],
|
||||||
|
"catalog": {
|
||||||
|
"lodash": "^4.17.21"
|
||||||
|
}
|
||||||
|
}
|
||||||
3
examples/workspace/packages/pkg-a/index.ts
Normal file
3
examples/workspace/packages/pkg-a/index.ts
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
export function workspaceMessage(): string {
|
||||||
|
return "workspace-pkg-a";
|
||||||
|
}
|
||||||
8
examples/workspace/packages/pkg-a/package.json
Normal file
8
examples/workspace/packages/pkg-a/package.json
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"name": "@workspace/pkg-a",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"main": "index.ts",
|
||||||
|
"dependencies": {
|
||||||
|
"lodash": "catalog:"
|
||||||
|
}
|
||||||
|
}
|
||||||
3
examples/workspace/packages/pkg-b/main.ts
Normal file
3
examples/workspace/packages/pkg-b/main.ts
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import { workspaceMessage } from "../pkg-a/index";
|
||||||
|
|
||||||
|
console.log(`hello-${workspaceMessage()}`);
|
||||||
8
examples/workspace/packages/pkg-b/package.json
Normal file
8
examples/workspace/packages/pkg-b/package.json
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"name": "@workspace/pkg-b",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"dependencies": {
|
||||||
|
"@workspace/pkg-a": "workspace:*",
|
||||||
|
"lodash": "catalog:"
|
||||||
|
}
|
||||||
|
}
|
||||||
12
flake.lock
generated
12
flake.lock
generated
@@ -9,16 +9,16 @@
|
|||||||
"treefmt-nix": "treefmt-nix"
|
"treefmt-nix": "treefmt-nix"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1772613315,
|
"lastModified": 1772610504,
|
||||||
"narHash": "sha256-RlPTOsyfVwuwEzvaMpwS+giOqQa6KQXMuSHyh1bctjk=",
|
"narHash": "sha256-uoMnjsab5IpZRZ/1mn5oVy4fRnAYn6b58E3FNa+jyQY=",
|
||||||
"ref": "v1.0.5",
|
"ref": "v1.0.4",
|
||||||
"rev": "e445e49baf8b44b385108cd4f26a14d8ccf9fd35",
|
"rev": "86a0792b6e54104e8cb33983cabc175aea8da464",
|
||||||
"revCount": 35,
|
"revCount": 33,
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git.dgren.dev/eric/nix-flake-lib"
|
"url": "https://git.dgren.dev/eric/nix-flake-lib"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"ref": "v1.0.5",
|
"ref": "v1.0.4",
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git.dgren.dev/eric/nix-flake-lib"
|
"url": "https://git.dgren.dev/eric/nix-flake-lib"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,13 +3,12 @@
|
|||||||
|
|
||||||
inputs = {
|
inputs = {
|
||||||
nixpkgs.url = "github:nixos/nixpkgs?ref=nixos-unstable";
|
nixpkgs.url = "github:nixos/nixpkgs?ref=nixos-unstable";
|
||||||
devshell-lib.url = "git+https://git.dgren.dev/eric/nix-flake-lib?ref=v1.0.5";
|
devshell-lib.url = "git+https://git.dgren.dev/eric/nix-flake-lib?ref=v1.0.4";
|
||||||
devshell-lib.inputs.nixpkgs.follows = "nixpkgs";
|
devshell-lib.inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs =
|
outputs =
|
||||||
{
|
{
|
||||||
self,
|
|
||||||
nixpkgs,
|
nixpkgs,
|
||||||
devshell-lib,
|
devshell-lib,
|
||||||
...
|
...
|
||||||
@@ -42,7 +41,6 @@
|
|||||||
bun
|
bun
|
||||||
bazel9
|
bazel9
|
||||||
bazel-buildtools
|
bazel-buildtools
|
||||||
self.packages.${system}.release
|
|
||||||
];
|
];
|
||||||
|
|
||||||
features = {
|
features = {
|
||||||
|
|||||||
@@ -76,3 +76,22 @@ sh_test(
|
|||||||
args = ["$(location //internal:bun_install.bzl)"],
|
args = ["$(location //internal:bun_install.bzl)"],
|
||||||
data = ["//internal:bun_install.bzl"],
|
data = ["//internal:bun_install.bzl"],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
sh_test(
|
||||||
|
name = "bun_install_workspaces_test",
|
||||||
|
srcs = ["workspaces.sh"],
|
||||||
|
args = select({
|
||||||
|
":linux_x86_64": ["$(location @bun_linux_x64//:bun)"],
|
||||||
|
":linux_aarch64": ["$(location @bun_linux_aarch64//:bun)"],
|
||||||
|
":darwin_x86_64": ["$(location @bun_darwin_x64//:bun)"],
|
||||||
|
":darwin_aarch64": ["$(location @bun_darwin_aarch64//:bun)"],
|
||||||
|
"//conditions:default": ["$(location @bun_linux_x64//:bun)"],
|
||||||
|
}),
|
||||||
|
data = select({
|
||||||
|
":linux_x86_64": ["@bun_linux_x64//:bun"],
|
||||||
|
":linux_aarch64": ["@bun_linux_aarch64//:bun"],
|
||||||
|
":darwin_x86_64": ["@bun_darwin_x64//:bun"],
|
||||||
|
":darwin_aarch64": ["@bun_darwin_aarch64//:bun"],
|
||||||
|
"//conditions:default": ["@bun_linux_x64//:bun"],
|
||||||
|
}),
|
||||||
|
)
|
||||||
|
|||||||
46
tests/install_test/workspaces.sh
Executable file
46
tests/install_test/workspaces.sh
Executable file
@@ -0,0 +1,46 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
bun_path="$1"
|
||||||
|
workdir="$(mktemp -d)"
|
||||||
|
trap 'rm -rf "${workdir}"' EXIT
|
||||||
|
|
||||||
|
mkdir -p "${workdir}/packages/pkg-a" "${workdir}/packages/pkg-b"
|
||||||
|
|
||||||
|
cat >"${workdir}/package.json" <<'JSON'
|
||||||
|
{
|
||||||
|
"name": "workspace-root",
|
||||||
|
"private": true,
|
||||||
|
"workspaces": ["packages/*"]
|
||||||
|
}
|
||||||
|
JSON
|
||||||
|
|
||||||
|
cat >"${workdir}/packages/pkg-a/package.json" <<'JSON'
|
||||||
|
{
|
||||||
|
"name": "@workspace/pkg-a",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"main": "index.js"
|
||||||
|
}
|
||||||
|
JSON
|
||||||
|
|
||||||
|
cat >"${workdir}/packages/pkg-a/index.js" <<'JS'
|
||||||
|
module.exports = { value: 42 };
|
||||||
|
JS
|
||||||
|
|
||||||
|
cat >"${workdir}/packages/pkg-b/package.json" <<'JSON'
|
||||||
|
{
|
||||||
|
"name": "@workspace/pkg-b",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"dependencies": {
|
||||||
|
"@workspace/pkg-a": "workspace:*"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"check": "bun -e \"const { value } = require('@workspace/pkg-a'); if (value !== 42) process.exit(1)\""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
JSON
|
||||||
|
|
||||||
|
"${bun_path}" install --cwd "${workdir}" >/dev/null
|
||||||
|
rm -rf "${workdir}/node_modules" "${workdir}/packages/pkg-b/node_modules"
|
||||||
|
"${bun_path}" install --cwd "${workdir}" --frozen-lockfile >/dev/null
|
||||||
|
"${bun_path}" run --cwd "${workdir}/packages/pkg-b" check >/dev/null
|
||||||
@@ -13,6 +13,28 @@ sh_test(
|
|||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
sh_test(
|
||||||
|
name = "examples_workspace_bundle_e2e_test",
|
||||||
|
srcs = ["examples_workspace_bundle_e2e_test.sh"],
|
||||||
|
args = ["$(location //examples/workspace:pkg_b_bundle)"],
|
||||||
|
data = ["//examples/workspace:pkg_b_bundle"],
|
||||||
|
)
|
||||||
|
|
||||||
|
sh_test(
|
||||||
|
name = "examples_workspace_catalog_shape_test",
|
||||||
|
srcs = ["examples_workspace_catalog_shape_test.sh"],
|
||||||
|
args = [
|
||||||
|
"$(location //examples/workspace:package.json)",
|
||||||
|
"$(location //examples/workspace:packages/pkg-a/package.json)",
|
||||||
|
"$(location //examples/workspace:packages/pkg-b/package.json)",
|
||||||
|
],
|
||||||
|
data = [
|
||||||
|
"//examples/workspace:package.json",
|
||||||
|
"//examples/workspace:packages/pkg-a/package.json",
|
||||||
|
"//examples/workspace:packages/pkg-b/package.json",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
sh_test(
|
sh_test(
|
||||||
name = "repo_all_targets_test",
|
name = "repo_all_targets_test",
|
||||||
srcs = ["repo_all_targets_test.sh"],
|
srcs = ["repo_all_targets_test.sh"],
|
||||||
|
|||||||
7
tests/integration_test/examples_workspace_bundle_e2e_test.sh
Executable file
7
tests/integration_test/examples_workspace_bundle_e2e_test.sh
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
bundle_file="$1"
|
||||||
|
|
||||||
|
[[ -f ${bundle_file} ]]
|
||||||
|
grep -Eq 'hello-workspace-pkg-a|workspace-pkg-a' "${bundle_file}"
|
||||||
11
tests/integration_test/examples_workspace_catalog_shape_test.sh
Executable file
11
tests/integration_test/examples_workspace_catalog_shape_test.sh
Executable file
@@ -0,0 +1,11 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
root_package_json="$1"
|
||||||
|
pkg_a_package_json="$2"
|
||||||
|
pkg_b_package_json="$3"
|
||||||
|
|
||||||
|
grep -Eq '"catalog"[[:space:]]*:[[:space:]]*\{' "${root_package_json}"
|
||||||
|
grep -Eq '"lodash"[[:space:]]*:[[:space:]]*"\^4\.17\.21"' "${root_package_json}"
|
||||||
|
grep -Eq '"lodash"[[:space:]]*:[[:space:]]*"catalog:"' "${pkg_a_package_json}"
|
||||||
|
grep -Eq '"lodash"[[:space:]]*:[[:space:]]*"catalog:"' "${pkg_b_package_json}"
|
||||||
Reference in New Issue
Block a user