ci: tweaks
This commit is contained in:
@@ -40,7 +40,10 @@ for (const [os, arch] of targets) {
|
|||||||
)
|
)
|
||||||
await $`bun build --define OPENCODE_TUI_PATH="'../../../dist/${name}/bin/tui'" --define OPENCODE_VERSION="'${version}'" --compile --target=bun-${os}-${arch} --outfile=dist/${name}/bin/opencode ./src/index.ts`
|
await $`bun build --define OPENCODE_TUI_PATH="'../../../dist/${name}/bin/tui'" --define OPENCODE_VERSION="'${version}'" --compile --target=bun-${os}-${arch} --outfile=dist/${name}/bin/opencode ./src/index.ts`
|
||||||
// Run the binary only if it matches current OS/arch
|
// Run the binary only if it matches current OS/arch
|
||||||
if ((process.platform === (os === "windows" ? "win32" : os)) && (process.arch === arch || (process.arch === "x64" && arch === "x64-baseline"))) {
|
if (
|
||||||
|
process.platform === (os === "windows" ? "win32" : os) &&
|
||||||
|
(process.arch === arch || (process.arch === "x64" && arch === "x64-baseline"))
|
||||||
|
) {
|
||||||
console.log(`smoke test: running dist/${name}/bin/opencode --version`)
|
console.log(`smoke test: running dist/${name}/bin/opencode --version`)
|
||||||
await $`./dist/${name}/bin/opencode --version`
|
await $`./dist/${name}/bin/opencode --version`
|
||||||
}
|
}
|
||||||
@@ -84,44 +87,10 @@ await Bun.file(`./dist/${pkg.name}/package.json`).write(
|
|||||||
if (!dry) await $`cd ./dist/${pkg.name} && bun publish --access public --tag ${npmTag}`
|
if (!dry) await $`cd ./dist/${pkg.name} && bun publish --access public --tag ${npmTag}`
|
||||||
|
|
||||||
if (!snapshot) {
|
if (!snapshot) {
|
||||||
// Github Release
|
|
||||||
for (const key of Object.keys(optionalDependencies)) {
|
for (const key of Object.keys(optionalDependencies)) {
|
||||||
await $`cd dist/${key}/bin && zip -r ../../${key}.zip *`
|
await $`cd dist/${key}/bin && zip -r ../../${key}.zip *`
|
||||||
}
|
}
|
||||||
|
|
||||||
const previous = await fetch("https://api.github.com/repos/sst/opencode/releases/latest")
|
|
||||||
.then((res) => {
|
|
||||||
if (!res.ok) throw new Error(res.statusText)
|
|
||||||
return res.json()
|
|
||||||
})
|
|
||||||
.then((data) => data.tag_name)
|
|
||||||
|
|
||||||
console.log("finding commits between", previous, "and", "HEAD")
|
|
||||||
const commits = await fetch(`https://api.github.com/repos/sst/opencode/compare/${previous}...HEAD`)
|
|
||||||
.then((res) => res.json())
|
|
||||||
.then((data) => data.commits || [])
|
|
||||||
|
|
||||||
const raw = commits.map((commit: any) => `- ${commit.commit.message.split("\n").join(" ")}`)
|
|
||||||
console.log(raw)
|
|
||||||
|
|
||||||
const notes =
|
|
||||||
raw
|
|
||||||
.filter((x: string) => {
|
|
||||||
const lower = x.toLowerCase()
|
|
||||||
return (
|
|
||||||
!lower.includes("release:") &&
|
|
||||||
!lower.includes("ignore:") &&
|
|
||||||
!lower.includes("chore:") &&
|
|
||||||
!lower.includes("ci:") &&
|
|
||||||
!lower.includes("wip:") &&
|
|
||||||
!lower.includes("docs:") &&
|
|
||||||
!lower.includes("doc:")
|
|
||||||
)
|
|
||||||
})
|
|
||||||
.join("\n") || "No notable changes"
|
|
||||||
|
|
||||||
if (!dry) await $`gh release create v${version} --title "v${version}" --notes ${notes} ./dist/*.zip`
|
|
||||||
|
|
||||||
// Calculate SHA values
|
// Calculate SHA values
|
||||||
const arm64Sha = await $`sha256sum ./dist/opencode-linux-arm64.zip | cut -d' ' -f1`.text().then((x) => x.trim())
|
const arm64Sha = await $`sha256sum ./dist/opencode-linux-arm64.zip | cut -d' ' -f1`.text().then((x) => x.trim())
|
||||||
const x64Sha = await $`sha256sum ./dist/opencode-linux-x64.zip | cut -d' ' -f1`.text().then((x) => x.trim())
|
const x64Sha = await $`sha256sum ./dist/opencode-linux-x64.zip | cut -d' ' -f1`.text().then((x) => x.trim())
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
#!/usr/bin/env bun
|
#!/usr/bin/env bun
|
||||||
|
|
||||||
import { $ } from "bun"
|
import { $ } from "bun"
|
||||||
|
import path from "path"
|
||||||
|
|
||||||
console.log("=== publishing ===\n")
|
console.log("=== publishing ===\n")
|
||||||
|
|
||||||
@@ -38,10 +39,46 @@ await import(`../packages/sdk/js/script/publish.ts`)
|
|||||||
console.log("\n=== plugin ===\n")
|
console.log("\n=== plugin ===\n")
|
||||||
await import(`../packages/plugin/script/publish.ts`)
|
await import(`../packages/plugin/script/publish.ts`)
|
||||||
|
|
||||||
|
const dir = new URL("..", import.meta.url).pathname
|
||||||
|
process.chdir(dir)
|
||||||
|
|
||||||
if (!snapshot) {
|
if (!snapshot) {
|
||||||
await $`git commit -am "release: v${version}"`
|
await $`git commit -am "release: v${version}"`
|
||||||
await $`git tag v${version}`
|
await $`git tag v${version}`
|
||||||
await $`git push origin HEAD --tags --no-verify`
|
await $`git push origin HEAD --tags --no-verify`
|
||||||
|
|
||||||
|
const previous = await fetch("https://api.github.com/repos/sst/opencode/releases/latest")
|
||||||
|
.then((res) => {
|
||||||
|
if (!res.ok) throw new Error(res.statusText)
|
||||||
|
return res.json()
|
||||||
|
})
|
||||||
|
.then((data) => data.tag_name)
|
||||||
|
|
||||||
|
console.log("finding commits between", previous, "and", "HEAD")
|
||||||
|
const commits = await fetch(`https://api.github.com/repos/sst/opencode/compare/${previous}...HEAD`)
|
||||||
|
.then((res) => res.json())
|
||||||
|
.then((data) => data.commits || [])
|
||||||
|
|
||||||
|
const raw = commits.map((commit: any) => `- ${commit.commit.message.split("\n").join(" ")}`)
|
||||||
|
console.log(raw)
|
||||||
|
|
||||||
|
const notes =
|
||||||
|
raw
|
||||||
|
.filter((x: string) => {
|
||||||
|
const lower = x.toLowerCase()
|
||||||
|
return (
|
||||||
|
!lower.includes("release:") &&
|
||||||
|
!lower.includes("ignore:") &&
|
||||||
|
!lower.includes("chore:") &&
|
||||||
|
!lower.includes("ci:") &&
|
||||||
|
!lower.includes("wip:") &&
|
||||||
|
!lower.includes("docs:") &&
|
||||||
|
!lower.includes("doc:")
|
||||||
|
)
|
||||||
|
})
|
||||||
|
.join("\n") || "No notable changes"
|
||||||
|
|
||||||
|
await $`gh release create v${version} --title "v${version}" --notes ${notes} ./packages/opencode/dist/*.zip`
|
||||||
}
|
}
|
||||||
if (snapshot) {
|
if (snapshot) {
|
||||||
await $`git checkout -b snapshot-${version}`
|
await $`git checkout -b snapshot-${version}`
|
||||||
|
|||||||
Reference in New Issue
Block a user