From 3fe6b2756eb159e8fc6ac66c443b481d3bd3fab2 Mon Sep 17 00:00:00 2001 From: Charles Ewert Date: Mon, 22 Jul 2024 21:39:56 -0400 Subject: [PATCH 1/5] don't run roku static analysis on push --- .github/workflows/roku-analysis.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/roku-analysis.yml b/.github/workflows/roku-analysis.yml index 2bac16036..e16b8546f 100644 --- a/.github/workflows/roku-analysis.yml +++ b/.github/workflows/roku-analysis.yml @@ -2,7 +2,6 @@ name: roku-analysis on: pull_request: - push: env: BRANCH_NAME: ${{ github.head_ref || github.ref_name }} From d6d1c528562114d6075d344c93bf4775ef113c2a Mon Sep 17 00:00:00 2001 From: Charles Ewert Date: Mon, 22 Jul 2024 21:57:11 -0400 Subject: [PATCH 2/5] add info about how the bump version PR was created --- .github/workflows/bump-version.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/bump-version.yml b/.github/workflows/bump-version.yml index 5670dc7de..1b64af00a 100644 --- a/.github/workflows/bump-version.yml +++ b/.github/workflows/bump-version.yml @@ -94,7 +94,7 @@ jobs: git add . git commit -m "Bump ${{ github.event.inputs.versionType }} version" git push --set-upstream origin "${{ env.newBranch }}" - gh pr create --title "Bump ${{ github.event.inputs.targetBranch }} branch to ${{ env.newVersion }}" --body "Bump version to prep for next release." --label ignore-changelog --base ${{ env.targetBranch }} + gh pr create --title "Bump ${{ github.event.inputs.targetBranch }} branch to ${{ env.newVersion }}" --body "Bump version to prep for next release. Generated by `.github/workflows/bump-version.yml`" --label ignore-changelog --base ${{ env.targetBranch }} minor: if: ${{ github.event.inputs.versionType == 'minor' }} runs-on: ubuntu-latest @@ -161,7 +161,7 @@ jobs: git add . git commit -m "Bump ${{ github.event.inputs.versionType }} version" git push --set-upstream origin "${{ env.newBranch }}" - gh pr create --title "Bump ${{ github.event.inputs.targetBranch }} branch to ${{ env.newVersion }}" --body "Bump version to prep for next release." --label ignore-changelog --base ${{ env.targetBranch }} + gh pr create --title "Bump ${{ github.event.inputs.targetBranch }} branch to ${{ env.newVersion }}" --body "Bump version to prep for next release. Generated by `.github/workflows/bump-version.yml`" --label ignore-changelog --base ${{ env.targetBranch }} major: if: ${{ github.event.inputs.versionType == 'major' }} @@ -231,5 +231,5 @@ jobs: git add . git commit -m "Bump ${{ github.event.inputs.versionType }} version" git push --set-upstream origin "${{ env.newBranch }}" - gh pr create --title "Bump ${{ github.event.inputs.targetBranch }} branch to ${{ env.newVersion }}" --body "Bump version to prep for next release." --label ignore-changelog --base ${{ env.targetBranch }} + gh pr create --title "Bump ${{ github.event.inputs.targetBranch }} branch to ${{ env.newVersion }}" --body "Bump version to prep for next release. Generated by `.github/workflows/bump-version.yml`" --label ignore-changelog --base ${{ env.targetBranch }} \ No newline at end of file From 472eee6a1db4276789f6f6e999a545b34a072e8d Mon Sep 17 00:00:00 2001 From: Charles Ewert Date: Mon, 22 Jul 2024 22:33:04 -0400 Subject: [PATCH 3/5] split up lint jobs into seperate workflows and only run them when needed --- .github/workflows/lint-brightscript.yml | 20 +++++ .github/workflows/lint-json.yml | 23 ++++++ .github/workflows/lint-markdown.yml | 23 ++++++ .github/workflows/lint-spelling.yml | 22 ++++++ .github/workflows/lint-translation-files.yml | 25 ++++++ .github/workflows/lint.yml | 81 -------------------- 6 files changed, 113 insertions(+), 81 deletions(-) create mode 100644 .github/workflows/lint-brightscript.yml create mode 100644 .github/workflows/lint-json.yml create mode 100644 .github/workflows/lint-markdown.yml create mode 100644 .github/workflows/lint-spelling.yml create mode 100644 .github/workflows/lint-translation-files.yml delete mode 100644 .github/workflows/lint.yml diff --git a/.github/workflows/lint-brightscript.yml b/.github/workflows/lint-brightscript.yml new file mode 100644 index 000000000..560bfd8be --- /dev/null +++ b/.github/workflows/lint-brightscript.yml @@ -0,0 +1,20 @@ +name: lint-brightscript +on: + pull_request: + paths: + - "**/*.brs" + - "**/*.bs" + +jobs: + run: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@master + - uses: actions/setup-node@master + with: + node-version: "lts/*" + cache: "npm" + - run: npm ci + - run: npx ropm install + - run: npm run validate + - run: npm run check-formatting diff --git a/.github/workflows/lint-json.yml b/.github/workflows/lint-json.yml new file mode 100644 index 000000000..a5b9f9080 --- /dev/null +++ b/.github/workflows/lint-json.yml @@ -0,0 +1,23 @@ +name: lint-json +on: + pull_request: + paths: + - "!docs/api/**" + - "**/*.json" + +jobs: + run: + runs-on: ubuntu-latest + steps: + - name: Clone github repo + uses: actions/checkout@master + - uses: actions/setup-node@master + with: + node-version: "lts/*" + cache: "npm" + - name: Install npm dependencies + run: npm ci + - name: Install roku package dependencies + run: npx ropm install + - name: Validate JSON syntax + run: npm run lint-json \ No newline at end of file diff --git a/.github/workflows/lint-markdown.yml b/.github/workflows/lint-markdown.yml new file mode 100644 index 000000000..a3a0f1a28 --- /dev/null +++ b/.github/workflows/lint-markdown.yml @@ -0,0 +1,23 @@ +name: lint-markdown +on: + pull_request: + paths: + - "**/*.md" + +jobs: + run: + runs-on: ubuntu-latest + steps: + - name: Clone github repo + uses: actions/checkout@master + - uses: actions/setup-node@master + with: + node-version: "lts/*" + cache: "npm" + - name: Install npm dependencies + run: npm ci + - name: Install roku package dependencies + run: npx ropm install + - uses: xt0rted/markdownlint-problem-matcher@1a5fabfb577370cfdf5af944d418e4be3ea06f27 # v3 + - name: Lint markdown files + run: npm run lint-markdown diff --git a/.github/workflows/lint-spelling.yml b/.github/workflows/lint-spelling.yml new file mode 100644 index 000000000..55ba8b169 --- /dev/null +++ b/.github/workflows/lint-spelling.yml @@ -0,0 +1,22 @@ +name: lint-brightscript +on: + pull_request: + paths: + - "**/*.md" + +jobs: + run: + runs-on: ubuntu-latest + steps: + - name: Clone github repo + uses: actions/checkout@master + - uses: actions/setup-node@master + with: + node-version: "lts/*" + cache: "npm" + - name: Install npm dependencies + run: npm ci + - name: Install roku package dependencies + run: npx ropm install + - name: Check markdown files for spelling errors + run: npm run lint-spelling diff --git a/.github/workflows/lint-translation-files.yml b/.github/workflows/lint-translation-files.yml new file mode 100644 index 000000000..011547e4c --- /dev/null +++ b/.github/workflows/lint-translation-files.yml @@ -0,0 +1,25 @@ +name: lint-translation-files +on: + pull_request: + paths: + - "locale/*/*.ts" + +jobs: + run: + runs-on: ubuntu-latest + steps: + - name: Clone github repo + uses: actions/checkout@master + - name: Install xmllint and xmlstarlet using apt (from cache) + uses: awalsh128/cache-apt-pkgs-action@latest + with: + packages: libxml2-utils xmlstarlet + - name: Validate XML syntax + run: xmllint --noout ./locale/en_US/translations.ts + - name: Save output of duplicate check + run: echo "tsDuplicates=$(xmlstarlet sel -t -m '/TS/context/message/source' -c '.' -nl ./locale/en_US/translations.ts | sort | uniq -d | awk '{ printf "%s", $0 }')" >> $GITHUB_ENV + - name: Check for duplicates + run: xmlstarlet sel -t -m '/TS/context/message/source' -f -o ' ' -c '.' -nl ./locale/en_US/translations.ts | sort | uniq -d + - name: Duplicates found + if: env.tsDuplicates != '' + run: exit 1 diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml deleted file mode 100644 index a46dfa9d8..000000000 --- a/.github/workflows/lint.yml +++ /dev/null @@ -1,81 +0,0 @@ -name: lint -on: - pull_request: - -jobs: - brightscript: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@master - - uses: actions/setup-node@master - with: - node-version: "lts/*" - cache: "npm" - - run: npm ci - - run: npx ropm install - - run: npm run validate - - run: npm run check-formatting - translation-files: - runs-on: ubuntu-latest - steps: - - name: Clone github repo - uses: actions/checkout@master - - name: Install xmllint and xmlstarlet using apt (from cache) - uses: awalsh128/cache-apt-pkgs-action@latest - with: - packages: libxml2-utils xmlstarlet - - name: Validate XML syntax - run: xmllint --noout ./locale/en_US/translations.ts - - name: Save output of duplicate check - run: echo "tsDuplicates=$(xmlstarlet sel -t -m '/TS/context/message/source' -c '.' -nl ./locale/en_US/translations.ts | sort | uniq -d | awk '{ printf "%s", $0 }')" >> $GITHUB_ENV - - name: Check for duplicates - run: xmlstarlet sel -t -m '/TS/context/message/source' -f -o ' ' -c '.' -nl ./locale/en_US/translations.ts | sort | uniq -d - - name: Duplicates found - if: env.tsDuplicates != '' - run: exit 1 - json: - runs-on: ubuntu-latest - steps: - - name: Clone github repo - uses: actions/checkout@master - - uses: actions/setup-node@master - with: - node-version: "lts/*" - cache: "npm" - - name: Install npm dependencies - run: npm ci - - name: Install roku package dependencies - run: npx ropm install - - name: Validate JSON syntax - run: npm run lint-json - markdown: - runs-on: ubuntu-latest - steps: - - name: Clone github repo - uses: actions/checkout@master - - uses: actions/setup-node@master - with: - node-version: "lts/*" - cache: "npm" - - name: Install npm dependencies - run: npm ci - - name: Install roku package dependencies - run: npx ropm install - - uses: xt0rted/markdownlint-problem-matcher@1a5fabfb577370cfdf5af944d418e4be3ea06f27 # v3 - - name: Lint markdown files - run: npm run lint-markdown - spelling: - runs-on: ubuntu-latest - steps: - - name: Clone github repo - uses: actions/checkout@master - - uses: actions/setup-node@master - with: - node-version: "lts/*" - cache: "npm" - - name: Install npm dependencies - run: npm ci - - name: Install roku package dependencies - run: npx ropm install - - name: Check markdown files for spelling errors - run: npm run lint-spelling From b7654a77aa534d0b29c6fb6f2b86ee17809e1214 Mon Sep 17 00:00:00 2001 From: Charles Ewert Date: Mon, 22 Jul 2024 22:53:40 -0400 Subject: [PATCH 4/5] increase days until stale to 30 and days to close to 15 --- .github/workflows/auto-close-stale-pr.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/auto-close-stale-pr.yml b/.github/workflows/auto-close-stale-pr.yml index 5cdd7447f..00892eec5 100644 --- a/.github/workflows/auto-close-stale-pr.yml +++ b/.github/workflows/auto-close-stale-pr.yml @@ -15,9 +15,9 @@ jobs: days-before-issue-stale: -1 days-before-issue-close: -1 stale-pr-label: stale - stale-pr-message: "This pull request has been inactive for 21 days and will be automatically closed in 7 days if there is no further activity." - close-pr-message: "This pull request has been closed because it has been inactive for 28 days. You may submit a new pull request if desired." - days-before-pr-stale: 21 - days-before-pr-close: 7 + stale-pr-message: "This pull request has been inactive for 30 days and will be automatically closed in 15 days if there is no further activity." + close-pr-message: "This pull request has been closed because it has been inactive for 45 days. You may submit a new pull request if desired." + days-before-pr-stale: 30 + days-before-pr-close: 15 exempt-draft-pr: true repo-token: ${{ secrets.JF_BOT_TOKEN }} From 50c6f8047440690be72a3c87962d2e5ef3517dd5 Mon Sep 17 00:00:00 2001 From: Charles Ewert Date: Mon, 22 Jul 2024 23:13:13 -0400 Subject: [PATCH 5/5] update name --- .github/workflows/lint-spelling.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/lint-spelling.yml b/.github/workflows/lint-spelling.yml index 55ba8b169..c2c9b8545 100644 --- a/.github/workflows/lint-spelling.yml +++ b/.github/workflows/lint-spelling.yml @@ -1,4 +1,4 @@ -name: lint-brightscript +name: lint-spelling on: pull_request: paths: