Commit e56aaba
test(ci): smoke-test publishing via local Verdaccio
Adds scripts/smoketest-publishing.sh, which boots a disposable Verdaccio
registry via 'npx verdaccio', runs 'yarn release:npm' against it (so the
full pack-all + npm-publish loop is exercised end-to-end), then installs
a representative subset of the published tarballs into a fresh consumer
and imports them under SES lockdown. The pattern mirrors agoric-sdk's
scripts/packing/smoketest-publishing.sh but is much smaller: endo
publishes already-built tarballs from dist/ rather than running lerna
publish against the source tree, so there is no dev-version bump, no
lerna, and no git state dance.
Key design points:
- A custom verdaccio.yaml disables the default npmjs.org uplink
('uplinks: {}'). Without this, Verdaccio proxies reads upstream and
refuses to let us publish over versions that already exist on the
public registry, since endo's tarballs carry real release numbers
rather than dev prereleases.
- A free TCP port is picked via Node's net.createServer() rather than
hardcoding 4873, so a stray Verdaccio on the conventional port can't
collide with us and we can't collide with it.
- HOME is a per-run mktemp dir, so the script never touches the
developer's ~/.npmrc or leaves auth tokens behind. A SIGTERM/SIGINT
trap cleans up Verdaccio and the dir on exit.
- 'npm_config_registry' is inlined on the yarn release:npm command
only, not exported globally. Exporting it causes 'npx npm-cli-login'
earlier in the script to try to fetch npm-cli-login itself from the
empty local registry and 404.
- The consumer install uses 'npm install <name>' (not '<path>') so
npm has to resolve each package from the registry. That proves the
rewritten 'workspace:' deps resolved to concrete versions that
actually exist in the same registry, and that the cross-package
type graph is self-consistent in tarball form.
Wired up as 'yarn smoketest:publish' and invoked from ci.yml's build
matrix, replacing the prior pair of steps:
- 'yarn workspaces foreach --all --topological exec npm pack', which
could not have worked after the ts-node-pack refactor: the .ts-using
packages (exo, patterns, eventual-send) no longer have prepack
hooks, so npm pack would have shipped raw .ts files.
- 'yarn lerna run prepack' for cross-package type-resolution
validation. That check is now subsumed by the consumer import step:
if a package's declarations depend on a neighbor whose published
form is missing or mis-resolved, the import will fail under SES.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>1 parent befc94b commit e56aaba
File tree
3 files changed
+168
-10
lines changed- .github/workflows
- scripts
3 files changed
+168
-10
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
318 | 318 | | |
319 | 319 | | |
320 | 320 | | |
321 | | - | |
322 | | - | |
323 | | - | |
324 | | - | |
325 | | - | |
326 | | - | |
327 | | - | |
328 | | - | |
329 | | - | |
330 | | - | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
331 | 335 | | |
332 | 336 | | |
333 | 337 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
59 | 59 | | |
60 | 60 | | |
61 | 61 | | |
| 62 | + | |
62 | 63 | | |
63 | 64 | | |
64 | 65 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
0 commit comments