Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update to Angular 18 #160

Open
wants to merge 9 commits into
base: main
Choose a base branch
from
Open

Update to Angular 18 #160

wants to merge 9 commits into from

Conversation

m-akinc
Copy link
Contributor

@m-akinc m-akinc commented Jan 7, 2025

Addresses #157

In addition to updating the dependency version, I'm fixing the following:

Implementation

Updated dependencies:

  • @angular/core to 18.2.13 (latest <19)
  • @angular-eslint packages to 18.4.3 (latest <19)
  • @typescript-eslint/eslint-plugin and @typescript-eslint/parser to 7.18.0 (latest <8)

After updating the version of @typescript-eslint/parser, I began getting the following test failure:

Error: Error while loading rule '@typescript-eslint/prefer-optional-chain': You have used a rule which requires parserServices to be generated. You must therefore provide a value for the "parserOptions.project" property for @typescript-eslint/parser.
Parser: C:\dev\javascript-styleguide\node_modules\@typescript-eslint\parser\dist\index.js
Occurred while linting C:\dev\javascript-styleguide\tests\typescript\index.ts

One of the typescript-eslint maintainers says that the rule does not require parserServices and seems to credit the error to using the rule on a non-ts file or with parser other than @typescript-eslint/parser, but that doesn't seem to be the case for our tests. In any case, clients should already be setting parserOptions.project for running eslint on their ts files, so I wouldn't expect this to cause issues.

Testing

  • Ran npm run print-evaluated-rules:diff and the only change is that the no-host-metadata-property rule was removed from the recommended eslint-plugin config (rule is deprecated in version 18 and fully removed in version 19). This should not break clients, as the rule still exists (so clients can still turn it on/off) and the default config is just more permissive.
  • Ran npm run print-evaluated-rules to do an audit, which turned up
    no warnings or diverged rules.
  • Ran npm run print-available-rules and the only new rule available in the updated version was @angular-eslint/runtime-localize, which we now enable.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Won't submit until ready to update clients.

@m-akinc m-akinc requested a review from jattasNI January 8, 2025 21:40
// declared using "export" rather than the old "main" syntax in package.json.
// See https://github.com/typescript-eslint/typescript-eslint/issues/7565
// and https://github.com/import-js/eslint-plugin-import/issues/2703
// eslint-disable-next-line import/no-unresolved
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The new version of eslint-plugin's package.json file no longer has "main": "dist/index.js" and instead uses the newer "exports" property. Unfortunately, eslint-plugin-import doesn't know how to resolve entry points in commonjs modules that are declared using "export". See typescript-eslint/typescript-eslint#7565 and import-js/eslint-plugin-import#2703

Copy link
Collaborator

@jattasNI jattasNI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me, but withholding final approval until we're ready to start the release train.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants