diff --git a/common/config/rush/pnpm-lock.yaml b/common/config/rush/pnpm-lock.yaml index 9410607e4e08..c7ccefc03b10 100644 --- a/common/config/rush/pnpm-lock.yaml +++ b/common/config/rush/pnpm-lock.yaml @@ -2244,6 +2244,12 @@ packages: '@types/node': 17.0.15 dev: false + /@types/mdast/3.0.10: + resolution: {integrity: sha512-W864tg/Osz1+9f4lrGTZpCSO5/z4608eUp19tbozkq2HJK6i3z1kT0H9tlADXuYIb1YYOBByU4Jsqkk75q48qA==} + dependencies: + '@types/unist': 2.0.6 + dev: false + /@types/mime/1.3.2: resolution: {integrity: sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==} dev: false @@ -2382,6 +2388,10 @@ packages: resolution: {integrity: sha512-uO4CD2ELOjw8tasUrAhvnn2W4A0ZECOvMjCivJr4gA9pGgjv+qxKWY9GLTMVEK8ej85BxQOocUyE7hImmSQYcg==} dev: false + /@types/unist/2.0.6: + resolution: {integrity: sha512-PBjIUxZHOuj0R15/xuwJYjFi+KZdNFrehocChv4g5hu6aFroHue8m0lBP0POdK2nKzbw0cgV1mws8+V/JAcEkQ==} + dev: false + /@types/uuid/8.3.4: resolution: {integrity: sha512-c/I8ZRb51j+pYGAu5CrFMRxqZ2ke4y2grEBO5AUjgSkSk+qT2Ea+OdWElz/OiMf5MNpn2b17kuVBwZLQJXzihw==} dev: false @@ -3083,6 +3093,18 @@ packages: supports-color: 7.2.0 dev: false + /character-entities-legacy/1.1.4: + resolution: {integrity: sha512-3Xnr+7ZFS1uxeiUDvV02wQ+QDbc55o97tIV5zHScSPJpcLm/r0DFPcoY3tYRp+VZukxuMeKgXYmsXQHO05zQeA==} + dev: false + + /character-entities/1.2.4: + resolution: {integrity: sha512-iBMyeEHxfVnIakwOuDXpVkc54HijNgCyQB2w0VfGQThle6NXn50zU6V/u+LDhxHcDUPojn6Kpga3PTAD8W1bQw==} + dev: false + + /character-reference-invalid/1.1.4: + resolution: {integrity: sha512-mKKUkUbhPpQlCOfIuZkvSEgktjPFIsZKRRbC6KWVEMvlzblj3i3asQv5ODsrwt0N3pHAEvjP8KTQPHkp0+6jOg==} + dev: false + /charenc/0.0.2: resolution: {integrity: sha1-wKHS86cJLgN3S/qD8UwPxXkKhmc=} dev: false @@ -3827,6 +3849,18 @@ packages: tsconfig-paths: 3.12.0 dev: false + /eslint-plugin-markdown/2.2.1_eslint@7.32.0: + resolution: {integrity: sha512-FgWp4iyYvTFxPwfbxofTvXxgzPsDuSKHQy2S+a8Ve6savbujey+lgrFFbXQA0HPygISpRYWYBjooPzhYSF81iA==} + engines: {node: ^8.10.0 || ^10.12.0 || >= 12.0.0} + peerDependencies: + eslint: '>=6.0.0' + dependencies: + eslint: 7.32.0 + mdast-util-from-markdown: 0.8.5 + transitivePeerDependencies: + - supports-color + dev: false + /eslint-plugin-no-only-tests/2.6.0: resolution: {integrity: sha512-T9SmE/g6UV1uZo1oHAqOvL86XWl7Pl2EpRpnLI8g/bkJu+h7XBCB+1LnubRZ2CUQXj805vh4/CYZdnqtVaEo2Q==} engines: {node: '>=4.0.0'} @@ -4847,6 +4881,17 @@ packages: engines: {node: '>= 0.10'} dev: false + /is-alphabetical/1.0.4: + resolution: {integrity: sha512-DwzsA04LQ10FHTZuL0/grVDk4rFoVH1pjAToYwBrHSxcrBIGQuXrQMtD5U1b0U2XVgKZCTLLP8u2Qxqhy3l2Vg==} + dev: false + + /is-alphanumerical/1.0.4: + resolution: {integrity: sha512-UzoZUr+XfVz3t3v4KyGEniVL9BDRoQtY7tOyrRybkVNjDFWyo1yhXNGrrBTQxp3ib9BLAWs7k2YKBQsFRkZG9A==} + dependencies: + is-alphabetical: 1.0.4 + is-decimal: 1.0.4 + dev: false + /is-arguments/1.1.1: resolution: {integrity: sha512-8Q7EARjzEnKpt/PCD7e1cgUS0a6X8u5tdSiMqXhojOdoV9TsMsiO+9VLC5vAmO8N7/GmXn7yjR8qnA6bVAEzfA==} engines: {node: '>= 0.4'} @@ -4914,6 +4959,10 @@ packages: has-tostringtag: 1.0.0 dev: false + /is-decimal/1.0.4: + resolution: {integrity: sha512-RGdriMmQQvZ2aqaQq3awNA6dCGtKpiDFcOzrTWrDAT2MiWrKQVPmxLGHl7Y2nNu6led0kEyoX0enY0qXYsv9zw==} + dev: false + /is-docker/2.2.1: resolution: {integrity: sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==} engines: {node: '>=8'} @@ -4963,6 +5012,10 @@ packages: is-extglob: 2.1.1 dev: false + /is-hexadecimal/1.0.4: + resolution: {integrity: sha512-gyPJuv83bHMpocVYoqof5VDiZveEoGoFL8m3BXNb2VW8Xs+rz9kqO8LOQ5DH6EsuvilT1ApazU0pyl+ytbPtlw==} + dev: false + /is-module/1.0.0: resolution: {integrity: sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=} dev: false @@ -5797,6 +5850,22 @@ packages: is-buffer: 1.1.6 dev: false + /mdast-util-from-markdown/0.8.5: + resolution: {integrity: sha512-2hkTXtYYnr+NubD/g6KGBS/0mFmBcifAsI0yIWRiRo0PjVs6SSOSOdtzbp6kSGnShDN6G5aWZpKQ2lWRy27mWQ==} + dependencies: + '@types/mdast': 3.0.10 + mdast-util-to-string: 2.0.0 + micromark: 2.11.4 + parse-entities: 2.0.0 + unist-util-stringify-position: 2.0.3 + transitivePeerDependencies: + - supports-color + dev: false + + /mdast-util-to-string/2.0.0: + resolution: {integrity: sha512-AW4DRS3QbBayY/jJmD8437V1Gombjf8RSOUCMFBuo5iHi58AGEgVCKQ+ezHkZZDpAQS75hcBMpLqjpJTjtUL7w==} + dev: false + /media-typer/0.3.0: resolution: {integrity: sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=} engines: {node: '>= 0.6'} @@ -5831,6 +5900,15 @@ packages: engines: {node: '>= 0.6'} dev: false + /micromark/2.11.4: + resolution: {integrity: sha512-+WoovN/ppKolQOFIAajxi7Lu9kInbPxFuTBVEavFcL8eAfVstoc5MocPmqBeAdBOJV00uaVjegzH4+MA0DN/uA==} + dependencies: + debug: 4.3.3 + parse-entities: 2.0.0 + transitivePeerDependencies: + - supports-color + dev: false + /micromatch/4.0.4: resolution: {integrity: sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==} engines: {node: '>=8.6'} @@ -6462,6 +6540,17 @@ packages: callsites: 3.1.0 dev: false + /parse-entities/2.0.0: + resolution: {integrity: sha512-kkywGpCcRYhqQIchaWqZ875wzpS/bMKhz5HnN3p7wveJTkTtyAB/AlnS0f8DFSqYW1T82t6yEAkEcB+A1I3MbQ==} + dependencies: + character-entities: 1.2.4 + character-entities-legacy: 1.1.4 + character-reference-invalid: 1.1.4 + is-alphanumerical: 1.0.4 + is-decimal: 1.0.4 + is-hexadecimal: 1.0.4 + dev: false + /parse-json/4.0.0: resolution: {integrity: sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=} engines: {node: '>=4'} @@ -8153,6 +8242,12 @@ packages: resolution: {integrity: sha512-ekY1NhRzq0B08g4bGuX4wd2jZx5GnKz6mKSqFL4nqBlfyMGiG10gDFhDTMEfYmDL6Jy0FUIZp7wiRB+0BP7J2g==} dev: false + /unist-util-stringify-position/2.0.3: + resolution: {integrity: sha512-3faScn5I+hy9VleOq/qNbAd6pAx7iH5jYBMS9I1HgQVijz/4mv5Bvw5iw1sC/90CODiKo81G/ps8AJrISn687g==} + dependencies: + '@types/unist': 2.0.6 + dev: false + /universal-user-agent/6.0.0: resolution: {integrity: sha512-isyNax3wXoKaulPDZWHQqbmIx1k2tb9fb3GGDBRxCscfYV2Ch7WxPArBsFEG8s/safwXTT7H4QGhaIkTp9447w==} dev: false @@ -13891,6 +13986,7 @@ packages: eslint: 7.32.0 eslint-config-prettier: 7.2.0_eslint@7.32.0 eslint-plugin-import: 2.25.4_eslint@7.32.0 + eslint-plugin-markdown: 2.2.1_eslint@7.32.0 eslint-plugin-no-only-tests: 2.6.0 eslint-plugin-promise: 6.0.0_eslint@7.32.0 eslint-plugin-tsdoc: 0.2.14 diff --git a/common/tools/eslint-plugin-azure-sdk/package.json b/common/tools/eslint-plugin-azure-sdk/package.json index cccbf799ded9..8e85ad767002 100644 --- a/common/tools/eslint-plugin-azure-sdk/package.json +++ b/common/tools/eslint-plugin-azure-sdk/package.json @@ -93,6 +93,7 @@ "rimraf": "^3.0.0", "source-map-support": "^0.5.9", "mocha-junit-reporter": "^2.0.0", - "typescript": "~4.2.0" + "typescript": "~4.2.0", + "eslint-plugin-markdown": "~2.2.1" } } diff --git a/common/tools/eslint-plugin-azure-sdk/src/configs/azure-sdk-base.ts b/common/tools/eslint-plugin-azure-sdk/src/configs/azure-sdk-base.ts index 0c3254537588..c448086531f7 100644 --- a/common/tools/eslint-plugin-azure-sdk/src/configs/azure-sdk-base.ts +++ b/common/tools/eslint-plugin-azure-sdk/src/configs/azure-sdk-base.ts @@ -4,124 +4,151 @@ export default { parser: "@typescript-eslint/parser", parserOptions: { - project: [ - "./tsconfig.json", - "../../../common/tools/eslint-plugin-azure-sdk/tsconfig.lintjson.json", - ], sourceType: "module", - extraFileExtensions: [".json"], + extraFileExtensions: [".json", ".javascript"], }, - plugins: ["@typescript-eslint", "no-only-tests", "promise", "eslint-plugin-tsdoc", "import"], + plugins: ["@typescript-eslint", "no-only-tests", "promise", "eslint-plugin-tsdoc", "import", "markdown"], extends: [ - "plugin:@typescript-eslint/recommended", "eslint:recommended", "plugin:promise/recommended", - "plugin:@typescript-eslint/eslint-recommended", "prettier", - "prettier/@typescript-eslint", - "plugin:@azure/azure-sdk/recommended", ], env: { mocha: true, }, ignorePatterns: ["**/generated/**"], - rules: { - curly: ["error", "multi-line"], - "eol-last": ["error", "always"], - eqeqeq: ["error", "always", { null: "ignore" }], - "import/no-extraneous-dependencies": [ - "error", - { - devDependencies: ["test/**/*.ts", "samples/**", "**/karma.conf.js", "**/.eslintrc.js"], - optionalDependencies: false, - peerDependencies: false, + "overrides": [ + { + files: ['*.ts', '*.tsx', '*.json'], + parserOptions: { + project: [ + "./tsconfig.json", + "../../../common/tools/eslint-plugin-azure-sdk/tsconfig.lintjson.json", + ] }, - ], - "no-console": "off", - "no-dupe-class-members": "off", - "no-invalid-this": "off", - "no-empty": "error", - "no-fallthrough": "error", - "@typescript-eslint/no-invalid-this": "error", - "@typescript-eslint/no-require-imports": "error", - "no-restricted-imports": ["error", { paths: ["rhea", "rhea/.*"] }], - "no-return-await": "error", - "no-undef": "off", - "no-unsafe-finally": "error", - "no-unused-vars": "off", - "no-unused-expressions": "error", - "no-useless-constructor": "off", - "no-use-before-define": "off", - "@typescript-eslint/no-use-before-define": ["error", { functions: false, classes: false }], - "no-var": "error", - "one-var-declaration-per-line": "error", - "prefer-const": "error", - "sort-imports": "warn", - "spaced-comment": ["error", "always", { markers: ["/"] }], - "space-infix-ops": ["error", { int32Hint: false }], - "use-isnan": "error", - "no-only-tests/no-only-tests": "error", - "@typescript-eslint/explicit-module-boundary-types": ["error"], - "no-redeclare": "off", - "@typescript-eslint/no-redeclare": ["error", { builtinGlobals: true }], - "@typescript-eslint/camelcase": "off", - "@typescript-eslint/naming-convention": [ - "error", - { selector: "default", format: null }, - { selector: ["class", "interface"], format: ["PascalCase"] }, - { - selector: "interface", - format: ["PascalCase"], - custom: { - regex: "^I[A-Z]", - match: false, - }, + extends: [ + "plugin:@typescript-eslint/recommended", + "plugin:@typescript-eslint/eslint-recommended", + "prettier/@typescript-eslint", + "plugin:@azure/azure-sdk/recommended", + ], + rules: { + curly: ["error", "multi-line"], + "eol-last": ["error", "always"], + eqeqeq: ["error", "always", { null: "ignore" }], + "import/no-extraneous-dependencies": [ + "error", + { + devDependencies: ["test/**/*.ts", "samples/**", "**/karma.conf.js", "**/.eslintrc.js"], + optionalDependencies: false, + peerDependencies: false, + }, + ], + "no-console": "off", + "no-dupe-class-members": "off", + "no-invalid-this": "off", + "no-empty": "error", + "no-fallthrough": "error", + "@typescript-eslint/no-invalid-this": "error", + "@typescript-eslint/no-require-imports": "error", + "no-restricted-imports": ["error", { paths: ["rhea", "rhea/.*"] }], + "no-return-await": "error", + "no-undef": "off", + "no-unsafe-finally": "error", + "no-unused-vars": "off", + "no-unused-expressions": "error", + "no-useless-constructor": "off", + "no-use-before-define": "off", + "@typescript-eslint/no-use-before-define": ["error", { functions: false, classes: false }], + "no-var": "error", + "one-var-declaration-per-line": "error", + "prefer-const": "error", + "sort-imports": "warn", + "spaced-comment": ["error", "always", { markers: ["/"] }], + "space-infix-ops": ["error", { int32Hint: false }], + "use-isnan": "error", + "no-only-tests/no-only-tests": "error", + "@typescript-eslint/explicit-module-boundary-types": ["error"], + "no-redeclare": "off", + "@typescript-eslint/no-redeclare": ["error", { builtinGlobals: true }], + "@typescript-eslint/camelcase": "off", + "@typescript-eslint/naming-convention": [ + "error", + { selector: "default", format: null }, + { selector: ["class", "interface"], format: ["PascalCase"] }, + { + selector: "interface", + format: ["PascalCase"], + custom: { + regex: "^I[A-Z]", + match: false, + }, + }, + ], + "@typescript-eslint/no-angle-bracket-type-assertion": "off", + "@typescript-eslint/no-array-constructor": "off", + "@typescript-eslint/no-explicit-any": "off", + "@typescript-eslint/explicit-function-return-type": [ + "warn", + { allowExpressions: true, allowTypedFunctionExpressions: true }, + ], + "@typescript-eslint/explicit-member-accessibility": "off", + "@typescript-eslint/no-inferrable-types": "off", + // We use empty extends and empty interface for shimming and renaming extensively + "@typescript-eslint/no-empty-interface": "off", + "@typescript-eslint/no-namespace": "error", + "@typescript-eslint/no-non-null-assertion": "off", + "@typescript-eslint/no-unused-vars": ["warn", { argsIgnorePattern: "^_" }], + "@typescript-eslint/no-useless-constructor": "error", + "@typescript-eslint/no-var-requires": "off", + "no-shadow": "off", + "@typescript-eslint/no-shadow": ["error", { ignoreTypeValueShadow: true }], + // https://github.com/Azure/azure-sdk-for-js/issues/7608 + // "@typescript-eslint/member-ordering": [ + // "error", + // { + // default: [ + // "instance-method", + // "method", + // "private-instance-method", + // "private-method", + // "private-static-method", + // "protected-instance-method", + // "protected-method", + // "protected-static-method", + // "public-instance-method", + // "public-method", + // "public-static-method", + // "static-method" + // ] + // } + // ], + // https://github.com/Azure/azure-sdk-for-js/issues/7605 + "@azure/azure-sdk/ts-apisurface-supportcancellation": "off", + // https://github.com/Azure/azure-sdk-for-js/issues/7609 + "@azure/azure-sdk/ts-pagination-list": "off", + // https://github.com/Azure/azure-sdk-for-js/issues/7610 + "@azure/azure-sdk/ts-doc-internal": "off", + "tsdoc/syntax": "error", }, - ], - "@typescript-eslint/no-angle-bracket-type-assertion": "off", - "@typescript-eslint/no-array-constructor": "off", - "@typescript-eslint/no-explicit-any": "off", - "@typescript-eslint/explicit-function-return-type": [ - "warn", - { allowExpressions: true, allowTypedFunctionExpressions: true }, - ], - "@typescript-eslint/explicit-member-accessibility": "off", - "@typescript-eslint/no-inferrable-types": "off", - // We use empty extends and empty interface for shimming and renaming extensively - "@typescript-eslint/no-empty-interface": "off", - "@typescript-eslint/no-namespace": "error", - "@typescript-eslint/no-non-null-assertion": "off", - "@typescript-eslint/no-unused-vars": ["warn", { argsIgnorePattern: "^_" }], - "@typescript-eslint/no-useless-constructor": "error", - "@typescript-eslint/no-var-requires": "off", - "no-shadow": "off", - "@typescript-eslint/no-shadow": ["error", { ignoreTypeValueShadow: true }], - // https://github.com/Azure/azure-sdk-for-js/issues/7608 - // "@typescript-eslint/member-ordering": [ - // "error", - // { - // default: [ - // "instance-method", - // "method", - // "private-instance-method", - // "private-method", - // "private-static-method", - // "protected-instance-method", - // "protected-method", - // "protected-static-method", - // "public-instance-method", - // "public-method", - // "public-static-method", - // "static-method" - // ] - // } - // ], - // https://github.com/Azure/azure-sdk-for-js/issues/7605 - "@azure/azure-sdk/ts-apisurface-supportcancellation": "off", - // https://github.com/Azure/azure-sdk-for-js/issues/7609 - "@azure/azure-sdk/ts-pagination-list": "off", - // https://github.com/Azure/azure-sdk-for-js/issues/7610 - "@azure/azure-sdk/ts-doc-internal": "off", - "tsdoc/syntax": "error", - }, + }, + { + files: ["**/*.md"], + processor: "markdown/markdown" + }, + { + files: ["**/*.md/*.{js,javascript}"], + extends: [ + "plugin:markdown/recommended" + ], + rules: { + "no-restricted-imports": ["error", { + "patterns": [{ + "group": ["*"], + "message": "Please use require instead of import." + }], + }] + } + } + ] }; diff --git a/sdk/textanalytics/ai-text-analytics/README.md b/sdk/textanalytics/ai-text-analytics/README.md index 3b8672b8e0db..42790a523cd3 100644 --- a/sdk/textanalytics/ai-text-analytics/README.md +++ b/sdk/textanalytics/ai-text-analytics/README.md @@ -510,7 +510,7 @@ main(); Enabling logging may help uncover useful information about failures. In order to see a log of HTTP requests and responses, set the `AZURE_LOG_LEVEL` environment variable to `info`. Alternatively, logging can be enabled at runtime by calling `setLogLevel` in the `@azure/logger`: ```javascript -import { setLogLevel } from "@azure/logger"; +const { logger } = require("@azure/logger"); setLogLevel("info"); ``` diff --git a/sdk/textanalytics/ai-text-analytics/package.json b/sdk/textanalytics/ai-text-analytics/package.json index 4999161f0847..7c337e4cfb29 100644 --- a/sdk/textanalytics/ai-text-analytics/package.json +++ b/sdk/textanalytics/ai-text-analytics/package.json @@ -70,8 +70,8 @@ "integration-test:browser": "dev-tool run test:browser", "integration-test:node": "dev-tool run test:node-js-input -- --timeout 5000000 \"dist-esm/test/**/*.spec.js\"", "integration-test": "npm run integration-test:node && npm run integration-test:browser", - "lint:fix": "eslint package.json api-extractor.json src test --ext .ts --fix --fix-type [problem,suggestion]", - "lint": "eslint package.json api-extractor.json src test --ext .ts", + "lint:fix": "eslint README.md package.json api-extractor.json src test --fix --fix-type [problem,suggestion]", + "lint": "eslint README.md package.json api-extractor.json src test", "pack": "npm pack 2>&1", "test:browser": "npm run clean && npm run build:test && npm run unit-test:browser", "test:node": "npm run clean && npm run build:test && npm run unit-test:node",