bulk-release 2.2.17 → 2.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,3 +1,13 @@
1
+ ## [2.3.1](https://github.com/semrel-extra/zx-bulk-release/compare/v2.3.0...v2.3.1) (2023-04-02)
2
+
3
+ ### Fixes & improvements
4
+ * refactor: use `traverseQueue`, `traverseDeps` from @semrel-extra/topo ([70d6cf4](https://github.com/semrel-extra/zx-bulk-release/commit/70d6cf41fdfd1436b561f9eb1d94254408e6d6e5))
5
+
6
+ ## [2.3.0](https://github.com/semrel-extra/zx-bulk-release/compare/v2.2.17...v2.3.0) (2023-03-28)
7
+
8
+ ### Features
9
+ * feat: introduce `onlyWorkspaceDeps` flag to identify `workspace` deps as the only graph edges ([b4aa4b5](https://github.com/semrel-extra/zx-bulk-release/commit/b4aa4b5e81c7ecc6658bac53b2188727e087aed6))
10
+
1
11
  ## [2.2.17](https://github.com/semrel-extra/zx-bulk-release/compare/v2.2.16...v2.2.17) (2023-03-28)
2
12
 
3
13
  ### Fixes & improvements
package/README.md CHANGED
@@ -44,6 +44,7 @@ GH_TOKEN=ghtoken GH_USER=username NPM_TOKEN=npmtoken npx zx-bulk-release [opts]
44
44
  | `--concurrency` | `build/publish` threads limit | `os.cpus.length` |
45
45
  | `--no-build` | Skip `buildCmd` invoke | |
46
46
  | `--no-npm-fetch` | Disable npm artifacts fetching | |
47
+ | `--only-workspace-deps` | Recognize only `workspace:` deps as graph edges | |
47
48
  | `--dry-run` / `--no-publish` | Disable any publish logic | |
48
49
  | `--report` | Persist release state to file | |
49
50
  | `--debug` | Enable [zx](https://github.com/google/zx#verbose) verbose mode | |
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "bulk-release",
3
3
  "alias": "bulk-release",
4
- "version": "2.2.17",
4
+ "version": "2.3.1",
5
5
  "description": "zx-based alternative for multi-semantic-release",
6
6
  "type": "module",
7
7
  "exports": {
@@ -22,7 +22,7 @@
22
22
  "docs": "mkdir -p docs && cp ./README.md ./docs/README.md"
23
23
  },
24
24
  "dependencies": {
25
- "@semrel-extra/topo": "^1.6.0",
25
+ "@semrel-extra/topo": "^1.8.1",
26
26
  "cosmiconfig": "^8.1.3",
27
27
  "queuefy": "^1.2.1",
28
28
  "zx-extra": "^2.5.4"
@@ -30,7 +30,7 @@
30
30
  "devDependencies": {
31
31
  "c8": "^7.13.0",
32
32
  "uvu": "^0.5.6",
33
- "verdaccio": "^5.22.1"
33
+ "verdaccio": "^5.23.1"
34
34
  },
35
35
  "publishConfig": {
36
36
  "access": "public"
@@ -1,27 +1,12 @@
1
1
  import {semver} from 'zx-extra'
2
- import {topo as _topo} from '@semrel-extra/topo'
2
+ import {topo as _topo, traverseDeps} from '@semrel-extra/topo'
3
3
 
4
- export const depScopes = ['dependencies', 'devDependencies', 'peerDependencies', 'optionalDependencies']
5
-
6
- export const traverseDeps = async (pkg, packages, fn) => {
7
- const {manifest} = pkg
8
-
9
- for (let scope of depScopes) {
10
- const deps = manifest[scope]
11
- if (!deps) continue
12
-
13
- for (let [name, version] of Object.entries(deps)) {
14
- if (!packages[name]) continue
15
-
16
- await fn(pkg, {name, version, deps, scope, pkg: packages[name]})
17
- }
18
- }
19
- }
4
+ export {traverseQueue, traverseDeps} from '@semrel-extra/topo'
20
5
 
21
6
  export const updateDeps = async (pkg, packages) => {
22
7
  const changes = []
23
8
 
24
- await traverseDeps(pkg, packages, async (_, {name, version, deps, scope, pkg: dep}) => {
9
+ await traverseDeps({pkg, packages, cb: async ({name, version, deps, scope, pkg: dep}) => {
25
10
  const prev = pkg.latest.meta?.[scope]?.[name]
26
11
  const actual = dep?.version
27
12
  const next = resolveNextVersion(version, actual, prev)
@@ -37,7 +22,7 @@ export const updateDeps = async (pkg, packages) => {
37
22
  change: 'perf',
38
23
  subj: `perf: ${name} updated to ${next}`,
39
24
  })
40
- })
25
+ }})
41
26
 
42
27
  return changes
43
28
  }
@@ -72,19 +57,9 @@ export const topo = async ({flags = {}, cwd} = {}) => {
72
57
  ? flags.ignore
73
58
  : []
74
59
 
75
- const filter = ({manifest: {private: _private, name}}) =>
60
+ const depFilter = flags.onlyWorkspaceDeps ? ({version}) => version.startsWith('workspace:') : undefined
61
+ const pkgFilter = ({manifest: {private: _private, name}}) =>
76
62
  !ignore.includes(name) && (flags.includePrivate || !_private)
77
63
 
78
- return _topo({cwd, filter})
79
- }
80
-
81
- export const traverseQueue = async ({queue, prev, cb}) => {
82
- const acc = {}
83
-
84
- return Promise.all(queue.map((name) =>
85
- (acc[name] = (async () => {
86
- await Promise.all((prev.get(name) || []).map((p) => acc[p]))
87
- await cb(name)
88
- })()))
89
- )
64
+ return _topo({cwd, pkgFilter, depFilter})
90
65
  }
@@ -116,7 +116,7 @@ const build = memoizeBy(async (pkg, run = runCmd, flags = {}, self = build) => w
116
116
  $.scope = pkg.name
117
117
 
118
118
  await Promise.all([
119
- traverseDeps(pkg, pkg.context.packages, async (_, {pkg}) => self(pkg, run, flags, self)),
119
+ traverseDeps({pkg, packages: pkg.context.packages, cb: async({pkg}) => self(pkg, run, flags, self)}),
120
120
  pkg.changes.length === 0 && pkg.config.npmFetch && !flags.noNpmFetch
121
121
  ? fetchPkg(pkg)
122
122
  : Promise.resolve()