diff --git a/.backportrc.json b/.backportrc.json index 60ef9f94..01904179 100644 --- a/.backportrc.json +++ b/.backportrc.json @@ -7,7 +7,13 @@ "backportBranchName": "backport/{{targetBranch}}-{{refValues}}", "prTitle": "{{sourcePullRequest.title}} (backport #{{sourcePullRequest.number}})", "targetBranchChoices": [ +<<<<<<< HEAD "maintenance/v5.3" +======= + "main", + "maintenance/v5.3", + "maintenance/v5.4" +>>>>>>> b69ed87 (feat: TypeScript 5.5 (#1256)) ], "//": "~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\"." } diff --git a/.gitattributes b/.gitattributes index b2af4efb..b0fa245d 100644 --- a/.gitattributes +++ b/.gitattributes @@ -9,8 +9,10 @@ /.github/workflows/auto-approve.yml linguist-generated /.github/workflows/auto-merge.yml linguist-generated /.github/workflows/auto-tag-dev-v5.3.yml linguist-generated +/.github/workflows/auto-tag-dev-v5.4.yml linguist-generated /.github/workflows/auto-tag-dev.yml linguist-generated /.github/workflows/auto-tag-releases-v5.3.yml linguist-generated +/.github/workflows/auto-tag-releases-v5.4.yml linguist-generated /.github/workflows/auto-tag-releases.yml linguist-generated /.github/workflows/backport.yml linguist-generated /.github/workflows/build.yml linguist-generated @@ -18,6 +20,7 @@ /.github/workflows/release.yml linguist-generated /.github/workflows/upgrade-main.yml linguist-generated /.github/workflows/upgrade-maintenance-v5.3.yml linguist-generated +/.github/workflows/upgrade-maintenance-v5.4.yml linguist-generated /.gitignore linguist-generated /.npmignore linguist-generated /.prettierrc.json linguist-generated diff --git a/.github/workflows/auto-tag-dev-v5.4.yml b/.github/workflows/auto-tag-dev-v5.4.yml new file mode 100644 index 00000000..f524f827 --- /dev/null +++ b/.github/workflows/auto-tag-dev-v5.4.yml @@ -0,0 +1,59 @@ +# ~~ Generated by projen. To modify, edit .projenrc.ts and run "npx projen". + +name: auto-tag-dev-v5.4 +run-name: Auto-Tag Prerelease (v5.4) +on: + schedule: + - cron: 0 10 * * 0,2-6 + workflow_dispatch: {} +jobs: + pre-flight: + name: Pre-Flight Checks + runs-on: ubuntu-latest + permissions: + contents: read + outputs: + sha: ${{ steps.git.outputs.sha }} + steps: + - name: Checkout + uses: actions/checkout@v3 + with: + repository: ${{ github.repository }} + ref: maintenance/v5.4 + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + cache: yarn + node-version: "18" + - name: Install dependencies + run: yarn install --frozen-lockfile + - name: Build + run: yarn build + - name: Identify git SHA + id: git + run: echo sha=$(git rev-parse HEAD) >> $GITHUB_OUTPUT + auto-tag: + name: Auto-Tag Release + needs: pre-flight + runs-on: ubuntu-latest + permissions: {} + steps: + - name: Checkout + uses: actions/checkout@v3 + with: + repository: ${{ github.repository }} + token: ${{ secrets.PROJEN_GITHUB_TOKEN }} + ref: ${{ needs.pre-flight.outputs.sha }} + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + cache: yarn + node-version: "18" + - name: Install dependencies + run: yarn install --frozen-lockfile + - name: Set git identity + run: |- + git config user.name "github-actions" + git config user.email "github-actions@github.com" + - name: Tag PreRelease + run: yarn tag-release --idempotent --no-sign --push --prerelease=dev --release-line=5.4 diff --git a/.github/workflows/auto-tag-dev.yml b/.github/workflows/auto-tag-dev.yml index dbef1e2b..1c73e487 100644 --- a/.github/workflows/auto-tag-dev.yml +++ b/.github/workflows/auto-tag-dev.yml @@ -56,4 +56,8 @@ jobs: git config user.name "github-actions" git config user.email "github-actions@github.com" - name: Tag PreRelease +<<<<<<< HEAD run: yarn tag-release --idempotent --no-sign --push --prerelease=dev --release-line=5.3 +======= + run: yarn tag-release --idempotent --no-sign --push --prerelease=dev --release-line=5.5 +>>>>>>> b69ed87 (feat: TypeScript 5.5 (#1256)) diff --git a/.github/workflows/auto-tag-releases-v5.4.yml b/.github/workflows/auto-tag-releases-v5.4.yml new file mode 100644 index 00000000..a1a13781 --- /dev/null +++ b/.github/workflows/auto-tag-releases-v5.4.yml @@ -0,0 +1,59 @@ +# ~~ Generated by projen. To modify, edit .projenrc.ts and run "npx projen". + +name: auto-tag-releases-v5.4 +run-name: Auto-Tag Release (v5.4) +on: + schedule: + - cron: 0 10 * * 1 + workflow_dispatch: {} +jobs: + pre-flight: + name: Pre-Flight Checks + runs-on: ubuntu-latest + permissions: + contents: read + outputs: + sha: ${{ steps.git.outputs.sha }} + steps: + - name: Checkout + uses: actions/checkout@v3 + with: + repository: ${{ github.repository }} + ref: maintenance/v5.4 + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + cache: yarn + node-version: "18" + - name: Install dependencies + run: yarn install --frozen-lockfile + - name: Build + run: yarn build + - name: Identify git SHA + id: git + run: echo sha=$(git rev-parse HEAD) >> $GITHUB_OUTPUT + auto-tag: + name: Auto-Tag Release + needs: pre-flight + runs-on: ubuntu-latest + permissions: {} + steps: + - name: Checkout + uses: actions/checkout@v3 + with: + repository: ${{ github.repository }} + token: ${{ secrets.PROJEN_GITHUB_TOKEN }} + ref: ${{ needs.pre-flight.outputs.sha }} + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + cache: yarn + node-version: "18" + - name: Install dependencies + run: yarn install --frozen-lockfile + - name: Set git identity + run: |- + git config user.name "github-actions" + git config user.email "github-actions@github.com" + - name: Tag Release + run: yarn tag-release --idempotent --no-sign --push --release-line=5.4 diff --git a/.github/workflows/auto-tag-releases.yml b/.github/workflows/auto-tag-releases.yml index 21fb1df3..3dcfcf2e 100644 --- a/.github/workflows/auto-tag-releases.yml +++ b/.github/workflows/auto-tag-releases.yml @@ -56,4 +56,8 @@ jobs: git config user.name "github-actions" git config user.email "github-actions@github.com" - name: Tag Release +<<<<<<< HEAD run: yarn tag-release --idempotent --no-sign --push --release-line=5.3 +======= + run: yarn tag-release --idempotent --no-sign --push --release-line=5.5 +>>>>>>> b69ed87 (feat: TypeScript 5.5 (#1256)) diff --git a/.github/workflows/upgrade-maintenance-v5.4.yml b/.github/workflows/upgrade-maintenance-v5.4.yml new file mode 100644 index 00000000..1f06ff15 --- /dev/null +++ b/.github/workflows/upgrade-maintenance-v5.4.yml @@ -0,0 +1,97 @@ +# ~~ Generated by projen. To modify, edit .projenrc.ts and run "npx projen". + +name: upgrade-maintenance-v5.4 +on: + workflow_dispatch: {} + schedule: + - cron: 0 0 * * * +jobs: + upgrade: + name: Upgrade + runs-on: ubuntu-latest + permissions: + contents: read + outputs: + patch_created: ${{ steps.create_patch.outputs.patch_created }} + steps: + - name: Checkout + uses: actions/checkout@v3 + with: + ref: maintenance/v5.4 + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + node-version: lts/* + - name: Install dependencies + run: yarn install --check-files --frozen-lockfile + - name: Back-port projenrc changes from main + env: + CI: "false" + run: git fetch origin main && git checkout FETCH_HEAD -- README.md && yarn projen + - name: Upgrade dependencies + run: npx projen upgrade + - name: Find mutations + id: create_patch + run: |- + git add . + git diff --staged --patch --exit-code > .repo.patch || echo "patch_created=true" >> $GITHUB_OUTPUT + working-directory: ./ + - name: Upload patch + if: steps.create_patch.outputs.patch_created + uses: actions/upload-artifact@v4 + with: + name: .repo.patch + path: .repo.patch + overwrite: true + pr: + name: Create Pull Request + needs: upgrade + runs-on: ubuntu-latest + permissions: + contents: read + if: ${{ needs.upgrade.outputs.patch_created }} + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + ref: maintenance/v5.4 + - name: Download patch + uses: actions/download-artifact@v4 + with: + name: .repo.patch + path: ${{ runner.temp }} + - name: Apply patch + run: '[ -s ${{ runner.temp }}/.repo.patch ] && git apply ${{ runner.temp }}/.repo.patch || echo "Empty patch. Skipping."' + - name: Set git identity + run: |- + git config user.name "github-actions" + git config user.email "github-actions@github.com" + - name: Create Pull Request + id: create-pr + uses: peter-evans/create-pull-request@v6 + with: + token: ${{ secrets.PROJEN_GITHUB_TOKEN }} + commit-message: |- + chore(deps): upgrade dependencies + + Upgrades project dependencies. See details in [workflow run]. + + [Workflow Run]: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }} + + ------ + + *Automatically created by projen via the "upgrade-maintenance-v5.4" workflow* + branch: github-actions/upgrade-maintenance-v5.4 + title: "chore(deps): upgrade dependencies" + labels: auto-approve + body: |- + Upgrades project dependencies. See details in [workflow run]. + + [Workflow Run]: ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }} + + ------ + + *Automatically created by projen via the "upgrade-maintenance-v5.4" workflow* + author: github-actions + committer: github-actions + signoff: true diff --git a/.gitignore b/.gitignore index f8262e71..026723a9 100644 --- a/.gitignore +++ b/.gitignore @@ -44,6 +44,7 @@ jspm_packages/ !/.eslintrc.json !/.github/workflows/upgrade-main.yml !/.github/workflows/upgrade-maintenance-v5.3.yml +!/.github/workflows/upgrade-maintenance-v5.4.yml /build-tools/tsconfig.json /projenrc/tsconfig.json /test/tsconfig.json @@ -60,6 +61,8 @@ jspm_packages/ !/.github/workflows/auto-tag-releases.yml !/.github/workflows/auto-tag-dev-v5.3.yml !/.github/workflows/auto-tag-releases-v5.3.yml +!/.github/workflows/auto-tag-dev-v5.4.yml +!/.github/workflows/auto-tag-releases-v5.4.yml !/.backportrc.json !/.github/workflows/backport.yml !/.projenrc.ts diff --git a/.projen/deps.json b/.projen/deps.json index 934b0d42..e784dc34 100644 --- a/.projen/deps.json +++ b/.projen/deps.json @@ -186,7 +186,11 @@ }, { "name": "typescript", +<<<<<<< HEAD "version": "~5.3", +======= + "version": "~5.5", +>>>>>>> b69ed87 (feat: TypeScript 5.5 (#1256)) "type": "runtime" }, { diff --git a/.projen/files.json b/.projen/files.json index 383473b7..513aac1e 100644 --- a/.projen/files.json +++ b/.projen/files.json @@ -7,8 +7,10 @@ ".github/workflows/auto-approve.yml", ".github/workflows/auto-merge.yml", ".github/workflows/auto-tag-dev-v5.3.yml", + ".github/workflows/auto-tag-dev-v5.4.yml", ".github/workflows/auto-tag-dev.yml", ".github/workflows/auto-tag-releases-v5.3.yml", + ".github/workflows/auto-tag-releases-v5.4.yml", ".github/workflows/auto-tag-releases.yml", ".github/workflows/backport.yml", ".github/workflows/build.yml", @@ -16,6 +18,7 @@ ".github/workflows/release.yml", ".github/workflows/upgrade-main.yml", ".github/workflows/upgrade-maintenance-v5.3.yml", + ".github/workflows/upgrade-maintenance-v5.4.yml", ".gitignore", ".npmignore", ".prettierrc.json", diff --git a/.projenrc.ts b/.projenrc.ts index c8ff66d8..15003e16 100644 --- a/.projenrc.ts +++ b/.projenrc.ts @@ -6,20 +6,24 @@ import { SUPPORT_POLICY, SupportPolicy } from './projenrc/support'; import { UpdateIntegPackage } from './projenrc/update-integ-package'; import { UpgradeDependencies } from './projenrc/upgrade-dependencies'; -// See 'projenrc/support.ts' for TypeScript versions we are tracking. To add a new version: +// See 'projenrc/support.ts' for TypeScript versions we are tracking. To add a new version: // -// 1. Fork the current `main` to a maintenance branch: -// `git push origin main:maintenance/vx.y` (x.y is the TS version that is about to be replaced by a new release) -// 2. Add a branch protection rule for the new maintenance branch -// 3. Edit `support.ts`, maintenance EOL date for the current version is 6 months from -// today, make the new version current. -// 4. Update `minNodeVersion` to the oldest LTS version of Node (i.e. dropping support for EOL versions of Node) -// 5. `npx projen` -// 6. Update the version list in the README (remember to remove EOS versions) -// 7. Create a PR -// 8. Note that merging the PR doesn't trigger a release. Release are perfoemd on a weekly schedule, you should manully create a release by trigeeting this workflow: -// https://github.com/aws/jsii-compiler/actions/workflows/auto-tag-releases.yml -// 9. Perform new version steps for `jsii-rosetta` +// 1. Fork the current `main` to a maintenance branch: +// `git switch main && git fetch --all && git pull` +// `git push origin main:maintenance/vX.Y` (X.Y is the TS version that is about to be replaced by a new release) +// 2. Add a branch protection rule for the new maintenance branch. +// Copy the settings from the branch for the version that is about to be replaced. +// 3. Edit `projenrc/support.ts`, maintenance EOL date for the current version to be 6 months from +// today (round up to the mid-point or end of month), make the new version current. +// 4. Update `minNodeVersion` to the oldest LTS version of Node (i.e. dropping support for EOL versions of Node) +// 5. `npx projen` +// 6. Update the version list in the README (remember to remove EOS versions) +// 7. If any versions dropped into EOS, change the respective branch protection rule to include "Lock branch" +// 8. Create a PR, with title "eat: TypeScript X.Y" +// 9. Note that merging the PR doesn't trigger a release. Release are performed on a weekly schedule. +// You need to manually create a release by triggering this workflow: +// https://github.com/aws/jsii-compiler/actions/workflows/auto-tag-releases.yml +// 10. Perform new version steps for `jsii-rosetta` const project = new typescript.TypeScriptProject({ projenrcTs: true, diff --git a/package.json b/package.json index ce151c32..15ce8409 100644 --- a/package.json +++ b/package.json @@ -81,7 +81,11 @@ "semver-intersect": "^1.5.0", "sort-json": "^2.0.1", "spdx-license-list": "^6.9.0", +<<<<<<< HEAD "typescript": "~5.3", +======= + "typescript": "~5.5", +>>>>>>> b69ed87 (feat: TypeScript 5.5 (#1256)) "yargs": "^17.7.2" }, "engines": { diff --git a/projenrc/support.ts b/projenrc/support.ts index fd3bbc6c..2d4d2edf 100644 --- a/projenrc/support.ts +++ b/projenrc/support.ts @@ -2,13 +2,18 @@ import { JsonFile, Project } from 'projen'; import type { ReleasesDocument } from '../src/support'; export const SUPPORT_POLICY: ReleasesDocument = { +<<<<<<< HEAD current: '5.3', +======= + current: '5.5', +>>>>>>> b69ed87 (feat: TypeScript 5.5 (#1256)) maintenance: { // version: End-of-support date '5.0': new Date('2024-01-31'), '5.1': new Date('2024-02-28'), '5.2': new Date('2024-06-30'), '5.3': new Date('2024-10-15'), + '5.4': new Date('2025-02-28'), }, }; diff --git a/releases.json b/releases.json index e160c91b..cef96b58 100644 --- a/releases.json +++ b/releases.json @@ -1,10 +1,15 @@ { +<<<<<<< HEAD "current": "5.3", +======= + "current": "5.5", +>>>>>>> b69ed87 (feat: TypeScript 5.5 (#1256)) "maintenance": { "5.0": "2024-01-31T00:00:00.000Z", "5.1": "2024-02-28T00:00:00.000Z", "5.2": "2024-06-30T00:00:00.000Z", - "5.3": "2024-10-15T00:00:00.000Z" + "5.3": "2024-10-15T00:00:00.000Z", + "5.4": "2025-02-28T00:00:00.000Z" }, "//": "~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\"." } diff --git a/test/tsconfig/helpers.ts b/test/tsconfig/helpers.ts index 0614ec25..096ccdbf 100644 --- a/test/tsconfig/helpers.ts +++ b/test/tsconfig/helpers.ts @@ -189,6 +189,7 @@ export function fcTsconfig( verbatimModuleSyntax: fc.boolean(), esModuleInterop: fc.boolean(), useDefineForClassFields: fc.boolean(), + isolatedDeclarations: fc.boolean(), }; // limit to only allowed keys diff --git a/yarn.lock b/yarn.lock index c2e7e670..92320de6 100644 --- a/yarn.lock +++ b/yarn.lock @@ -6060,16 +6060,7 @@ string-length@^4.0.1: char-regex "^1.0.2" strip-ansi "^6.0.0" -"string-width-cjs@npm:string-width@^4.2.0": - version "4.2.3" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" - integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== - dependencies: - emoji-regex "^8.0.0" - is-fullwidth-code-point "^3.0.0" - strip-ansi "^6.0.1" - -"string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: +"string-width-cjs@npm:string-width@^4.2.0", "string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: version "4.2.3" resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== @@ -6122,14 +6113,7 @@ string_decoder@^1.1.1: dependencies: safe-buffer "~5.2.0" -"strip-ansi-cjs@npm:strip-ansi@^6.0.1": - version "6.0.1" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" - integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== - dependencies: - ansi-regex "^5.0.1" - -strip-ansi@^6.0.0, strip-ansi@^6.0.1: +"strip-ansi-cjs@npm:strip-ansi@^6.0.1", strip-ansi@^6.0.0, strip-ansi@^6.0.1: version "6.0.1" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== @@ -6457,10 +6441,17 @@ typescript@~3.9.10: resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.9.10.tgz#70f3910ac7a51ed6bef79da7800690b19bf778b8" integrity sha512-w6fIxVE/H1PkLKcCPsFqKE7Kv7QUwhU8qQY2MueZXWx5cPZdwFupLgKK3vntcK98BtNHZtAF4LA/yl2a7k8R6Q== +<<<<<<< HEAD typescript@~5.3: version "5.3.3" resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.3.3.tgz#b3ce6ba258e72e6305ba66f5c9b452aaee3ffe37" integrity sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw== +======= +typescript@~5.5: + version "5.5.4" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.5.4.tgz#d9852d6c82bad2d2eda4fd74a5762a8f5909e9ba" + integrity sha512-Mtq29sKDAEYP7aljRgtPOpTvOfbwRWlS6dPRzwjdE+C0R4brX/GUyhHSecbHMFLNBLcJIPt9nl9yG5TZ1weH+Q== +>>>>>>> b69ed87 (feat: TypeScript 5.5 (#1256)) unbox-primitive@^1.0.2: version "1.0.2" @@ -6708,7 +6699,7 @@ word-wrap@^1.2.5: resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.5.tgz#d2c45c6dd4fbce621a66f136cbe328afd0410b34" integrity sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA== -"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0": +"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0", wrap-ansi@^7.0.0: version "7.0.0" resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== @@ -6726,15 +6717,6 @@ wrap-ansi@^6.2.0: string-width "^4.1.0" strip-ansi "^6.0.0" -wrap-ansi@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" - integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== - dependencies: - ansi-styles "^4.0.0" - string-width "^4.1.0" - strip-ansi "^6.0.0" - wrap-ansi@^8.1.0: version "8.1.0" resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-8.1.0.tgz#56dc22368ee570face1b49819975d9b9a5ead214"