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 +10 -0
- package/README.md +1 -0
- package/package.json +3 -3
- package/src/main/js/deps.js +7 -32
- package/src/main/js/processor.js +1 -1
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.
|
|
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.
|
|
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.
|
|
33
|
+
"verdaccio": "^5.23.1"
|
|
34
34
|
},
|
|
35
35
|
"publishConfig": {
|
|
36
36
|
"access": "public"
|
package/src/main/js/deps.js
CHANGED
|
@@ -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
|
|
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 (
|
|
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
|
|
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,
|
|
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
|
}
|
package/src/main/js/processor.js
CHANGED
|
@@ -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
|
|
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()
|