Skip to content

Commit

Permalink
chore: edge release on each commit (nuxt#294)
Browse files Browse the repository at this point in the history
  • Loading branch information
pi0 authored Jul 1, 2021
1 parent 1126255 commit fb08be3
Show file tree
Hide file tree
Showing 6 changed files with 144 additions and 1 deletion.
6 changes: 6 additions & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -48,3 +48,9 @@ jobs:

# - name: Coverage
# uses: codecov/codecov-action@v1

- name: Release Edge
if: github.event_name == 'push'
run: ./scripts/release-edge.sh
env:
NODE_AUTH_TOKEN: ${{secrets.NODE_AUTH_TOKEN}}
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
"esbuild": "^0.12.12",
"eslint": "^7.29.0",
"eslint-plugin-jsdoc": "^35.4.1",
"globby": "^11.0.4",
"jest": "^27.0.6",
"jiti": "^1.10.1",
"lerna": "^4.0.0",
Expand Down
2 changes: 1 addition & 1 deletion packages/nuxt3/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
"dist"
],
"scripts": {
"prepack": "unbuild"
"prepack": "unbuild || true"
},
"bin": {
"nu": "./bin/nuxt.js",
Expand Down
109 changes: 109 additions & 0 deletions scripts/bump-edge.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,109 @@
import { promises as fsp } from 'fs'
import { resolve } from 'path'
import { execSync } from 'child_process'
import globby from 'globby'

async function loadPackage (dir: string) {
const pkgPath = resolve(dir, 'package.json')
const data = JSON.parse(await fsp.readFile(pkgPath, 'utf-8').catch(() => '{}'))
const save = () => fsp.writeFile(pkgPath, JSON.stringify(data, null, 2) + '\n')

const updateDeps = (reviver: Function) => {
for (const type of ['dependencies', 'devDependencies', 'optionalDependencies', 'peerDependencies']) {
if (!data[type]) { continue }
for (const e of Object.entries(data[type])) {
const dep = { name: e[0], range: e[1], type }
delete data[type][dep.name]
const updated = reviver(dep) || dep
data[updated.type] = data[updated.type] || {}
data[updated.type][updated.name] = updated.range
}
}
}

return {
dir,
data,
save,
updateDeps
}
}

type ThenArg<T> = T extends PromiseLike<infer U> ? U : T
type Package = ThenArg<ReturnType<typeof loadPackage>>

async function loadWorkspace (dir: string) {
const workspacePkg = await loadPackage(dir)
const pkgDirs = await globby(workspacePkg.data.workspaces || [], { onlyDirectories: true })

const packages: Package[] = []

for (const pkgDir of pkgDirs) {
const pkg = await loadPackage(pkgDir)
if (!pkg.data.name) { continue }
packages.push(pkg)
}

const find = (name: string) => {
const pkg = packages.find(pkg => pkg.data.name === name)
if (!pkg) {
throw new Error('Workspace package not found: ' + name)
}
return pkg
}

const rename = (from: string, to: string) => {
find(from).data.name = to
for (const pkg of packages) {
pkg.updateDeps((dep) => {
if (dep.name === from && !dep.range.startsWith('npm:')) {
dep.range = 'npm:' + to + '@' + dep.range
}
})
}
}

const setVersion = (name: string, newVersion: string) => {
find(name).data.version = newVersion
for (const pkg of packages) {
pkg.updateDeps((dep) => {
if (dep.name === name) {
dep.range = newVersion
}
})
}
}

const save = () => Promise.all(packages.map(pkg => pkg.save()))

return {
dir,
workspacePkg,
packages,
save,
find,
rename,
setVersion
}
}

async function main () {
const workspace = await loadWorkspace(process.cwd())

const commit = execSync('git rev-parse --short HEAD').toString('utf-8').trim()
const date = Math.round(Date.now() / (1000 * 60))

for (const pkg of workspace.packages.filter(p => !p.data.private)) {
workspace.setVersion(pkg.data.name, `${pkg.data.version}-${date}.${commit}`)
if (pkg.data.name !== 'nuxt3' /* TODO: Hardcoded! */) {
workspace.rename(pkg.data.name, pkg.data.name + '-edge')
}
}

await workspace.save()
}

main().catch((err) => {
console.error(err)
process.exit(1)
})
26 changes: 26 additions & 0 deletions scripts/release-edge.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
#!/bin/bash

# Restore all git changes
git restore -s@ -SW -- packages examples

# Bump versions to edge
yarn jiti ./scripts/bump-edge

# Resolve yarn
yarn

# Update token
if [[ ! -z ${NODE_AUTH_TOKEN} ]] ; then
echo "//registry.npmjs.org/:_authToken=${NODE_AUTH_TOKEN}" >> ~/.npmrc
echo "registry=https://registry.npmjs.org/" >> ~/.npmrc
echo "always-auth=true" >> ~/.npmrc
npm whoami
fi

# Release packages
for p in packages/* ; do
pushd $p
echo "Publishing $p"
npm publish -q --access public # --dry-run
popd
done
1 change: 1 addition & 0 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -9797,6 +9797,7 @@ __metadata:
esbuild: ^0.12.12
eslint: ^7.29.0
eslint-plugin-jsdoc: ^35.4.1
globby: ^11.0.4
jest: ^27.0.6
jiti: ^1.10.1
lerna: ^4.0.0
Expand Down

0 comments on commit fb08be3

Please sign in to comment.