-
Notifications
You must be signed in to change notification settings - Fork 34
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'origin/main' into renovate-eslint-9.x
- Loading branch information
Showing
45 changed files
with
1,550 additions
and
1,837 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
--- | ||
'skuba': major | ||
--- | ||
|
||
node, start: Replace `ts-node` with `tsx` | ||
|
||
`skuba start` and `skuba node` now use `tsx` instead of `ts-node` for running TypeScript files. `tsx` has better ESM interoperability, like support for dynamic imports (`await import()`), than `ts-node`. | ||
|
||
There are some downsides for the REPL (which is what `skuba node` without any file is): | ||
|
||
- `import` statements in the REPL are not supported; `require` and `await import()` are still supported. | ||
- Pasting code into the REPL may not work as well as `ts-node`. If encountering issues, a workaround could be to use [`.editor`](https://nodejs.org/en/learn/command-line/how-to-use-the-nodejs-repl#dot-commands) | ||
|
||
Otherwise, `skuba start` and `skuba node <file>` _should_ work as expected. However, it is difficult to comprehensively test every scenario, so this has been released as a major version. It is recommended to test your use-cases of `skuba start` and `skuba node` after upgrading. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
--- | ||
'skuba': patch | ||
--- | ||
|
||
template/koa-rest-api: Enable secure headers middleware by default |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
--- | ||
'skuba': minor | ||
--- | ||
|
||
lint: Removes obsolete version field from docker-compose.yml files |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
--- | ||
'skuba': patch | ||
--- | ||
|
||
template: Add required tags to `lambda-sqs-worker-cdk` template |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
--- | ||
'skuba': patch | ||
--- | ||
|
||
api: Truncate Buildkite annotations over 1 MiB to resolve `buildkite-agent` crash |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
--- | ||
'skuba': minor | ||
--- | ||
|
||
template/lambda-sqs-worker-cdk: Replace custom hooks with `@seek/aws-codedeploy-infra` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -92,6 +92,16 @@ | |
prPriority: 99, | ||
schedule: 'before 3:00 am every weekday', | ||
}, | ||
{ | ||
matchDepTypes: ['devDependencies'], | ||
matchManagers: ['npm'], | ||
semanticCommitType: 'devDeps', | ||
}, | ||
{ | ||
matchDepTypes: ['dependencies', 'peerDependencies'], | ||
matchManagers: ['npm'], | ||
semanticCommitType: 'deps', | ||
}, | ||
{ | ||
matchPaths: ['template/**'], | ||
|
||
|
@@ -102,13 +112,14 @@ | |
], | ||
branchPrefix: 'renovate-', | ||
commitMessageAction: '', | ||
gitIgnoredAuthors: ['[email protected]'], | ||
postUpdateOptions: [], | ||
prConcurrentLimit: 3, | ||
prNotPendingHours: 1, | ||
rangeStrategy: 'replace', | ||
schedule: 'after 3:00 am and before 6:00 am every weekday', | ||
semanticCommitScope: '', | ||
semanticCommitType: 'deps', | ||
semanticCommitType: 'update', | ||
customManagers: [ | ||
{ | ||
customType: 'regex', | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
# Modelled on https://github.com/backstage/backstage/blob/5083c8024deffbdf454983900f02780d14b55a0b/.github/workflows/sync_renovate-changesets.yml#L6 | ||
|
||
name: Sync Renovate changeset | ||
on: | ||
pull_request_target: | ||
paths: | ||
- '.github/workflows/renovate-changeset.yml' | ||
- 'pnpm-lock.yaml' | ||
|
||
jobs: | ||
generate-changeset: | ||
runs-on: ubuntu-latest | ||
if: github.actor == 'renovate[bot]' && github.repository == 'seek-oss/skuba' | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 2 | ||
ref: ${{ github.head_ref }} | ||
token: ${{ secrets.SEEK_OSS_CI_GITHUB_TOKEN }} | ||
- name: Configure Git | ||
run: | | ||
git config --global user.email [email protected] | ||
git config --global user.name 'Github changeset workflow' | ||
- name: Generate changeset | ||
uses: actions/github-script@v7 | ||
env: | ||
PR_TITLE: ${{ github.event.pull_request.title }} | ||
with: | ||
script: | | ||
const { promises: fs } = require('fs'); | ||
async function getPackagesNames(files) { | ||
const packageJsons = await Promise.all( | ||
files.map(async (file) => JSON.parse(await fs.readFile(file, 'utf8'))), | ||
); | ||
return packageJsons.flatMap((d) => (d.private ? [] : [d.name])); | ||
} | ||
async function createChangeset(fileName, message, packages) { | ||
const header = packages.map((pkg) => `'${pkg}': patch`).join('\n'); | ||
const body = `---\n${header}\n---\n\n${message.trim()}\n`; | ||
await fs.writeFile(fileName, body); | ||
} | ||
const prTitle = process.env.PR_TITLE; | ||
if (!prTitle) { | ||
console.log('No PR title found, skipping'); | ||
return; | ||
} | ||
const prefix = prTitle.split(':')[0]; | ||
if (prefix !== 'deps' && prefix !== 'template') { | ||
console.log('Not a prod/template update PR, skipping'); | ||
return; | ||
} | ||
const branch = await exec.getExecOutput('git branch --show-current'); | ||
if (!branch.stdout.startsWith('renovate-')) { | ||
console.log('Not a renovate branch, skipping'); | ||
return; | ||
} | ||
const diffOutput = await exec.getExecOutput('git diff --name-only HEAD~1'); | ||
const diffFiles = diffOutput.stdout.split('\n'); | ||
if (diffFiles.find((f) => f.startsWith('.changeset'))) { | ||
console.log('Changeset already exists, skipping'); | ||
return; | ||
} | ||
const files = diffFiles.filter((file) => file.includes('package.json')); | ||
const packageNames = await getPackagesNames(files); | ||
if (!packageNames.length) { | ||
console.log('No package.json changes to published packages, skipping'); | ||
return; | ||
} | ||
const { stdout: shortHash } = await exec.getExecOutput( | ||
'git rev-parse --short HEAD', | ||
); | ||
const fileName = `.changeset/renovate-${shortHash.trim()}.md`; | ||
await createChangeset(fileName, prTitle, packageNames); | ||
await exec.exec('git', ['add', fileName]); | ||
await exec.exec('git commit -C HEAD --amend --no-edit'); | ||
await exec.exec('git push --force'); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.