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

Chore/8201 deprecate json tokens #8246

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

weronikaolejniczak
Copy link
Contributor

@weronikaolejniczak weronikaolejniczak commented Dec 17, 2024

Summary

I added a new rule to our ESLint plugin, no-restricted-eui-imports, that won't conflict with the inbuilt no-restricted-imports rule and will allow us to define several error levels at once. I.e. we want some imports to be marked as warning and not an error, as it's done in Kibana.

Screenshot 2025-01-07 at 11 48 02 Screenshot 2025-01-07 at 11 50 41

Context:

The JSON token imports in @kbn/eslint/module_migration need to be removed as well:

https://github.com/elastic/kibana/blob/212b1926743ca5821992c2877d9c68f621e1875e/packages/kbn-eslint-config/.eslintrc.js#L131-L140

QA

  1. Pack the ESLint plugin: yarn workspace @elastic/eslint-plugin-eui pack
  2. Go to Kibana and point the EUI ESLint plugin to the tarball: "@elastic/eslint-plugin-eui": "file:path/to/the/package.tgz"
  3. Install dependencies in Kibana: yarn and bootstrap: yarn kbn bootstrap --no-validate
Screenshot 2025-01-07 at 11 52 56 Screenshot 2025-01-07 at 11 53 14

Unit tests: yarn workspace @elastic/eslint-plugin-eui test

@weronikaolejniczak weronikaolejniczak force-pushed the chore/8201-deprecate-json-tokens branch from 04461a6 to 5cd5dd5 Compare December 29, 2024 18:44
@weronikaolejniczak weronikaolejniczak force-pushed the chore/8201-deprecate-json-tokens branch from 5cd5dd5 to 6a751f9 Compare January 7, 2025 10:05
@weronikaolejniczak weronikaolejniczak marked this pull request as ready for review January 7, 2025 10:52
@weronikaolejniczak weronikaolejniczak requested a review from a team as a code owner January 7, 2025 10:52
@weronikaolejniczak weronikaolejniczak force-pushed the chore/8201-deprecate-json-tokens branch from 6a751f9 to b8d7a96 Compare January 8, 2025 10:56
@kibanamachine
Copy link

Preview staging links for this PR:

@elasticmachine
Copy link
Collaborator

💚 Build Succeeded

History

Copy link
Contributor

@acstll acstll left a comment

Choose a reason for hiding this comment

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

This is great, thank you @weronikaolejniczak (also for the patience!)

I got this working locally without issues 👌

image

I added some comments, and I included [non-blocking] in some of them, but thinking about it, all comments are non-blocking because they're mostly questions and ideas that could turn into improvements…

Let me know what you think and we can get this finally merged 🙂

type: 'problem',
docs: {
description: 'Disallow deprecated EUI imports.',
category: 'Possible Errors',
Copy link
Contributor

Choose a reason for hiding this comment

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

[non-blocking] I couldn't find the category props in the meta structure docs, is it needed?

meta: {
type: 'problem',
docs: {
description: 'Disallow deprecated EUI imports.',
Copy link
Contributor

Choose a reason for hiding this comment

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

I would rephrase this to something like "Discourage" or "Warn about", to me "disallow" sounds a bit authoritarian (I don't know if that makes sense 🙃)

Copy link
Contributor Author

Choose a reason for hiding this comment

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

@acstll that makes total sense 😄 I'll do that!

return {
ImportDeclaration(node) {
allPatterns.forEach(({ pattern, message }) => {
const regex = new RegExp(pattern.replace('*', '.*'));
Copy link
Contributor

Choose a reason for hiding this comment

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

I need to ask this because I'm not well-versed with globs — will this pattern.replace('*', '.*') play nicely with any custom user patterns? (I think yes but I'm not sure)

@@ -0,0 +1,2 @@
{
Copy link
Contributor

Choose a reason for hiding this comment

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

[non-blocking] I think jest will work without a config file (using the defaults?), maybe this file is not needed?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I thought the same thing but couldn't run jest without a config, maybe I was missing some param.

Copy link
Contributor

Choose a reason for hiding this comment

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

I also wasn't sure, but it runs locally for me without it 🤔

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

Successfully merging this pull request may close these issues.

Deprecate euiThemeVars
4 participants