Skip to content
Snippets Groups Projects
Select Git revision
  • 4328ad86f0b6e0d79b2fc4e7e900b55279d1f2ba
  • master default protected
  • 4
  • 4.2
  • 4.2.2
  • 4.2.1
  • 4.2.0
  • 4.1
  • 4.1.1
  • 4.1.0
  • 4.0.3
  • 4.0.2
  • 4.0
  • 4.0.1
  • 4.0.0
15 results

gitlab-ci-node-vault.yml

Blame
  • .eslintrc.js 6.48 KiB
    module.exports = {
      root: true,
      env: {
        node: true,
      },
      plugins: ['@renovate', 'typescript-enum', 'jest-formatting'],
      extends: [
        'eslint:recommended',
        'plugin:import/errors',
        'plugin:import/warnings',
        'plugin:import/typescript',
        'plugin:jest/recommended',
        'plugin:jest/style',
        // https://github.com/typescript-eslint/typescript-eslint/tree/master/packages/eslint-plugin/src/configs
        'plugin:@typescript-eslint/recommended',
        'plugin:@typescript-eslint/recommended-requiring-type-checking',
        'plugin:promise/recommended',
        'plugin:jest-formatting/recommended',
        'prettier',
      ],
      parserOptions: {
        ecmaVersion: 9,
        tsconfigRootDir: __dirname,
        project: ['./tsconfig.lint.json'],
        extraFileExtensions: ['.mjs'],
      },
      rules: {
        /*
         * checks done by typescript.
         *
         * https://github.com/typescript-eslint/typescript-eslint/blob/master/docs/getting-started/linting/FAQ.md#eslint-plugin-import
         * required for esm check
         */
        'import/default': 2,
        'import/named': 2,
        'import/namespace': 2,
        'import/no-named-as-default-member': 0,
        'import/no-extraneous-dependencies': [
          'error',
          { devDependencies: ['test/**/*', '**/*.spec.ts'] },
        ],
        'import/prefer-default-export': 0, // no benefit
    
        'import/no-cycle': 2, // cycles don't work when moving to esm
    
        /*
         * This rule is not needed since the project uses typescript and the rule
         * `@typescript-eslint/explicit-function-return-type`.
         *
         * Any non-exhaustive definition of the function will therefore result in a
         * typescript TS2366 error.
         */
        'consistent-return': 0,
    
        // other rules
        eqeqeq: 'error',
        'no-console': 'error',
        'no-negated-condition': 'error',
        'no-param-reassign': 'error',
        'no-template-curly-in-string': 'error',
        'sort-imports': [
          'error',
          {
            ignoreCase: false,
            ignoreDeclarationSort: true, // conflicts with our other import ordering rules
            ignoreMemberSort: false,
            memberSyntaxSortOrder: ['none', 'all', 'multiple', 'single'],
          },
        ],
    
        // mdast is a types only package `@types/mdast`
        'import/no-unresolved': ['error', { ignore: ['^mdast$'] }],
        'import/order': [
          'error',
          {
            alphabetize: {
              order: 'asc',
            },
          },
        ],
    
        // disallow direct `nock` module usage as it causes memory issues.
        // disallow `parse-link-header` to allow override ENV https://github.com/thlorenz/parse-link-header#environmental-variables
        // disallow `path` in favor of `upath`
        'no-restricted-imports': [
          2,
          { paths: ['nock', 'parse-link-header', 'path'] },
        ],
    
        '@typescript-eslint/consistent-type-assertions': [
          'error',
          { assertionStyle: 'as', objectLiteralTypeAssertions: 'allow' },
        ],
    
        // Makes no sense to allow type inference for expression parameters, but require typing the response
        '@typescript-eslint/explicit-function-return-type': [
          'error',
          { allowExpressions: true, allowTypedFunctionExpressions: true },
        ],
    
        // TODO: fix lint
        '@typescript-eslint/no-explicit-any': 0,
        // TODO: https://github.com/renovatebot/renovate/issues/7154
        '@typescript-eslint/no-non-null-assertion': 0,
        '@typescript-eslint/no-unused-vars': [
          2,
          {
            vars: 'all',
            args: 'none',
            ignoreRestSiblings: true,
          },
        ],
        '@typescript-eslint/prefer-optional-chain': 2,
        '@typescript-eslint/prefer-nullish-coalescing': 2,
        curly: [2, 'all'],
        'require-await': 2,
        // next 2 rules disabled due to https://github.com/microsoft/TypeScript/issues/20024
        '@typescript-eslint/no-unsafe-assignment': 0,
        '@typescript-eslint/no-unsafe-member-access': 0,
    
        // TODO: fix me
        '@typescript-eslint/no-unsafe-return': 0,
        '@typescript-eslint/no-unsafe-call': 0,
        '@typescript-eslint/no-unsafe-argument': 0, // thousands of errors :-/
    
        '@typescript-eslint/restrict-template-expressions': [
          2,
          { allowNumber: true, allowBoolean: true },
        ],
        '@typescript-eslint/restrict-plus-operands': 2,
    
        '@typescript-eslint/naming-convention': [
          2,
          {
            selector: 'enumMember',
            format: ['PascalCase'],
          },
        ],
    
        '@typescript-eslint/unbound-method': [2, { ignoreStatic: true }],
        '@typescript-eslint/ban-types': 2,
        '@renovate/jest-root-describe': 2,
    
        'typescript-enum/no-const-enum': 2,
        'typescript-enum/no-enum': 2,
        'object-shorthand': [
          'error',
          'always',
          {
            avoidQuotes: true,
          },
        ],
      },
      settings: {
        'import/parsers': {
          '@typescript-eslint/parser': ['.ts'],
        },
        'import/resolver': {
          typescript: {
            alwaysTryTypes: true, // always try to resolve types under `<root>@types` directory even it doesn't contain any source code, like `@types/unist`
            project: 'tsconfig.lint.json',
          },
        },
      },
      overrides: [
        {
          // files to check, so no `--ext` is required
          files: ['**/*.{js,mjs,cjs,ts}'],
        },
        {
          files: ['**/*.spec.ts', 'test/**'],
          env: {
            jest: true,
          },
          rules: {
            'no-template-curly-in-string': 0,
            'prefer-destructuring': 0,
            'prefer-promise-reject-errors': 0,
            'import/no-dynamic-require': 0,
            'global-require': 0,
    
            '@typescript-eslint/no-var-requires': 0,
            '@typescript-eslint/no-object-literal-type-assertion': 0,
            '@typescript-eslint/explicit-function-return-type': 0,
            '@typescript-eslint/unbound-method': 0,
    
            'jest/valid-title': [0, { ignoreTypeOfDescribeName: true }],
            'max-classes-per-file': 0,
            'class-methods-use-this': 0,
          },
        },
        {
          files: ['**/*.{js,mjs,cjs}'],
    
          rules: {
            '@typescript-eslint/explicit-function-return-type': 0,
            '@typescript-eslint/explicit-module-boundary-types': 0,
            '@typescript-eslint/restrict-template-expressions': 0,
          },
        },
        {
          files: ['tools/**/*.{ts,js,mjs,cjs}'],
          env: {
            node: true,
          },
          rules: {
            'import/no-extraneous-dependencies': [
              'error',
              { devDependencies: true },
            ],
            'no-console': 'off',
          },
        },
        {
          files: ['tools/**/*.{js,cjs}', 'bin/*.{js,cjs}'],
          rules: {
            // need commonjs
            '@typescript-eslint/no-var-requires': 'off',
          },
        },
        {
          files: ['*.mjs'],
          rules: {
            // esm always requires extensions
            'import/extensions': 0,
          },
        },
      ],
    };