summaryrefslogtreecommitdiffhomepage
path: root/.github
diff options
context:
space:
mode:
authorAiden Cline <[email protected]>2026-01-08 12:43:57 -0600
committerAiden Cline <[email protected]>2026-01-08 12:44:04 -0600
commit1906a347f318bdc263231a691e12167fdce7d9ea (patch)
tree42463b6e5903445c4cc5068ca5f592624b5cf4df /.github
parente5d0c63b29a0044cc48287caede6632e8d9e1826 (diff)
downloadopencode-1906a347f318bdc263231a691e12167fdce7d9ea.tar.gz
opencode-1906a347f318bdc263231a691e12167fdce7d9ea.zip
docs: update pr workflows
Diffstat (limited to '.github')
-rw-r--r--.github/workflows/pr-standards.yml136
-rw-r--r--.github/workflows/pr-title.yml62
2 files changed, 136 insertions, 62 deletions
diff --git a/.github/workflows/pr-standards.yml b/.github/workflows/pr-standards.yml
new file mode 100644
index 000000000..ea5e36574
--- /dev/null
+++ b/.github/workflows/pr-standards.yml
@@ -0,0 +1,136 @@
+name: PR Standards
+
+on:
+ pull_request:
+ types: [opened, edited, synchronize]
+
+jobs:
+ check-standards:
+ if: |
+ github.event.pull_request.user.login != 'actions-user' &&
+ github.event.pull_request.user.login != 'opencode' &&
+ github.event.pull_request.user.login != 'rekram1-node' &&
+ github.event.pull_request.user.login != 'thdxr' &&
+ github.event.pull_request.user.login != 'kommander' &&
+ github.event.pull_request.user.login != 'jayair' &&
+ github.event.pull_request.user.login != 'fwang' &&
+ github.event.pull_request.user.login != 'adamdotdevin' &&
+ github.event.pull_request.user.login != 'iamdavidhill' &&
+ github.event.pull_request.user.login != 'opencode-agent[bot]'
+ runs-on: ubuntu-latest
+ permissions:
+ pull-requests: write
+ steps:
+ - name: Check PR standards
+ uses: actions/github-script@v7
+ with:
+ script: |
+ const pr = context.payload.pull_request;
+ const title = pr.title;
+
+ async function addLabel(label) {
+ await github.rest.issues.addLabels({
+ owner: context.repo.owner,
+ repo: context.repo.repo,
+ issue_number: pr.number,
+ labels: [label]
+ });
+ }
+
+ async function removeLabel(label) {
+ try {
+ await github.rest.issues.removeLabel({
+ owner: context.repo.owner,
+ repo: context.repo.repo,
+ issue_number: pr.number,
+ name: label
+ });
+ } catch (e) {
+ // Label wasn't present, ignore
+ }
+ }
+
+ async function comment(marker, body) {
+ const markerText = `<!-- pr-standards:${marker} -->`;
+ const { data: comments } = await github.rest.issues.listComments({
+ owner: context.repo.owner,
+ repo: context.repo.repo,
+ issue_number: pr.number
+ });
+
+ const existing = comments.find(c => c.body.includes(markerText));
+ if (existing) return;
+
+ await github.rest.issues.createComment({
+ owner: context.repo.owner,
+ repo: context.repo.repo,
+ issue_number: pr.number,
+ body: markerText + '\n' + body
+ });
+ }
+
+ // Step 1: Check title format
+ const validPrefixes = ['feat:', 'fix:', 'docs:', 'chore:', 'refactor:', 'test:'];
+ const hasValidTitle = validPrefixes.some(prefix => title.startsWith(prefix));
+
+ if (!hasValidTitle) {
+ await addLabel('needs:title');
+ await comment('title', `Hey! Your PR title \`${title}\` doesn't follow conventional commit format.
+
+ Please update it to start with one of:
+ - \`feat:\` new feature
+ - \`fix:\` bug fix
+ - \`docs:\` documentation changes
+ - \`chore:\` maintenance tasks
+ - \`refactor:\` code refactoring
+ - \`test:\` adding or updating tests
+
+ See [CONTRIBUTING.md](../blob/dev/CONTRIBUTING.md#pr-titles) for details.`);
+ return;
+ }
+
+ await removeLabel('needs:title');
+
+ // Step 2: Check for linked issue (skip for docs/refactor PRs)
+ const skipIssueCheck = title.startsWith('docs:') || title.startsWith('refactor:');
+ if (skipIssueCheck) {
+ await removeLabel('needs:issue');
+ console.log('Skipping issue check for docs/refactor PR');
+ return;
+ }
+ const query = `
+ query($owner: String!, $repo: String!, $number: Int!) {
+ repository(owner: $owner, name: $repo) {
+ pullRequest(number: $number) {
+ closingIssuesReferences(first: 1) {
+ totalCount
+ }
+ }
+ }
+ }
+ `;
+
+ const result = await github.graphql(query, {
+ owner: context.repo.owner,
+ repo: context.repo.repo,
+ number: pr.number
+ });
+
+ const linkedIssues = result.repository.pullRequest.closingIssuesReferences.totalCount;
+
+ if (linkedIssues === 0) {
+ await addLabel('needs:issue');
+ await comment('issue', `Thanks for your contribution!
+
+ This PR doesn't have a linked issue. All PRs must reference an existing issue.
+
+ Please:
+ 1. Open an issue describing the bug/feature (if one doesn't exist)
+ 2. Add \`Fixes #<number>\` or \`Closes #<number>\` to this PR description
+
+ See [CONTRIBUTING.md](../blob/dev/CONTRIBUTING.md#issue-first-policy) for details.`);
+ return;
+ }
+
+ await removeLabel('needs:issue');
+ console.log('PR meets all standards');
diff --git a/.github/workflows/pr-title.yml b/.github/workflows/pr-title.yml
deleted file mode 100644
index 220f34054..000000000
--- a/.github/workflows/pr-title.yml
+++ /dev/null
@@ -1,62 +0,0 @@
-name: PR Title Validation
-
-on:
- pull_request:
- types: [opened, edited, synchronize]
-
-jobs:
- validate-title:
- if: |
- github.event.pull_request.user.login != 'actions-user' &&
- github.event.pull_request.user.login != 'opencode' &&
- github.event.pull_request.user.login != 'rekram1-node' &&
- github.event.pull_request.user.login != 'thdxr' &&
- github.event.pull_request.user.login != 'kommander' &&
- github.event.pull_request.user.login != 'jayair' &&
- github.event.pull_request.user.login != 'fwang' &&
- github.event.pull_request.user.login != 'adamdotdevin' &&
- github.event.pull_request.user.login != 'iamdavidhill' &&
- github.event.pull_request.user.login != 'opencode-agent[bot]'
- runs-on: ubuntu-latest
- permissions:
- pull-requests: write
- steps:
- - name: Validate PR title
- uses: actions/github-script@v7
- with:
- script: |
- const title = context.payload.pull_request.title;
- const validPrefixes = ['feat:', 'fix:', 'docs:', 'chore:', 'refactor:', 'test:'];
- const isValid = validPrefixes.some(prefix => title.startsWith(prefix));
-
- if (!isValid) {
- const body = `👋 Thanks for opening this PR!
-
- Your PR title \`${title}\` doesn't follow our conventional commit format.
-
- Please update it to start with one of these prefixes:
- - \`feat:\` new feature or functionality
- - \`fix:\` bug fix
- - \`docs:\` documentation or README changes
- - \`chore:\` maintenance tasks, dependency updates, etc.
- - \`refactor:\` code refactoring without changing behavior
- - \`test:\` adding or updating tests
-
- **Examples:**
- - \`docs: update contributing guidelines\`
- - \`fix: resolve crash on startup\`
- - \`feat: add dark mode support\`
-
- See [CONTRIBUTING.md](../blob/dev/CONTRIBUTING.md#pr-titles) for more details.`;
-
- await github.rest.issues.createComment({
- owner: context.repo.owner,
- repo: context.repo.repo,
- issue_number: context.payload.pull_request.number,
- body: body
- });
-
- core.setFailed('PR title does not follow conventional commit format');
- } else {
- console.log('PR title is valid:', title);
- }