From ca63d5daaf4e510895b7cc89c90d22b5db5e5b53 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 21 Feb 2024 14:33:54 -0600 Subject: [PATCH 01/74] update dependencies and add plugin-e2e and playwright --- package.json | 126 +-- yarn.lock | 2623 +++++++++++++++++++++++--------------------------- 2 files changed, 1261 insertions(+), 1488 deletions(-) diff --git a/package.json b/package.json index 6201c95c..81e65abb 100644 --- a/package.json +++ b/package.json @@ -19,70 +19,72 @@ "license": "Apache-2.0", "devDependencies": { "@emotion/eslint-plugin": "11.11.0", - "@grafana/e2e": "10.2.0", - "@grafana/e2e-selectors": "10.2.0", + "@grafana/e2e": "11.0.0-pre", + "@grafana/e2e-selectors": "11.0.0-pre", "@grafana/eslint-config": "6.0.1", + "@grafana/plugin-e2e": "0.17.1", "@grafana/tsconfig": "1.3.0-rc1", + "@playwright/test": "^1.41.2", + "@sentry/browser": "7.102.0", "@swc/core": "1.3.75", - "@swc/helpers": "0.5.0", + "@swc/helpers": "0.5.6", "@swc/jest": "0.2.26", - "@testing-library/dom": "9.3.1", - "@sentry/browser": "7.102.0", - "@testing-library/jest-dom": "5.16.5", - "@testing-library/react": "14.0.0", - "@testing-library/user-event": "14.4.3", - "@types/d3": "7.4.0", - "@types/debounce-promise": "3.1.7", - "@types/eslint": "8.44.0", - "@types/jest": "29.5.5", - "@types/lodash": "4.14.199", - "@types/node": "20.8.2", + "@testing-library/dom": "9.3.4", + "@testing-library/jest-dom": "6.4.2", + "@testing-library/react": "14.2.1", + "@testing-library/user-event": "14.5.2", + "@types/d3": "7.4.3", + "@types/debounce-promise": "3.1.9", + "@types/eslint": "8.56.2", + "@types/jest": "29.5.12", + "@types/lodash": "4.14.202", + "@types/node": "20.11.19", "@types/ol-ext": "npm:@siedlerchr/types-ol-ext@3.2.0", - "@types/pluralize": "0.0.30", - "@types/prismjs": "1.26.0", - "@types/react": "18.2.29", - "@types/react-beautiful-dnd": "13.1.6", - "@types/react-dom": "18.2.14", - "@types/react-highlight-words": "0.16.5", + "@types/pluralize": "^0.0.33", + "@types/prismjs": "1.26.3", + "@types/react": "18.2.55", + "@types/react-beautiful-dnd": "13.1.8", + "@types/react-dom": "18.2.19", + "@types/react-highlight-words": "0.16.7", "@types/react-redux": "7.1.25", - "@types/react-window": "1.8.7", - "@types/semver": "7.5.0", + "@types/react-window": "1.8.8", + "@types/semver": "7.5.7", "@types/slate": "0.47.11", "@types/slate-plain-serializer": "0.7.2", "@types/slate-react": "0.22.9", - "@types/testing-library__jest-dom": "5.14.8", - "@types/uuid": "9.0.2", - "@typescript-eslint/eslint-plugin": "5.42.0", - "@typescript-eslint/parser": "5.42.0", - "copy-webpack-plugin": "11.0.0", - "css-loader": "6.7.3", - "eslint": "8.50.0", - "eslint-config-prettier": "8.8.0", - "eslint-plugin-import": "2.26.0", - "eslint-plugin-jest": "27.2.3", - "eslint-plugin-jsdoc": "46.4.3", - "eslint-plugin-jsx-a11y": "6.7.1", + "@types/testing-library__jest-dom": "5.14.9", + "@types/uuid": "9.0.8", + "@typescript-eslint/eslint-plugin": "6.21.0", + "@typescript-eslint/parser": "6.21.0", + "copy-webpack-plugin": "12.0.2", + "css-loader": "6.10.0", + "eslint": "8.56.0", + "eslint-config-prettier": "9.1.0", + "eslint-plugin-import": "^2.26.0", + "eslint-plugin-jest": "27.8.0", + "eslint-plugin-jsdoc": "48.1.0", + "eslint-plugin-jsx-a11y": "6.8.0", "eslint-plugin-lodash": "7.4.0", - "eslint-plugin-react": "7.32.2", + "eslint-plugin-react": "7.33.2", "eslint-plugin-react-hooks": "4.6.0", "eslint-webpack-plugin": "4.0.1", - "fork-ts-checker-webpack-plugin": "8.0.0", + "fork-ts-checker-webpack-plugin": "9.0.2", "glob": "10.3.10", "identity-obj-proxy": "3.0.0", - "jest": "29.5.0", - "jest-environment-jsdom": "29.5.0", - "prettier": "3.0.3", + "jest": "29.7.0", + "jest-environment-jsdom": "29.7.0", + "prettier": "3.2.5", "react-popper-tooltip": "4.4.2", "replace-in-file-webpack-plugin": "1.0.6", - "sass": "1.68.0", + "sass": "1.70.0", "sass-loader": "13.3.2", - "style-loader": "3.3.3", + "style-loader": "3.3.4", "swc-loader": "0.2.3", "testing-library-selector": "0.3.1", - "ts-node": "10.9.1", + "ts-node": "10.9.2", "tsconfig-paths": "4.2.0", - "typescript": "4.8.4", - "webpack": "5.86.0", + "typescript": "5.3.3", + "webpack": "5.90.2", "webpack-cli": "5.1.4", "webpack-livereload-plugin": "3.0.2" }, @@ -91,25 +93,25 @@ }, "dependencies": { "@emotion/css": "11.11.2", - "@grafana/aws-sdk": "0.1.3", - "@grafana/data": "10.2.0", - "@grafana/experimental": "1.7.9", - "@grafana/faro-web-sdk": "1.2.1", - "@grafana/runtime": "10.3.0", - "@grafana/schema": "10.2.0", - "@grafana/ui": "10.3.0", - "@grafana/prometheus": "10.4.0-161545", - "@leeoniya/ufuzzy": "1.0.8", - "@lezer/common": "1.1.0", - "@lezer/highlight": "1.1.3", + "@grafana/aws-sdk": "0.3.1", + "@grafana/data": "11.0.0-pre", + "@grafana/experimental": "1.7.10", + "@grafana/faro-web-sdk": "^1.3.6", + "@grafana/prometheus": "11.0.0-pre", + "@grafana/runtime": "11.0.0-pre", + "@grafana/schema": "11.0.0-pre", + "@grafana/ui": "11.0.0-pre", + "@leeoniya/ufuzzy": "1.0.14", + "@lezer/common": "1.2.1", + "@lezer/highlight": "1.2.0", "@lezer/lr": "1.3.3", "@prometheus-io/lezer-promql": "0.37.0", - "@reduxjs/toolkit": "1.9.6", + "@reduxjs/toolkit": "1.9.5", "d3": "7.8.5", "debounce-promise": "3.1.2", "lodash": "4.17.21", - "lru-cache": "10.0.1", - "moment": "2.29.4", + "lru-cache": "10.2.0", + "moment": "2.30.1", "monaco-promql": "1.7.4", "pluralize": "8.0.0", "prismjs": "1.29.0", @@ -118,15 +120,15 @@ "react-dom": "18.2.0", "react-highlight-words": "0.20.0", "react-redux": "7.2.6", - "react-use": "17.4.0", - "react-window": "1.8.9", + "react-use": "17.5.0", + "react-window": "1.8.10", "rxjs": "7.8.1", - "semver": "7.5.4", + "semver": "7.6.0", "slate": "0.47.9", "slate-plain-serializer": "0.7.13", "slate-react": "0.22.10", "uuid": "^9.0.1", - "whatwg-fetch": "3.6.2" + "whatwg-fetch": "3.6.20" }, "packageManager": "yarn@3.6.1", "dependenciesMeta": { diff --git a/yarn.lock b/yarn.lock index d58e877a..870a16c0 100644 --- a/yarn.lock +++ b/yarn.lock @@ -7,10 +7,10 @@ resolved "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz" integrity sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA== -"@adobe/css-tools@^4.0.1": - version "4.3.1" - resolved "https://registry.npmjs.org/@adobe/css-tools/-/css-tools-4.3.1.tgz" - integrity sha512-/62yikz7NLScCGAAST5SHdnjaDJQBDq0M2muyRTpf2VQhw6StBg2ALiu73zSJQ4fMVLA+0uBhBHAle7Wg+2kSg== +"@adobe/css-tools@^4.3.2": + version "4.3.3" + resolved "https://registry.yarnpkg.com/@adobe/css-tools/-/css-tools-4.3.3.tgz#90749bde8b89cd41764224f5aac29cd4138f75ff" + integrity sha512-rE0Pygv0sEZ4vBWHlAgJLGDU7Pm8xoO6p3wsEceb7GYAjScrOHpEo8KK/eVkAcnSM+slAEtXjA2JpdjLp4fJQQ== "@ampproject/remapping@^2.2.0": version "2.2.1" @@ -33,30 +33,9 @@ resolved "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.2.tgz" integrity sha512-0S9TQMmDHlqAZ2ITT95irXKfxN9bncq8ZCoJhun3nHL/lLUxd2NKBJYoNGWH7S0hz6fRQwWlAWn/ILM0C70KZQ== -"@babel/core@7.23.0": - version "7.23.0" - resolved "https://registry.npmjs.org/@babel/core/-/core-7.23.0.tgz" - integrity sha512-97z/ju/Jy1rZmDxybphrBuI+jtJjFVoz7Mr9yUQVVVi+DNZE333uFQeMOqcCIy1x3WYBIbWftUSLmbNXNT7qFQ== - dependencies: - "@ampproject/remapping" "^2.2.0" - "@babel/code-frame" "^7.22.13" - "@babel/generator" "^7.23.0" - "@babel/helper-compilation-targets" "^7.22.15" - "@babel/helper-module-transforms" "^7.23.0" - "@babel/helpers" "^7.23.0" - "@babel/parser" "^7.23.0" - "@babel/template" "^7.22.15" - "@babel/traverse" "^7.23.0" - "@babel/types" "^7.23.0" - convert-source-map "^2.0.0" - debug "^4.1.0" - gensync "^1.0.0-beta.2" - json5 "^2.2.3" - semver "^6.3.1" - -"@babel/core@^7.11.6", "@babel/core@^7.12.3": +"@babel/core@7.23.2", "@babel/core@^7.11.6", "@babel/core@^7.12.3": version "7.23.2" - resolved "https://registry.npmjs.org/@babel/core/-/core-7.23.2.tgz" + resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.23.2.tgz#ed10df0d580fff67c5f3ee70fd22e2e4c90a9f94" integrity sha512-n7s51eWdaWZ3vGT2tD4T7J6eJs3QoBXydv7vkUM06Bf1cbVD2Kc2UrkzhiQwobfV7NwOnQXYL7UBJ5VPU+RGoQ== dependencies: "@ampproject/remapping" "^2.2.0" @@ -265,7 +244,7 @@ "@babel/template" "^7.22.15" "@babel/types" "^7.22.19" -"@babel/helpers@^7.23.0", "@babel/helpers@^7.23.2": +"@babel/helpers@^7.23.2": version "7.23.2" resolved "https://registry.npmjs.org/@babel/helpers/-/helpers-7.23.2.tgz" integrity sha512-lzchcp8SjTSVe/fPmLwtWVBFC7+Tbn8LGHDVfDp9JGxpAY5opSaEFgt8UQvrnECWOTdji2mOWMz1rOhkHscmGQ== @@ -945,7 +924,7 @@ resolved "https://registry.npmjs.org/@babel/regjsgen/-/regjsgen-0.8.0.tgz" integrity sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA== -"@babel/runtime@^7.0.0", "@babel/runtime@^7.1.2", "@babel/runtime@^7.10.1", "@babel/runtime@^7.11.1", "@babel/runtime@^7.11.2", "@babel/runtime@^7.12.0", "@babel/runtime@^7.12.1", "@babel/runtime@^7.12.13", "@babel/runtime@^7.12.5", "@babel/runtime@^7.14.0", "@babel/runtime@^7.15.4", "@babel/runtime@^7.18.0", "@babel/runtime@^7.18.3", "@babel/runtime@^7.19.4", "@babel/runtime@^7.20.0", "@babel/runtime@^7.20.6", "@babel/runtime@^7.20.7", "@babel/runtime@^7.21.0", "@babel/runtime@^7.23.2", "@babel/runtime@^7.5.5", "@babel/runtime@^7.8.4", "@babel/runtime@^7.8.7", "@babel/runtime@^7.9.2": +"@babel/runtime@^7.0.0", "@babel/runtime@^7.1.2", "@babel/runtime@^7.10.1", "@babel/runtime@^7.11.1", "@babel/runtime@^7.11.2", "@babel/runtime@^7.12.0", "@babel/runtime@^7.12.1", "@babel/runtime@^7.12.13", "@babel/runtime@^7.12.5", "@babel/runtime@^7.14.0", "@babel/runtime@^7.15.4", "@babel/runtime@^7.18.0", "@babel/runtime@^7.18.3", "@babel/runtime@^7.19.4", "@babel/runtime@^7.20.0", "@babel/runtime@^7.20.6", "@babel/runtime@^7.20.7", "@babel/runtime@^7.23.2", "@babel/runtime@^7.5.5", "@babel/runtime@^7.8.4", "@babel/runtime@^7.8.7", "@babel/runtime@^7.9.2": version "7.23.2" resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.2.tgz" integrity sha512-mM8eg4yl5D6i3lu2QKPuPH4FArvJ8KhTofbE7jwMUv9KX5mBvwPAqnV3MlyBNqdp9RyRKP6Yck8TrfYrPvX3bg== @@ -961,7 +940,7 @@ "@babel/parser" "^7.22.15" "@babel/types" "^7.22.15" -"@babel/traverse@^7.23.0", "@babel/traverse@^7.23.2": +"@babel/traverse@^7.23.2": version "7.23.2" resolved "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.2.tgz" integrity sha512-azpe59SQ48qG6nu2CzcMLbxUudtN+dOM9kDbUqGq3HXUJRlo7i8fvPoxQUzYgLZ4cMVmuZgm8vvBpNeRhd6XSw== @@ -991,11 +970,6 @@ resolved "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz" integrity sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw== -"@braintree/sanitize-url@6.0.2": - version "6.0.2" - resolved "https://registry.npmjs.org/@braintree/sanitize-url/-/sanitize-url-6.0.2.tgz" - integrity sha512-Tbsj02wXCbqGmzdnXNk0SOF19ChhRU70BsroIi4Pm6Ehp56in6vch94mfbdQ17DozxkL3BAVjbZ4Qc1a0HFRAg== - "@braintree/sanitize-url@7.0.0": version "7.0.0" resolved "https://registry.yarnpkg.com/@braintree/sanitize-url/-/sanitize-url-7.0.0.tgz#8899d8e68a1b3f6933d4ad57a263fd3cf1d34d8a" @@ -1113,29 +1087,29 @@ resolved "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.8.1.tgz" integrity sha512-W2P2c/VRW1/1tLox0mVUalvnWXxavmv/Oum2aPsRcoDJuob75FC3Y8FbpfLwUegRcxINtGUMPq0tFCvYNTBXNA== -"@emotion/react@11.11.1", "@emotion/react@^11.8.1": - version "11.11.1" - resolved "https://registry.npmjs.org/@emotion/react/-/react-11.11.1.tgz" - integrity sha512-5mlW1DquU5HaxjLkfkGN1GA/fvVGdyHURRiX/0FHl2cfIfRxSOfmxEH5YS43edp0OldZrZ+dkBKbngxcNCdZvA== +"@emotion/react@11.11.3": + version "11.11.3" + resolved "https://registry.yarnpkg.com/@emotion/react/-/react-11.11.3.tgz#96b855dc40a2a55f52a72f518a41db4f69c31a25" + integrity sha512-Cnn0kuq4DoONOMcnoVsTOR8E+AdnKFf//6kUWc4LCdnxj31pZWn7rIULd6Y7/Js1PiPHzn7SKCM9vB/jBni8eA== dependencies: "@babel/runtime" "^7.18.3" "@emotion/babel-plugin" "^11.11.0" "@emotion/cache" "^11.11.0" - "@emotion/serialize" "^1.1.2" + "@emotion/serialize" "^1.1.3" "@emotion/use-insertion-effect-with-fallbacks" "^1.0.1" "@emotion/utils" "^1.2.1" "@emotion/weak-memoize" "^0.3.1" hoist-non-react-statics "^3.3.1" -"@emotion/react@11.11.3": - version "11.11.3" - resolved "https://registry.yarnpkg.com/@emotion/react/-/react-11.11.3.tgz#96b855dc40a2a55f52a72f518a41db4f69c31a25" - integrity sha512-Cnn0kuq4DoONOMcnoVsTOR8E+AdnKFf//6kUWc4LCdnxj31pZWn7rIULd6Y7/Js1PiPHzn7SKCM9vB/jBni8eA== +"@emotion/react@^11.8.1": + version "11.11.1" + resolved "https://registry.npmjs.org/@emotion/react/-/react-11.11.1.tgz" + integrity sha512-5mlW1DquU5HaxjLkfkGN1GA/fvVGdyHURRiX/0FHl2cfIfRxSOfmxEH5YS43edp0OldZrZ+dkBKbngxcNCdZvA== dependencies: "@babel/runtime" "^7.18.3" "@emotion/babel-plugin" "^11.11.0" "@emotion/cache" "^11.11.0" - "@emotion/serialize" "^1.1.3" + "@emotion/serialize" "^1.1.2" "@emotion/use-insertion-effect-with-fallbacks" "^1.0.1" "@emotion/utils" "^1.2.1" "@emotion/weak-memoize" "^0.3.1" @@ -1197,7 +1171,16 @@ esquery "^1.5.0" jsdoc-type-pratt-parser "~4.0.0" -"@eslint-community/eslint-utils@^4.2.0": +"@es-joy/jsdoccomment@~0.42.0": + version "0.42.0" + resolved "https://registry.yarnpkg.com/@es-joy/jsdoccomment/-/jsdoccomment-0.42.0.tgz#59e878708336aaee88c2b34c894f73dbf77ae2b0" + integrity sha512-R1w57YlVA6+YE01wch3GPYn6bCsrOV3YW/5oGGE2tmX6JcL9Nr+b5IikrjMPF+v9CV3ay+obImEdsDhovhJrzw== + dependencies: + comment-parser "1.4.1" + esquery "^1.5.0" + jsdoc-type-pratt-parser "~4.0.0" + +"@eslint-community/eslint-utils@^4.2.0", "@eslint-community/eslint-utils@^4.4.0": version "4.4.0" resolved "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz" integrity sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA== @@ -1209,7 +1192,12 @@ resolved "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.9.1.tgz" integrity sha512-Y27x+MBLjXa+0JWDhykM3+JE+il3kHKAEqabfEWq3SDhZjLYb6/BHL/JKFnH3fe207JaXkyDo685Oc2Glt6ifA== -"@eslint/eslintrc@^2.0.3", "@eslint/eslintrc@^2.1.2": +"@eslint-community/regexpp@^4.5.1": + version "4.10.0" + resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.10.0.tgz#548f6de556857c8bb73bbee70c35dc82a2e74d63" + integrity sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA== + +"@eslint/eslintrc@^2.0.3": version "2.1.2" resolved "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.2.tgz" integrity sha512-+wvgpDsrB1YqAMdEUCcnTlpfVBH7Vqn6A/NT3D8WVXFIaKMlErPIZT3oCIAVCOtarRpMtelZLqJeU3t7WY6X6g== @@ -1224,15 +1212,30 @@ minimatch "^3.1.2" strip-json-comments "^3.1.1" +"@eslint/eslintrc@^2.1.4": + version "2.1.4" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-2.1.4.tgz#388a269f0f25c1b6adc317b5a2c55714894c70ad" + integrity sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ== + dependencies: + ajv "^6.12.4" + debug "^4.3.2" + espree "^9.6.0" + globals "^13.19.0" + ignore "^5.2.0" + import-fresh "^3.2.1" + js-yaml "^4.1.0" + minimatch "^3.1.2" + strip-json-comments "^3.1.1" + "@eslint/js@8.42.0": version "8.42.0" resolved "https://registry.npmjs.org/@eslint/js/-/js-8.42.0.tgz" integrity sha512-6SWlXpWU5AvId8Ac7zjzmIOqMOba/JWY8XZ4A7q7Gn1Vlfg/SFFIlrtHXt9nPn4op9ZPAkl91Jao+QQv3r/ukw== -"@eslint/js@8.50.0": - version "8.50.0" - resolved "https://registry.npmjs.org/@eslint/js/-/js-8.50.0.tgz" - integrity sha512-NCC3zz2+nvYd+Ckfh87rA47zfu2QsQpvc6k1yzTk+b9KzRj0wkGa8LSoGOXN6Zv4lRf/EIoZ80biDh9HOI+RNQ== +"@eslint/js@8.56.0": + version "8.56.0" + resolved "https://registry.yarnpkg.com/@eslint/js/-/js-8.56.0.tgz#ef20350fec605a7f7035a01764731b2de0f3782b" + integrity sha512-gMsVel9D7f2HLkBma9VbtzZRehRogVRfbr++f06nL2vnCGCNlzOD+/MUov/F4p8myyAHspEhVobgjpX64q5m6A== "@floating-ui/core@^1.0.0": version "1.6.0" @@ -1336,83 +1339,21 @@ dependencies: tslib "^2.4.1" -"@grafana/aws-sdk@0.1.3": - version "0.1.3" - resolved "https://registry.npmjs.org/@grafana/aws-sdk/-/aws-sdk-0.1.3.tgz" - integrity sha512-Kg/fDAVRSCa+FbdRRbCEIfUYk2dUJGWhj7iyXY0EvGm96EWPT6/MWezn0Gi9uje7WaLgbpU1XQaLWr47DUZDbw== +"@grafana/aws-sdk@0.3.1": + version "0.3.1" + resolved "https://registry.yarnpkg.com/@grafana/aws-sdk/-/aws-sdk-0.3.1.tgz#0ada1b06c13882320ae2c07e7b2bbd703091da7c" + integrity sha512-YwJhe89qhYmpKWcP4smI90f+AB7C70mYcASnczZ9jGevOt8I8T6rQwTlsMJIoDXYMqYTpOzqi2FYemu/knSCqQ== dependencies: "@grafana/async-query-data" "0.1.4" - "@grafana/experimental" "1.1.0" - -"@grafana/data@10.2.0": - version "10.2.0" - resolved "https://registry.npmjs.org/@grafana/data/-/data-10.2.0.tgz" - integrity sha512-MPUmkokQY7AWbJKVundp9AtTZdk4HqZHUCNvM1TFkTACUW9rVCi5fmmjwJQFLfTJ9JL2fkls8Z6S1l9Hd9ViTw== - dependencies: - "@braintree/sanitize-url" "6.0.2" - "@grafana/schema" "10.2.0" - "@types/d3-interpolate" "^3.0.0" - "@types/string-hash" "1.1.1" - d3-interpolate "3.0.1" - date-fns "2.30.0" - dompurify "^2.4.3" - eventemitter3 "5.0.1" - fast_array_intersect "1.1.0" - history "4.10.1" - lodash "4.17.21" - marked "5.1.1" - marked-mangle "1.1.0" - moment "2.29.4" - moment-timezone "0.5.43" - ol "7.4.0" - papaparse "5.4.1" - react-use "17.4.0" - regenerator-runtime "0.13.11" - rxjs "7.8.1" - string-hash "^1.1.3" - tinycolor2 "1.6.0" - tslib "2.6.0" - uplot "1.6.26" - xss "^1.0.14" - -"@grafana/data@10.3.0": - version "10.3.0" - resolved "https://registry.npmjs.org/@grafana/data/-/data-10.3.0.tgz" - integrity sha512-jyAjk4qtJWD1ruXz4BkgVPAvQziNIuiNvLOu0u7ddMsBzmbLLt3kTSFwfEN4HYEJo/VEP+2DaVErfQ6GwL2tGA== - dependencies: - "@braintree/sanitize-url" "6.0.2" - "@grafana/schema" "10.3.0" - "@types/d3-interpolate" "^3.0.0" - "@types/string-hash" "1.1.1" - d3-interpolate "3.0.1" - date-fns "2.30.0" - dompurify "^2.4.3" - eventemitter3 "5.0.1" - fast_array_intersect "1.1.0" - history "4.10.1" - lodash "4.17.21" - marked "5.1.1" - marked-mangle "1.1.0" - moment "2.29.4" - moment-timezone "0.5.43" - ol "7.4.0" - papaparse "5.4.1" - react-use "17.4.0" - regenerator-runtime "0.13.11" - rxjs "7.8.1" - string-hash "^1.1.3" - tinycolor2 "1.6.0" - tslib "2.6.0" - uplot "1.6.26" - xss "^1.0.14" + "@grafana/experimental" "1.7.0" -"@grafana/data@10.4.0-161545": - version "10.4.0-161545" - resolved "https://registry.yarnpkg.com/@grafana/data/-/data-10.4.0-161545.tgz#9a39115deabd627cff6fcc253ad344caba4420c2" - integrity sha512-vJxeKzJ0gUGOVh2eSUKaq9HdPHlb8x98GkU5V2m6oJM1XEcDCIjJnpn/iLftSeDhHm0d/4fgjCfl60G+BUicqg== +"@grafana/data@11.0.0-162094", "@grafana/data@11.0.0-pre": + version "11.0.0-162094" + resolved "https://registry.yarnpkg.com/@grafana/data/-/data-11.0.0-162094.tgz#16cb9ab721dbca52b7ac8b13152b7ec98f442529" + integrity sha512-Czl8IKRauiDrGd1Bv6a0PUROifsS6TkqPqMd7QlkDJWtZCuxRcasrqxsvVH2OITPmw+cmH/Q7gkk5RpaBF1BQA== dependencies: "@braintree/sanitize-url" "7.0.0" - "@grafana/schema" "10.4.0-161545" + "@grafana/schema" "11.0.0-162094" "@types/d3-interpolate" "^3.0.0" "@types/string-hash" "1.1.3" d3-interpolate "3.0.1" @@ -1437,43 +1378,25 @@ uplot "1.6.30" xss "^1.0.14" -"@grafana/e2e-selectors@10.2.0": - version "10.2.0" - resolved "https://registry.npmjs.org/@grafana/e2e-selectors/-/e2e-selectors-10.2.0.tgz" - integrity sha512-mrYz7xri7H7TiYpDXQHeMHKMDzx2a9kIM0OklXhN1ZsQQSeYrh0+87EizyWeL0T7/d0OorLR4nq8zxVyVni8Bg== - dependencies: - "@grafana/tsconfig" "^1.2.0-rc1" - tslib "2.6.0" - typescript "4.8.4" - -"@grafana/e2e-selectors@10.3.0": - version "10.3.0" - resolved "https://registry.npmjs.org/@grafana/e2e-selectors/-/e2e-selectors-10.3.0.tgz" - integrity sha512-IHJp6kHRt+1QHROgR/2RWgrCup/xq1zNXiHdZGcs0Gkoo1DKRTQEqQnO242WCXe0p8Cr1PmzeCB+67UYIk19uQ== - dependencies: - "@grafana/tsconfig" "^1.2.0-rc1" - tslib "2.6.0" - typescript "4.8.4" - -"@grafana/e2e-selectors@10.4.0-161545": - version "10.4.0-161545" - resolved "https://registry.yarnpkg.com/@grafana/e2e-selectors/-/e2e-selectors-10.4.0-161545.tgz#fcd2154e6f1e64bd8bc2d388bfd1944eaaab9a1d" - integrity sha512-OBao9Y7EgjgVke/cyC286Bsc2bvbaPXtjq525ab86Qje/5Po7nRPXIUnniFgHcRnQcnHm3s6AHblqxXE6ESDtQ== +"@grafana/e2e-selectors@11.0.0-162094", "@grafana/e2e-selectors@11.0.0-pre": + version "11.0.0-162094" + resolved "https://registry.yarnpkg.com/@grafana/e2e-selectors/-/e2e-selectors-11.0.0-162094.tgz#8f5b538adaf9e79d4f4776c3fc9dfcc5a933b1db" + integrity sha512-n3+OmRvpRixc34yNGa+ifSRLshPpC1vmIKnkk6Sqcj+O1dd/E0lOJMipAiQmXV+jg7LXIyiRiGqelYmE1kcG7w== dependencies: "@grafana/tsconfig" "^1.2.0-rc1" tslib "2.6.2" typescript "5.3.3" -"@grafana/e2e@10.2.0": - version "10.2.0" - resolved "https://registry.npmjs.org/@grafana/e2e/-/e2e-10.2.0.tgz" - integrity sha512-NyW6JS9nNkqDLDqHOECD1SK5AXTZ35XnC/7aBwpNXYnJqkGaqWW3vgEcgit8kyWBgEH8JlpZSPCWHfko3E6leQ== +"@grafana/e2e@11.0.0-pre": + version "11.0.0-162094" + resolved "https://registry.yarnpkg.com/@grafana/e2e/-/e2e-11.0.0-162094.tgz#c0eadf2fc244ca1e6f87d085c4444410a5aaeba9" + integrity sha512-52HBe3nxdi+vWlKjFPg2ttarnCCdTKZQKtMvnzyTzNgdumketZ4xVvjP6+LLrP2hKecqMKPhoVUKH5bTc+ofRA== dependencies: - "@babel/core" "7.23.0" + "@babel/core" "7.23.2" "@babel/preset-env" "7.23.2" "@cypress/webpack-preprocessor" "5.17.1" - "@grafana/e2e-selectors" "10.2.0" - "@grafana/schema" "10.2.0" + "@grafana/e2e-selectors" "11.0.0-162094" + "@grafana/schema" "11.0.0-162094" "@grafana/tsconfig" "^1.2.0-rc1" "@mochajs/json-file-reporter" "^1.2.0" babel-loader "9.1.3" @@ -1491,7 +1414,7 @@ tracelib "1.0.1" ts-loader "8.4.0" tslib "2.6.0" - typescript "4.8.4" + typescript "5.2.2" uuid "9.0.0" yaml "^2.0.0" @@ -1509,10 +1432,10 @@ eslint-plugin-react-hooks "4.6.0" typescript "4.8.4" -"@grafana/experimental@1.1.0": - version "1.1.0" - resolved "https://registry.npmjs.org/@grafana/experimental/-/experimental-1.1.0.tgz" - integrity sha512-pQhYhw+jB7Q+t8rLcd1jcx91BiFDNslBATJkNIgO9I2Bah+ww+2RH1hUGVoJNPL84vW7WRU7w9k/L7FJs7/L6Q== +"@grafana/experimental@1.7.0": + version "1.7.0" + resolved "https://registry.yarnpkg.com/@grafana/experimental/-/experimental-1.7.0.tgz#f05ce178f3201cd5268645eb14dc5bcfefa05a4c" + integrity sha512-3DfDzGTUnvG/v2U0lhBaB05j4x0bczrgylrg5Co6LMyRYh1kPA4XnK0dTshSxA6igjKqAjSacfwZQ40f4rLdqw== dependencies: "@types/uuid" "^8.3.3" uuid "^8.3.2" @@ -1531,30 +1454,6 @@ semver "^7.5.4" uuid "^8.3.2" -"@grafana/experimental@1.7.9": - version "1.7.9" - resolved "https://registry.npmjs.org/@grafana/experimental/-/experimental-1.7.9.tgz" - integrity sha512-AOXqkOZUmkG8Bua3nUrTs7ILsEyeAZiww5COZf4Mi1KZIES4Oeov0/NdiDUXiRcq+dzPdXnOlyHP2SPcL/UrzA== - dependencies: - "@types/uuid" "^8.3.3" - lodash "^4.17.21" - prismjs "^1.29.0" - react-beautiful-dnd "^13.1.1" - react-popper-tooltip "^4.4.2" - react-use "^17.4.2" - semver "^7.5.4" - uuid "^8.3.2" - -"@grafana/faro-core@^1.2.1": - version "1.2.1" - resolved "https://registry.npmjs.org/@grafana/faro-core/-/faro-core-1.2.1.tgz" - integrity sha512-gI8CpyhAKRsMbPHom3sAa0qCgiQAXZrlv43Tv2q30PgMgNsV4iWI6UKHN/7NPJyvUFd+h0B/plukYDGZxO1kew== - dependencies: - "@opentelemetry/api" "^1.4.1" - "@opentelemetry/api-metrics" "^0.33.0" - "@opentelemetry/otlp-transformer" "^0.41.2" - murmurhash-js "^1.0.0" - "@grafana/faro-core@^1.3.8": version "1.3.8" resolved "https://registry.yarnpkg.com/@grafana/faro-core/-/faro-core-1.3.8.tgz#d77f110d883fb9775f024d747eec74d19442fb5a" @@ -1563,15 +1462,6 @@ "@opentelemetry/api" "^1.7.0" "@opentelemetry/otlp-transformer" "^0.48.0" -"@grafana/faro-web-sdk@1.2.1": - version "1.2.1" - resolved "https://registry.npmjs.org/@grafana/faro-web-sdk/-/faro-web-sdk-1.2.1.tgz" - integrity sha512-86Bk3IjVNdV/WufkdPJVUvjx7PYKjPV5n2Szpn+dOewZqEDd1lIqhyFYqVVM9kdjT+ARbSzY5BZvb+r0Kh8tuQ== - dependencies: - "@grafana/faro-core" "^1.2.1" - ua-parser-js "^1.0.32" - web-vitals "^3.1.1" - "@grafana/faro-web-sdk@1.3.8", "@grafana/faro-web-sdk@^1.3.6": version "1.3.8" resolved "https://registry.yarnpkg.com/@grafana/faro-web-sdk/-/faro-web-sdk-1.3.8.tgz#2dd88437b773fbc3024ceb210c346fbcb2cccc34" @@ -1581,19 +1471,28 @@ ua-parser-js "^1.0.32" web-vitals "^3.1.1" -"@grafana/prometheus@10.4.0-161545": - version "10.4.0-161545" - resolved "https://registry.yarnpkg.com/@grafana/prometheus/-/prometheus-10.4.0-161545.tgz#ed3101dfd7eca81d44663f39e4bf6861e0378989" - integrity sha512-sYGrZGKVAw+Elq0rfFTLLsGYRpLfb4DYH8xbS03aUIWxbblOJ9sa94J3EGHEAz1dFjgqNLCK13WC6XiMxIFLgQ== +"@grafana/plugin-e2e@0.17.1": + version "0.17.1" + resolved "https://registry.yarnpkg.com/@grafana/plugin-e2e/-/plugin-e2e-0.17.1.tgz#c8cbcda5e60c2a4e0b10e3966e8ab27fae6bb93b" + integrity sha512-VyFJKwGzK+/f0R/SitPmDoRLe952gOcJWgkaUikxr/58KFLAPwuwZvvPhK4Gyjkz2Rwcl6NE3AplU2jgoS0r6A== + dependencies: + semver "^7.5.4" + uuid "^9.0.1" + yaml "^2.3.4" + +"@grafana/prometheus@11.0.0-pre": + version "11.0.0-162094" + resolved "https://registry.yarnpkg.com/@grafana/prometheus/-/prometheus-11.0.0-162094.tgz#0b3523cc53b3a8160e48a928cecdb1f5ee500e38" + integrity sha512-I+e3P7STmFgxZ/STySr4I0gt188D5w8gJ11flI51/TVq/H637xOQDh/ZLxPYcfnzi4mMQDmvlRAWv7skkg5QWQ== dependencies: "@emotion/css" "11.11.2" "@floating-ui/react" "0.26.9" - "@grafana/data" "10.4.0-161545" + "@grafana/data" "11.0.0-162094" "@grafana/experimental" "1.7.10" "@grafana/faro-web-sdk" "1.3.8" - "@grafana/runtime" "10.4.0-161545" - "@grafana/schema" "10.4.0-161545" - "@grafana/ui" "10.4.0-161545" + "@grafana/runtime" "11.0.0-162094" + "@grafana/schema" "11.0.0-162094" + "@grafana/ui" "11.0.0-162094" "@leeoniya/ufuzzy" "1.0.14" "@lezer/common" "1.2.1" "@lezer/highlight" "1.2.0" @@ -1624,32 +1523,16 @@ uuid "9.0.1" whatwg-fetch "3.6.20" -"@grafana/runtime@10.3.0": - version "10.3.0" - resolved "https://registry.npmjs.org/@grafana/runtime/-/runtime-10.3.0.tgz" - integrity sha512-ghFRHf1FL2VkY6vA0lbYnR7VdDgTKOA9RfyL9I/4U+TvjErTcC5gtDLKSA0Eb/MQH5AzPFYjMdd7W4X5516zaQ== +"@grafana/runtime@11.0.0-162094", "@grafana/runtime@11.0.0-pre": + version "11.0.0-162094" + resolved "https://registry.yarnpkg.com/@grafana/runtime/-/runtime-11.0.0-162094.tgz#866a6caf6227b898881468351a8c82f2514efa52" + integrity sha512-H7tbo+MQUoLeEGgSrQ272OfaKKc2XRn3/qWS2Ii8mg80bVhBItDoMiwWnkm2i7knNwngFcT2m5Bkbnv/sdeoPA== dependencies: - "@grafana/data" "10.3.0" - "@grafana/e2e-selectors" "10.3.0" - "@grafana/faro-web-sdk" "1.2.1" - "@grafana/ui" "10.3.0" - history "4.10.1" - lodash "4.17.21" - rxjs "7.8.1" - systemjs "6.14.2" - systemjs-cjs-extra "0.2.0" - tslib "2.6.0" - -"@grafana/runtime@10.4.0-161545": - version "10.4.0-161545" - resolved "https://registry.yarnpkg.com/@grafana/runtime/-/runtime-10.4.0-161545.tgz#e0ce4a2e221e2cea65e61cc11af27a12d7bc6cad" - integrity sha512-TdHYFQw0o3Ag1sHq1KROjA934NT1WUOu4yzZZP8JXNB4/cKlrZlqD/bhLGxEpcVBOzMGWU0+NLYGNaURa3noag== - dependencies: - "@grafana/data" "10.4.0-161545" - "@grafana/e2e-selectors" "10.4.0-161545" + "@grafana/data" "11.0.0-162094" + "@grafana/e2e-selectors" "11.0.0-162094" "@grafana/faro-web-sdk" "^1.3.6" - "@grafana/schema" "10.4.0-161545" - "@grafana/ui" "10.4.0-161545" + "@grafana/schema" "11.0.0-162094" + "@grafana/ui" "11.0.0-162094" history "4.10.1" lodash "4.17.21" rxjs "7.8.1" @@ -1657,24 +1540,10 @@ systemjs-cjs-extra "0.2.0" tslib "2.6.2" -"@grafana/schema@10.2.0": - version "10.2.0" - resolved "https://registry.npmjs.org/@grafana/schema/-/schema-10.2.0.tgz" - integrity sha512-IvjlezsOfIRjnsOwTJ1qu1GWbq9Rz3ofFi2Pd+1Brza6Gn951Hv/5MlLwqIuZJ+VnSVs35ZlNOl3sz9uSq2ibg== - dependencies: - tslib "2.6.0" - -"@grafana/schema@10.3.0": - version "10.3.0" - resolved "https://registry.npmjs.org/@grafana/schema/-/schema-10.3.0.tgz" - integrity sha512-dbNC3gfj/zRw3lVPr/TffKZLmmGzW38EHMXunMatKv1nc5A+BscRwH9xHO2LDrsHzkGEdW8ROwVYAkIWbxl/0Q== - dependencies: - tslib "2.6.0" - -"@grafana/schema@10.4.0-161545": - version "10.4.0-161545" - resolved "https://registry.yarnpkg.com/@grafana/schema/-/schema-10.4.0-161545.tgz#3e6f12245f40e89afdbd207a0931eb16f082add1" - integrity sha512-aELP3E5P70EbjeTBBLtXZDY7dbdE9n8oakSIbkZebGN7visyzA0Vusj6q1KgoxfJII/Wtbs+hMR2q7oXwJTbyA== +"@grafana/schema@11.0.0-162094", "@grafana/schema@11.0.0-pre": + version "11.0.0-162094" + resolved "https://registry.yarnpkg.com/@grafana/schema/-/schema-11.0.0-162094.tgz#43518f9c775b4d441e11ac23cfdaea30b4c127f3" + integrity sha512-EWYBkqlyAAteerfGmJFljEC4uQGSwnhHpDWFy1MK5LE/NhMK/MfmX976WftQMh18RymEm0sdpZwQj9BngLku3Q== dependencies: tslib "2.6.2" @@ -1688,97 +1557,25 @@ resolved "https://registry.npmjs.org/@grafana/tsconfig/-/tsconfig-1.2.0-rc1.tgz" integrity sha512-+SgQeBQ1pT6D/E3/dEdADqTrlgdIGuexUZ8EU+8KxQFKUeFeU7/3z/ayI2q/wpJ/Kr6WxBBNlrST6aOKia19Ag== -"@grafana/ui@10.3.0": - version "10.3.0" - resolved "https://registry.npmjs.org/@grafana/ui/-/ui-10.3.0.tgz" - integrity sha512-03eZthK8MzsseUUQpz81VbY1wn1Wa4ml6cqLgQfg+2MM0rh2Bfo/tXeUG7nAhUDYAgoXn0CWTIl6WXlLn8gE3g== - dependencies: - "@emotion/css" "11.11.2" - "@emotion/react" "11.11.1" - "@grafana/data" "10.3.0" - "@grafana/e2e-selectors" "10.3.0" - "@grafana/faro-web-sdk" "1.2.1" - "@grafana/schema" "10.3.0" - "@leeoniya/ufuzzy" "1.0.8" - "@monaco-editor/react" "4.6.0" - "@popperjs/core" "2.11.8" - "@react-aria/button" "3.8.0" - "@react-aria/dialog" "3.5.3" - "@react-aria/focus" "3.13.0" - "@react-aria/menu" "3.10.0" - "@react-aria/overlays" "3.15.0" - "@react-aria/utils" "3.18.0" - "@react-stately/menu" "3.5.3" - ansicolor "1.1.100" - calculate-size "1.1.1" - classnames "2.3.2" - core-js "3.33.0" - d3 "7.8.5" - date-fns "2.30.0" - hoist-non-react-statics "3.3.2" - i18next "^22.0.0" - i18next-browser-languagedetector "^7.0.2" - immutable "4.3.1" - is-hotkey "0.2.0" - jquery "3.7.0" - lodash "4.17.21" - micro-memoize "^4.1.2" - moment "2.29.4" - monaco-editor "0.34.0" - ol "7.4.0" - prismjs "1.29.0" - rc-cascader "3.18.1" - rc-drawer "6.5.2" - rc-slider "10.3.1" - rc-time-picker "^3.7.3" - rc-tooltip "6.1.1" - react-beautiful-dnd "13.1.1" - react-calendar "4.3.0" - react-colorful "5.6.1" - react-custom-scrollbars-2 "4.5.0" - react-dropzone "14.2.3" - react-highlight-words "0.20.0" - react-hook-form "7.5.3" - react-i18next "^12.0.0" - react-inlinesvg "3.0.2" - react-loading-skeleton "3.3.1" - react-popper "2.3.0" - react-popper-tooltip "4.4.2" - react-router-dom "5.3.3" - react-select "5.7.4" - react-select-event "^5.1.0" - react-table "7.8.0" - react-transition-group "4.4.5" - react-use "17.4.0" - react-window "1.8.9" - rxjs "7.8.1" - slate "0.47.9" - slate-plain-serializer "0.7.13" - slate-react "0.22.10" - tinycolor2 "1.6.0" - tslib "2.6.0" - uplot "1.6.26" - uuid "9.0.0" - -"@grafana/ui@10.4.0-161545": - version "10.4.0-161545" - resolved "https://registry.yarnpkg.com/@grafana/ui/-/ui-10.4.0-161545.tgz#9f7fcbbb231e172a434083413432f6328883f535" - integrity sha512-wFFyQICjlCud7YChWdb5PzGJzauOxCQT+acZ/2A2hw926V7Io/bxQTrv/j+fingxn6CrWhfRJK8+zudL3uuXPQ== +"@grafana/ui@11.0.0-162094", "@grafana/ui@11.0.0-pre": + version "11.0.0-162094" + resolved "https://registry.yarnpkg.com/@grafana/ui/-/ui-11.0.0-162094.tgz#adfc7fab0a755982d2cbeeb0989b10cb7ee89963" + integrity sha512-52hP39yD9M3v5L1hkuCq9T4p0H5M/YMVEXmO1Na8KnuB3+a5B2OnW7KJqTTfzDWskhKc/zwfs1RYo+LN9lCjog== dependencies: "@emotion/css" "11.11.2" "@emotion/react" "11.11.3" "@floating-ui/react" "0.26.9" - "@grafana/data" "10.4.0-161545" - "@grafana/e2e-selectors" "10.4.0-161545" + "@grafana/data" "11.0.0-162094" + "@grafana/e2e-selectors" "11.0.0-162094" "@grafana/faro-web-sdk" "^1.3.6" - "@grafana/schema" "10.4.0-161545" + "@grafana/schema" "11.0.0-162094" "@leeoniya/ufuzzy" "1.0.14" "@monaco-editor/react" "4.6.0" "@popperjs/core" "2.11.8" - "@react-aria/dialog" "3.5.11" - "@react-aria/focus" "3.16.1" - "@react-aria/overlays" "3.21.0" - "@react-aria/utils" "3.23.1" + "@react-aria/dialog" "3.5.12" + "@react-aria/focus" "3.16.2" + "@react-aria/overlays" "3.21.1" + "@react-aria/utils" "3.23.2" ansicolor "1.1.100" calculate-size "1.1.1" classnames "2.5.1" @@ -1827,7 +1624,7 @@ uplot "1.6.30" uuid "9.0.1" -"@humanwhocodes/config-array@^0.11.10", "@humanwhocodes/config-array@^0.11.11": +"@humanwhocodes/config-array@^0.11.10": version "0.11.11" resolved "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.11.tgz" integrity sha512-N2brEuAadi0CcdeMXUkhbZB84eskAc8MEX1By6qEchoVywSgXPIjou4rYsl0V3Hj0ZnuGycGCjdNgockbzeWNA== @@ -1836,6 +1633,15 @@ debug "^4.1.1" minimatch "^3.0.5" +"@humanwhocodes/config-array@^0.11.13": + version "0.11.14" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.11.14.tgz#d78e481a039f7566ecc9660b4ea7fe6b1fec442b" + integrity sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg== + dependencies: + "@humanwhocodes/object-schema" "^2.0.2" + debug "^4.3.1" + minimatch "^3.0.5" + "@humanwhocodes/module-importer@^1.0.1": version "1.0.1" resolved "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz" @@ -1846,12 +1652,10 @@ resolved "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz" integrity sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA== -"@internationalized/date@^3.5.1": - version "3.5.1" - resolved "https://registry.npmjs.org/@internationalized/date/-/date-3.5.1.tgz" - integrity sha512-LUQIfwU9e+Fmutc/DpRTGXSdgYZLBegi4wygCWDSVmUdLTaMHsQyASDiJtREwanwKuQLq0hY76fCJ9J/9I2xOQ== - dependencies: - "@swc/helpers" "^0.5.0" +"@humanwhocodes/object-schema@^2.0.2": + version "2.0.2" + resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz#d9fae00a2d5cb40f92cfe64b47ad749fbc38f917" + integrity sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw== "@internationalized/date@^3.5.2": version "3.5.2" @@ -1860,14 +1664,6 @@ dependencies: "@swc/helpers" "^0.5.0" -"@internationalized/message@^3.1.1": - version "3.1.1" - resolved "https://registry.npmjs.org/@internationalized/message/-/message-3.1.1.tgz" - integrity sha512-ZgHxf5HAPIaR0th+w0RUD62yF6vxitjlprSxmLJ1tam7FOekqRSDELMg4Cr/DdszG5YLsp5BG3FgHgqquQZbqw== - dependencies: - "@swc/helpers" "^0.5.0" - intl-messageformat "^10.1.0" - "@internationalized/message@^3.1.2": version "3.1.2" resolved "https://registry.yarnpkg.com/@internationalized/message/-/message-3.1.2.tgz#c42fcc5118b6e9c4cd2109695daf1ad126a87375" @@ -1876,13 +1672,6 @@ "@swc/helpers" "^0.5.0" intl-messageformat "^10.1.0" -"@internationalized/number@^3.5.0": - version "3.5.0" - resolved "https://registry.npmjs.org/@internationalized/number/-/number-3.5.0.tgz" - integrity sha512-ZY1BW8HT9WKYvaubbuqXbbDdHhOUMfE2zHHFJeTppid0S+pc8HtdIxFxaYMsGjCb4UsF+MEJ4n2TfU7iHnUK8w== - dependencies: - "@swc/helpers" "^0.5.0" - "@internationalized/number@^3.5.1": version "3.5.1" resolved "https://registry.yarnpkg.com/@internationalized/number/-/number-3.5.1.tgz#8e3359b498aec6bb865be668ef7e794a424067a7" @@ -1890,13 +1679,6 @@ dependencies: "@swc/helpers" "^0.5.0" -"@internationalized/string@^3.2.0": - version "3.2.0" - resolved "https://registry.npmjs.org/@internationalized/string/-/string-3.2.0.tgz" - integrity sha512-Xx3Sy3f2c9ctT+vh8c7euEaEHQZltp0euZ3Hy4UfT3E13r6lxpUS3kgKyumEjboJZSnaZv7JhqWz3D75v+IxQg== - dependencies: - "@swc/helpers" "^0.5.0" - "@internationalized/string@^3.2.1": version "3.2.1" resolved "https://registry.yarnpkg.com/@internationalized/string/-/string-3.2.1.tgz#9059a580956b0af882ab05409efa276a42e2d960" @@ -1944,7 +1726,7 @@ jest-util "^29.7.0" slash "^3.0.0" -"@jest/core@^29.5.0", "@jest/core@^29.7.0": +"@jest/core@^29.7.0": version "29.7.0" resolved "https://registry.npmjs.org/@jest/core/-/core-29.7.0.tgz" integrity sha512-n7aeXWKMnGtDA48y8TLWJPJmLmmZ642Ceo78cYWEpiD7FzDgmNDV/GCVRorPABdXLJZ/9wzzgZAlHjXjxDHGsg== @@ -1985,7 +1767,7 @@ dependencies: "@jest/types" "^27.5.1" -"@jest/environment@^29.5.0", "@jest/environment@^29.7.0": +"@jest/environment@^29.7.0": version "29.7.0" resolved "https://registry.npmjs.org/@jest/environment/-/environment-29.7.0.tgz" integrity sha512-aQIfHDq33ExsN4jP1NWGXhxgQ/wixs60gDiKO+XVMd8Mn0NWPWgc34ZQDTb2jKaUWQ7MuwoitXAsN2XVXNMpAw== @@ -2010,7 +1792,7 @@ expect "^29.7.0" jest-snapshot "^29.7.0" -"@jest/fake-timers@^29.5.0", "@jest/fake-timers@^29.7.0": +"@jest/fake-timers@^29.7.0": version "29.7.0" resolved "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.7.0.tgz" integrity sha512-q4DH1Ha4TTFPdxLsqDXK1d3+ioSL7yL5oCMJZgDYm6i+6CygW5E5xVr/D1HdsGxjt1ZWSfUAs9OxSB/BNelWrQ== @@ -2130,7 +1912,7 @@ "@types/yargs" "^16.0.0" chalk "^4.0.0" -"@jest/types@^29.5.0", "@jest/types@^29.6.3": +"@jest/types@^29.6.3": version "29.6.3" resolved "https://registry.npmjs.org/@jest/types/-/types-29.6.3.tgz" integrity sha512-u3UPsIilWKOM3F9CXtrG8LEJmNxwoCQC/XVj4IKYXvvpx7QIi/Kg1LI5uDmDpKlac62NUtX7eLjRh+jVZcLOzw== @@ -2190,32 +1972,28 @@ "@jridgewell/resolve-uri" "^3.1.0" "@jridgewell/sourcemap-codec" "^1.4.14" +"@jridgewell/trace-mapping@^0.3.20": + version "0.3.22" + resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.22.tgz#72a621e5de59f5f1ef792d0793a82ee20f645e4c" + integrity sha512-Wf963MzWtA2sjrNt+g18IAln9lKnlRp+K2eH4jjIoF1wYeq3aMREpG09xhlhdzS0EjwU7qmUJYangWa+151vZw== + dependencies: + "@jridgewell/resolve-uri" "^3.1.0" + "@jridgewell/sourcemap-codec" "^1.4.14" + "@leeoniya/ufuzzy@1.0.14": version "1.0.14" resolved "https://registry.yarnpkg.com/@leeoniya/ufuzzy/-/ufuzzy-1.0.14.tgz#01572c0de9cfa1420cf6ecac76dd59db5ebd1337" integrity sha512-/xF4baYuCQMo+L/fMSUrZnibcu0BquEGnbxfVPiZhs/NbJeKj4c/UmFpQzW9Us0w45ui/yYW3vyaqawhNYsTzA== -"@leeoniya/ufuzzy@1.0.8": - version "1.0.8" - resolved "https://registry.npmjs.org/@leeoniya/ufuzzy/-/ufuzzy-1.0.8.tgz" - integrity sha512-HQ6aJlYpWLq1f9AiApJl0aOIXlJUtuhBOYfSfv5rt3XNYkCBveojtnL6FvOVpJ2gEJ2wqgMW8xOHkLVYAbXghg== - -"@lezer/common@1.1.0", "@lezer/common@^1.0.0": - version "1.1.0" - resolved "https://registry.npmjs.org/@lezer/common/-/common-1.1.0.tgz" - integrity sha512-XPIN3cYDXsoJI/oDWoR2tD++juVrhgIago9xyKhZ7IhGlzdDM9QgC8D8saKNCz5pindGcznFr2HBSsEQSWnSjw== - "@lezer/common@1.2.1": version "1.2.1" resolved "https://registry.yarnpkg.com/@lezer/common/-/common-1.2.1.tgz#198b278b7869668e1bebbe687586e12a42731049" integrity sha512-yemX0ZD2xS/73llMZIK6KplkjIjf2EvAHcinDi/TfJ9hS25G0388+ClHt6/3but0oOxinTcQHJLDXh6w1crzFQ== -"@lezer/highlight@1.1.3": - version "1.1.3" - resolved "https://registry.npmjs.org/@lezer/highlight/-/highlight-1.1.3.tgz" - integrity sha512-3vLKLPThO4td43lYRBygmMY18JN3CPh9w+XS2j8WC30vR4yZeFG4z1iFe4jXE43NtGqe//zHW5q8ENLlHvz9gw== - dependencies: - "@lezer/common" "^1.0.0" +"@lezer/common@^1.0.0": + version "1.1.0" + resolved "https://registry.npmjs.org/@lezer/common/-/common-1.1.0.tgz" + integrity sha512-XPIN3cYDXsoJI/oDWoR2tD++juVrhgIago9xyKhZ7IhGlzdDM9QgC8D8saKNCz5pindGcznFr2HBSsEQSWnSjw== "@lezer/highlight@1.2.0": version "1.2.0" @@ -2300,13 +2078,6 @@ "@nodelib/fs.scandir" "2.1.5" fastq "^1.6.0" -"@opentelemetry/api-logs@0.41.2": - version "0.41.2" - resolved "https://registry.npmjs.org/@opentelemetry/api-logs/-/api-logs-0.41.2.tgz" - integrity sha512-JEV2RAqijAFdWeT6HddYymfnkiRu2ASxoTBr4WsnGJhOjWZkEy6vp+Sx9ozr1NaIODOa2HUyckExIqQjn6qywQ== - dependencies: - "@opentelemetry/api" "^1.0.0" - "@opentelemetry/api-logs@0.48.0": version "0.48.0" resolved "https://registry.yarnpkg.com/@opentelemetry/api-logs/-/api-logs-0.48.0.tgz#9521a0c1e920ed536f31cda117164c4afff44caf" @@ -2314,14 +2085,7 @@ dependencies: "@opentelemetry/api" "^1.0.0" -"@opentelemetry/api-metrics@^0.33.0": - version "0.33.0" - resolved "https://registry.npmjs.org/@opentelemetry/api-metrics/-/api-metrics-0.33.0.tgz" - integrity sha512-78evfPRRRnJA6uZ3xuBuS3VZlXTO/LRs+Ff1iv3O/7DgibCtq9k27T6Zlj8yRdJDFmcjcbQrvC0/CpDpWHaZYA== - dependencies: - "@opentelemetry/api" "^1.0.0" - -"@opentelemetry/api@^1.0.0", "@opentelemetry/api@^1.4.1": +"@opentelemetry/api@^1.0.0": version "1.4.1" resolved "https://registry.npmjs.org/@opentelemetry/api/-/api-1.4.1.tgz" integrity sha512-O2yRJce1GOc6PAy3QxFM4NzFiWzvScDC1/5ihYBL6BUEVdq0XMWN01sppE+H6bBXbaFYipjwFLEWLg5PaSOThA== @@ -2331,13 +2095,6 @@ resolved "https://registry.yarnpkg.com/@opentelemetry/api/-/api-1.7.0.tgz#b139c81999c23e3c8d3c0a7234480e945920fc40" integrity sha512-AdY5wvN0P2vXBi3b29hxZgSFvdhdxPB9+f0B6s//P9Q8nibRWeA3cHm8UmLpio9ABigkVHJ5NMPk+Mz8VCCyrw== -"@opentelemetry/core@1.15.2": - version "1.15.2" - resolved "https://registry.npmjs.org/@opentelemetry/core/-/core-1.15.2.tgz" - integrity sha512-+gBv15ta96WqkHZaPpcDHiaz0utiiHZVfm2YOYSqFGrUaJpPkMoSuLBB58YFQGi6Rsb9EHos84X6X5+9JspmLw== - dependencies: - "@opentelemetry/semantic-conventions" "1.15.2" - "@opentelemetry/core@1.21.0": version "1.21.0" resolved "https://registry.yarnpkg.com/@opentelemetry/core/-/core-1.21.0.tgz#8c16faf16edf861b073c03c9d45977b3f4003ee1" @@ -2345,18 +2102,6 @@ dependencies: "@opentelemetry/semantic-conventions" "1.21.0" -"@opentelemetry/otlp-transformer@^0.41.2": - version "0.41.2" - resolved "https://registry.npmjs.org/@opentelemetry/otlp-transformer/-/otlp-transformer-0.41.2.tgz" - integrity sha512-jJbPwB0tNu2v+Xi0c/v/R3YBLJKLonw1p+v3RVjT2VfzeUyzSp/tBeVdY7RZtL6dzZpA9XSmp8UEfWIFQo33yA== - dependencies: - "@opentelemetry/api-logs" "0.41.2" - "@opentelemetry/core" "1.15.2" - "@opentelemetry/resources" "1.15.2" - "@opentelemetry/sdk-logs" "0.41.2" - "@opentelemetry/sdk-metrics" "1.15.2" - "@opentelemetry/sdk-trace-base" "1.15.2" - "@opentelemetry/otlp-transformer@^0.48.0": version "0.48.0" resolved "https://registry.yarnpkg.com/@opentelemetry/otlp-transformer/-/otlp-transformer-0.48.0.tgz#969d52a767c7538552b88f7baaa001d3f88feb17" @@ -2369,14 +2114,6 @@ "@opentelemetry/sdk-metrics" "1.21.0" "@opentelemetry/sdk-trace-base" "1.21.0" -"@opentelemetry/resources@1.15.2": - version "1.15.2" - resolved "https://registry.npmjs.org/@opentelemetry/resources/-/resources-1.15.2.tgz" - integrity sha512-xmMRLenT9CXmm5HMbzpZ1hWhaUowQf8UB4jMjFlAxx1QzQcsD3KFNAVX/CAWzFPtllTyTplrA4JrQ7sCH3qmYw== - dependencies: - "@opentelemetry/core" "1.15.2" - "@opentelemetry/semantic-conventions" "1.15.2" - "@opentelemetry/resources@1.21.0": version "1.21.0" resolved "https://registry.yarnpkg.com/@opentelemetry/resources/-/resources-1.21.0.tgz#e773e918cc8ca26493a987dfbfc6b8a315a2ab45" @@ -2385,14 +2122,6 @@ "@opentelemetry/core" "1.21.0" "@opentelemetry/semantic-conventions" "1.21.0" -"@opentelemetry/sdk-logs@0.41.2": - version "0.41.2" - resolved "https://registry.npmjs.org/@opentelemetry/sdk-logs/-/sdk-logs-0.41.2.tgz" - integrity sha512-smqKIw0tTW15waj7BAPHFomii5c3aHnSE4LQYTszGoK5P9nZs8tEAIpu15UBxi3aG31ZfsLmm4EUQkjckdlFrw== - dependencies: - "@opentelemetry/core" "1.15.2" - "@opentelemetry/resources" "1.15.2" - "@opentelemetry/sdk-logs@0.48.0": version "0.48.0" resolved "https://registry.yarnpkg.com/@opentelemetry/sdk-logs/-/sdk-logs-0.48.0.tgz#5248e4cbfc99bbee555ffd1a23b5db53d6553f2c" @@ -2401,15 +2130,6 @@ "@opentelemetry/core" "1.21.0" "@opentelemetry/resources" "1.21.0" -"@opentelemetry/sdk-metrics@1.15.2": - version "1.15.2" - resolved "https://registry.npmjs.org/@opentelemetry/sdk-metrics/-/sdk-metrics-1.15.2.tgz" - integrity sha512-9aIlcX8GnhcsAHW/Wl8bzk4ZnWTpNlLtud+fxUfBtFATu6OZ6TrGrF4JkT9EVrnoxwtPIDtjHdEsSjOqisY/iA== - dependencies: - "@opentelemetry/core" "1.15.2" - "@opentelemetry/resources" "1.15.2" - lodash.merge "^4.6.2" - "@opentelemetry/sdk-metrics@1.21.0": version "1.21.0" resolved "https://registry.yarnpkg.com/@opentelemetry/sdk-metrics/-/sdk-metrics-1.21.0.tgz#40d71aaec5b696e58743889ce6d5bf2593f9a23d" @@ -2419,15 +2139,6 @@ "@opentelemetry/resources" "1.21.0" lodash.merge "^4.6.2" -"@opentelemetry/sdk-trace-base@1.15.2": - version "1.15.2" - resolved "https://registry.npmjs.org/@opentelemetry/sdk-trace-base/-/sdk-trace-base-1.15.2.tgz" - integrity sha512-BEaxGZbWtvnSPchV98qqqqa96AOcb41pjgvhfzDij10tkBhIu9m0Jd6tZ1tJB5ZHfHbTffqYVYE0AOGobec/EQ== - dependencies: - "@opentelemetry/core" "1.15.2" - "@opentelemetry/resources" "1.15.2" - "@opentelemetry/semantic-conventions" "1.15.2" - "@opentelemetry/sdk-trace-base@1.21.0": version "1.21.0" resolved "https://registry.yarnpkg.com/@opentelemetry/sdk-trace-base/-/sdk-trace-base-1.21.0.tgz#ffad912e453a92044fb220bd5d2f6743bf37bb8a" @@ -2437,11 +2148,6 @@ "@opentelemetry/resources" "1.21.0" "@opentelemetry/semantic-conventions" "1.21.0" -"@opentelemetry/semantic-conventions@1.15.2": - version "1.15.2" - resolved "https://registry.npmjs.org/@opentelemetry/semantic-conventions/-/semantic-conventions-1.15.2.tgz" - integrity sha512-CjbOKwk2s+3xPIMcd5UNYQzsf+v94RczbdNix9/kQh38WiQkM90sUOi3if8eyHFgiBjBjhwXrA7W3ydiSQP9mw== - "@opentelemetry/semantic-conventions@1.21.0": version "1.21.0" resolved "https://registry.yarnpkg.com/@opentelemetry/semantic-conventions/-/semantic-conventions-1.21.0.tgz#83f7479c524ab523ac2df702ade30b9724476c72" @@ -2457,6 +2163,13 @@ resolved "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz" integrity sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg== +"@playwright/test@^1.41.2": + version "1.41.2" + resolved "https://registry.yarnpkg.com/@playwright/test/-/test-1.41.2.tgz#bd9db40177f8fd442e16e14e0389d23751cdfc54" + integrity sha512-qQB9h7KbibJzrDpkXkYvsmiDJK14FULCCZgEcoe2AvFAS64oCirWTwzTlAYEbKaRxWs5TFesE1Na6izMv3HfGg== + dependencies: + playwright "1.41.2" + "@popperjs/core@2.11.8", "@popperjs/core@^2.11.5": version "2.11.8" resolved "https://registry.npmjs.org/@popperjs/core/-/core-2.11.8.tgz" @@ -2481,7 +2194,7 @@ classnames "^2.3.2" rc-util "^5.24.4" -"@rc-component/trigger@^1.17.0", "@rc-component/trigger@^1.18.0", "@rc-component/trigger@^1.5.0": +"@rc-component/trigger@^1.18.0", "@rc-component/trigger@^1.5.0": version "1.18.3" resolved "https://registry.npmjs.org/@rc-component/trigger/-/trigger-1.18.3.tgz" integrity sha512-Ksr25pXreYe1gX6ayZ1jLrOrl9OAUHUqnuhEx6MeHnNa1zVM5Y2Aj3Q35UrER0ns8D2cJYtmJtVli+i+4eKrvA== @@ -2493,78 +2206,19 @@ rc-resize-observer "^1.3.1" rc-util "^5.38.0" -"@react-aria/button@3.8.0": - version "3.8.0" - resolved "https://registry.npmjs.org/@react-aria/button/-/button-3.8.0.tgz" - integrity sha512-QdvXTQgn+QEWOHoMbUIPXSBIN5P2r1zthRvqDJMTCzuT0I6LbNAq7RoojEbRrcn0DbTa/nZPzOOYsZXjgteRdw== - dependencies: - "@react-aria/focus" "^3.13.0" - "@react-aria/interactions" "^3.16.0" - "@react-aria/utils" "^3.18.0" - "@react-stately/toggle" "^3.6.0" - "@react-types/button" "^3.7.3" - "@react-types/shared" "^3.18.1" - "@swc/helpers" "^0.5.0" - -"@react-aria/dialog@3.5.11": - version "3.5.11" - resolved "https://registry.yarnpkg.com/@react-aria/dialog/-/dialog-3.5.11.tgz#b9db0089e783967c426b7407c021e1ee7fdcb687" - integrity sha512-oT+FBOtPZRWVBxPt1K8F5XaKGYpi+ZV3oFFzub8w+D6m+9WN4pktUx7YBz95Kunw7M1HcAsyQZX0fsAuDPL7Rw== +"@react-aria/dialog@3.5.12": + version "3.5.12" + resolved "https://registry.yarnpkg.com/@react-aria/dialog/-/dialog-3.5.12.tgz#e43d31211bde833de6add609e4f24e8409a9a200" + integrity sha512-7UJR/h/Y364u6Ltpw0bT51B48FybTuIBacGpEJN5IxZlpxvQt0KQcBDiOWfAa/GQogw4B5hH6agaOO0nJcP49Q== dependencies: - "@react-aria/focus" "^3.16.1" - "@react-aria/overlays" "^3.21.0" - "@react-aria/utils" "^3.23.1" - "@react-types/dialog" "^3.5.7" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - -"@react-aria/dialog@3.5.3": - version "3.5.3" - resolved "https://registry.npmjs.org/@react-aria/dialog/-/dialog-3.5.3.tgz" - integrity sha512-wXpAqnt6TtR4X/5Xk5HCTBM0qyPcF2bXFQ5z2gSwl1olgoQ5znZEgMqMLbMmwb4dsWGGtAueULs6fVZk766ygA== - dependencies: - "@react-aria/focus" "^3.13.0" - "@react-aria/overlays" "^3.15.0" - "@react-aria/utils" "^3.18.0" - "@react-stately/overlays" "^3.6.0" - "@react-types/dialog" "^3.5.3" - "@react-types/shared" "^3.18.1" - "@swc/helpers" "^0.5.0" - -"@react-aria/focus@3.13.0", "@react-aria/focus@^3.13.0": - version "3.13.0" - resolved "https://registry.npmjs.org/@react-aria/focus/-/focus-3.13.0.tgz" - integrity sha512-9DW7RqgbFWiImZmkmTIJGe9LrQBqEeLYwlKY+F1FTVXerIPiCCQ3JO3ESEa4lFMmkaHoueFLUrq2jkYjRNqoTw== - dependencies: - "@react-aria/interactions" "^3.16.0" - "@react-aria/utils" "^3.18.0" - "@react-types/shared" "^3.18.1" - "@swc/helpers" "^0.5.0" - clsx "^1.1.1" - -"@react-aria/focus@3.16.1": - version "3.16.1" - resolved "https://registry.yarnpkg.com/@react-aria/focus/-/focus-3.16.1.tgz#557a451cbe901153d23045ce27851b05709db24a" - integrity sha512-3ZEYc+hWqDQX7fA54ZOTkED8OGXs9+K9fYmjD1IdjZJAJS/2/AJ95PgIQ29zBkl9D9TAi4Nb3tJ/3+H/02UzoA== - dependencies: - "@react-aria/interactions" "^3.21.0" - "@react-aria/utils" "^3.23.1" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - clsx "^2.0.0" - -"@react-aria/focus@^3.16.0": - version "3.16.0" - resolved "https://registry.npmjs.org/@react-aria/focus/-/focus-3.16.0.tgz" - integrity sha512-GP6EYI07E8NKQQcXHjpIocEU0vh0oi0Vcsd+/71fKS0NnTR0TUOEeil0JuuQ9ymkmPDTu51Aaaa4FxVsuN/23A== - dependencies: - "@react-aria/interactions" "^3.20.1" - "@react-aria/utils" "^3.23.0" - "@react-types/shared" "^3.22.0" + "@react-aria/focus" "^3.16.2" + "@react-aria/overlays" "^3.21.1" + "@react-aria/utils" "^3.23.2" + "@react-types/dialog" "^3.5.8" + "@react-types/shared" "^3.22.1" "@swc/helpers" "^0.5.0" - clsx "^2.0.0" -"@react-aria/focus@^3.16.1", "@react-aria/focus@^3.16.2": +"@react-aria/focus@3.16.2", "@react-aria/focus@^3.16.2": version "3.16.2" resolved "https://registry.yarnpkg.com/@react-aria/focus/-/focus-3.16.2.tgz#2285bc19e091233b4d52399c506ac8fa60345b44" integrity sha512-Rqo9ummmgotESfypzFjI3uh58yMpL+E+lJBbQuXkBM0u0cU2YYzu0uOrFrq3zcHk997udZvq1pGK/R+2xk9B7g== @@ -2575,21 +2229,7 @@ "@swc/helpers" "^0.5.0" clsx "^2.0.0" -"@react-aria/i18n@^3.10.0", "@react-aria/i18n@^3.8.0": - version "3.10.0" - resolved "https://registry.npmjs.org/@react-aria/i18n/-/i18n-3.10.0.tgz" - integrity sha512-sviD5Y1pLPG49HHRmVjR+5nONrp0HK219+nu9Y7cDfUhXu2EjyhMS9t/n9/VZ69hHChZ2PnHYLEE2visu9CuCg== - dependencies: - "@internationalized/date" "^3.5.1" - "@internationalized/message" "^3.1.1" - "@internationalized/number" "^3.5.0" - "@internationalized/string" "^3.2.0" - "@react-aria/ssr" "^3.9.1" - "@react-aria/utils" "^3.23.0" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - -"@react-aria/i18n@^3.10.1", "@react-aria/i18n@^3.10.2": +"@react-aria/i18n@^3.10.2": version "3.10.2" resolved "https://registry.yarnpkg.com/@react-aria/i18n/-/i18n-3.10.2.tgz#b421b1d96bc92d5e2a042d53f24d16fdbe07821f" integrity sha512-Z1ormoIvMOI4mEdcFLYsoJy9w/EzBdBmgfLP+S/Ah+1xwQOXpgwZxiKOhYHpWa0lf6hkKJL34N9MHJvCJ5Crvw== @@ -2603,17 +2243,7 @@ "@react-types/shared" "^3.22.1" "@swc/helpers" "^0.5.0" -"@react-aria/interactions@^3.16.0", "@react-aria/interactions@^3.20.1": - version "3.20.1" - resolved "https://registry.npmjs.org/@react-aria/interactions/-/interactions-3.20.1.tgz" - integrity sha512-PLNBr87+SzRhe9PvvF9qvzYeP4ofTwfKSorwmO+hjr3qoczrSXf4LRQlb27wB6hF10C7ZE/XVbUI1lj4QQrZ/g== - dependencies: - "@react-aria/ssr" "^3.9.1" - "@react-aria/utils" "^3.23.0" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - -"@react-aria/interactions@^3.21.0", "@react-aria/interactions@^3.21.1": +"@react-aria/interactions@^3.21.1": version "3.21.1" resolved "https://registry.yarnpkg.com/@react-aria/interactions/-/interactions-3.21.1.tgz#d8d9b0cf628d0bf4bb4e9d7eac485cfb9ed9cb97" integrity sha512-AlHf5SOzsShkHfV8GLLk3v9lEmYqYHURKcXWue0JdYbmquMRkUsf/+Tjl1+zHVAQ8lKqRnPYbTmc4AcZbqxltw== @@ -2623,60 +2253,7 @@ "@react-types/shared" "^3.22.1" "@swc/helpers" "^0.5.0" -"@react-aria/menu@3.10.0": - version "3.10.0" - resolved "https://registry.npmjs.org/@react-aria/menu/-/menu-3.10.0.tgz" - integrity sha512-zOOOXvx21aGSxZsXvLa3NV48hLk0jBC/zu5WZHT0Mo/wAe0+43f8p/U3AT8Gc4WnxYbIestcdLaIwgeagSoLtQ== - dependencies: - "@react-aria/focus" "^3.13.0" - "@react-aria/i18n" "^3.8.0" - "@react-aria/interactions" "^3.16.0" - "@react-aria/overlays" "^3.15.0" - "@react-aria/selection" "^3.16.0" - "@react-aria/utils" "^3.18.0" - "@react-stately/collections" "^3.9.0" - "@react-stately/menu" "^3.5.3" - "@react-stately/tree" "^3.7.0" - "@react-types/button" "^3.7.3" - "@react-types/menu" "^3.9.2" - "@react-types/shared" "^3.18.1" - "@swc/helpers" "^0.5.0" - -"@react-aria/overlays@3.15.0", "@react-aria/overlays@^3.15.0": - version "3.15.0" - resolved "https://registry.npmjs.org/@react-aria/overlays/-/overlays-3.15.0.tgz" - integrity sha512-MeLn74GvXZfi881NSx5sSd5eTduki/PMk4vPvMNp2Xm+9nGHm0FbGu2GMIGgarYy5JC7l/bOO7H01YrS4AozPg== - dependencies: - "@react-aria/focus" "^3.13.0" - "@react-aria/i18n" "^3.8.0" - "@react-aria/interactions" "^3.16.0" - "@react-aria/ssr" "^3.7.0" - "@react-aria/utils" "^3.18.0" - "@react-aria/visually-hidden" "^3.8.2" - "@react-stately/overlays" "^3.6.0" - "@react-types/button" "^3.7.3" - "@react-types/overlays" "^3.8.0" - "@react-types/shared" "^3.18.1" - "@swc/helpers" "^0.5.0" - -"@react-aria/overlays@3.21.0": - version "3.21.0" - resolved "https://registry.yarnpkg.com/@react-aria/overlays/-/overlays-3.21.0.tgz#62818e676542e5ad4a12e89577b12543e6efb438" - integrity sha512-ulE5RQP3ZUFqY6Zok4L/CCZW5HCPZeuyDEezPw4/4Y/WD6TjGZ1ChbPuGsAl+X+fo/iKTpe7joN4kYrKmTb5WA== - dependencies: - "@react-aria/focus" "^3.16.1" - "@react-aria/i18n" "^3.10.1" - "@react-aria/interactions" "^3.21.0" - "@react-aria/ssr" "^3.9.1" - "@react-aria/utils" "^3.23.1" - "@react-aria/visually-hidden" "^3.8.9" - "@react-stately/overlays" "^3.6.4" - "@react-types/button" "^3.9.1" - "@react-types/overlays" "^3.8.4" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - -"@react-aria/overlays@^3.21.0": +"@react-aria/overlays@3.21.1", "@react-aria/overlays@^3.21.1": version "3.21.1" resolved "https://registry.yarnpkg.com/@react-aria/overlays/-/overlays-3.21.1.tgz#7119191e9c52febb9357fc143ba546cf999f4ec1" integrity sha512-djEBDF+TbIIOHWWNpdm19+z8xtY8U+T+wKVQg/UZ6oWnclSqSWeGl70vu73Cg4HVBJ4hKf1SRx4Z/RN6VvH4Yw== @@ -2693,26 +2270,6 @@ "@react-types/shared" "^3.22.1" "@swc/helpers" "^0.5.0" -"@react-aria/selection@^3.16.0": - version "3.17.3" - resolved "https://registry.npmjs.org/@react-aria/selection/-/selection-3.17.3.tgz" - integrity sha512-xl2sgeGH61ngQeE05WOWWPVpGRTPMjQEFmsAWEprArFi4Z7ihSZgpGX22l1w7uSmtXM/eN/v0W8hUYUju5iXlQ== - dependencies: - "@react-aria/focus" "^3.16.0" - "@react-aria/i18n" "^3.10.0" - "@react-aria/interactions" "^3.20.1" - "@react-aria/utils" "^3.23.0" - "@react-stately/selection" "^3.14.2" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - -"@react-aria/ssr@^3.7.0", "@react-aria/ssr@^3.9.1": - version "3.9.1" - resolved "https://registry.npmjs.org/@react-aria/ssr/-/ssr-3.9.1.tgz" - integrity sha512-NqzkLFP8ZVI4GSorS0AYljC13QW2sc8bDqJOkBvkAt3M8gbcAXJWVRGtZBCRscki9RZF+rNlnPdg0G0jYkhJcg== - dependencies: - "@swc/helpers" "^0.5.0" - "@react-aria/ssr@^3.9.2": version "3.9.2" resolved "https://registry.yarnpkg.com/@react-aria/ssr/-/ssr-3.9.2.tgz#01b756965cd6e32b95217f968f513eb3bd6ee44b" @@ -2720,40 +2277,7 @@ dependencies: "@swc/helpers" "^0.5.0" -"@react-aria/utils@3.18.0", "@react-aria/utils@^3.18.0": - version "3.18.0" - resolved "https://registry.npmjs.org/@react-aria/utils/-/utils-3.18.0.tgz" - integrity sha512-eLs0ExzXx/D3P9qe6ophJ87ZFcI1oRTyRa51M59pCad7grrpk0gWcYrBjMwcR457YWOQQWCeLuq8QJl2QxCW6Q== - dependencies: - "@react-aria/ssr" "^3.7.0" - "@react-stately/utils" "^3.7.0" - "@react-types/shared" "^3.18.1" - "@swc/helpers" "^0.5.0" - clsx "^1.1.1" - -"@react-aria/utils@3.23.1": - version "3.23.1" - resolved "https://registry.yarnpkg.com/@react-aria/utils/-/utils-3.23.1.tgz#a082a5ffb97a7b9c03d522dcedfc251af8473e44" - integrity sha512-iXibf9ojqdoygbvy/++v5cKLKgjc/5ZmKV8/9u/2Hkpha1cf5Td/Z+Vl42B6giUBAsuDio5kuZYfYC7Uk+t8ag== - dependencies: - "@react-aria/ssr" "^3.9.1" - "@react-stately/utils" "^3.9.0" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - clsx "^2.0.0" - -"@react-aria/utils@^3.23.0": - version "3.23.0" - resolved "https://registry.npmjs.org/@react-aria/utils/-/utils-3.23.0.tgz" - integrity sha512-fJA63/VU4iQNT8WUvrmll3kvToqMurD69CcgVmbQ56V7ZbvlzFi44E7BpnoaofScYLLtFWRjVdaHsohT6O/big== - dependencies: - "@react-aria/ssr" "^3.9.1" - "@react-stately/utils" "^3.9.0" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - clsx "^2.0.0" - -"@react-aria/utils@^3.23.1", "@react-aria/utils@^3.23.2": +"@react-aria/utils@3.23.2", "@react-aria/utils@^3.23.2": version "3.23.2" resolved "https://registry.yarnpkg.com/@react-aria/utils/-/utils-3.23.2.tgz#23fd55b165a799ecf72c1c66508574f67de20162" integrity sha512-yznR9jJ0GG+YJvTMZxijQwVp+ahP66DY0apZf7X+dllyN+ByEDW+yaL1ewYPIpugxVzH5P8jhnBXsIyHKN411g== @@ -2764,7 +2288,7 @@ "@swc/helpers" "^0.5.0" clsx "^2.0.0" -"@react-aria/visually-hidden@^3.8.10", "@react-aria/visually-hidden@^3.8.9": +"@react-aria/visually-hidden@^3.8.10": version "3.8.10" resolved "https://registry.yarnpkg.com/@react-aria/visually-hidden/-/visually-hidden-3.8.10.tgz#bd95254c9d1dae2acd8934870fb24ea762567eb4" integrity sha512-np8c4wxdbE7ZrMv/bnjwEfpX0/nkWy9sELEb0sK8n4+HJ+WycoXXrVxBUb9tXgL/GCx5ReeDQChjQWwajm/z3A== @@ -2774,45 +2298,7 @@ "@react-types/shared" "^3.22.1" "@swc/helpers" "^0.5.0" -"@react-aria/visually-hidden@^3.8.2": - version "3.8.8" - resolved "https://registry.npmjs.org/@react-aria/visually-hidden/-/visually-hidden-3.8.8.tgz" - integrity sha512-Cn2PYKD4ijGDtF0+dvsh8qa4y7KTNAlkTG6h20r8Q+6UTyRNmtE2/26QEaApRF8CBiNy9/BZC/ZC4FK2OjvCoA== - dependencies: - "@react-aria/interactions" "^3.20.1" - "@react-aria/utils" "^3.23.0" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - -"@react-stately/collections@^3.10.4", "@react-stately/collections@^3.9.0": - version "3.10.4" - resolved "https://registry.npmjs.org/@react-stately/collections/-/collections-3.10.4.tgz" - integrity sha512-OHhCrItGt4zB2bSrgObRo0H2SC7QlkH8ReGxo+NVIWchXRLRoiWBP7S+IwleewEo5gOqDVPY3hqA9n4iiI8twg== - dependencies: - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - -"@react-stately/menu@3.5.3", "@react-stately/menu@^3.5.3": - version "3.5.3" - resolved "https://registry.npmjs.org/@react-stately/menu/-/menu-3.5.3.tgz" - integrity sha512-RFgwVD/4BgTtJkexi1WaHpAEkQWZPvpyri0LQUgXWVqBf9PpjB8wigF3XBLMDNkL+YXE0QtzQZBNS1nJECf7rg== - dependencies: - "@react-stately/overlays" "^3.6.0" - "@react-stately/utils" "^3.7.0" - "@react-types/menu" "^3.9.2" - "@react-types/shared" "^3.18.1" - "@swc/helpers" "^0.5.0" - -"@react-stately/overlays@^3.6.0": - version "3.6.4" - resolved "https://registry.npmjs.org/@react-stately/overlays/-/overlays-3.6.4.tgz" - integrity sha512-tHEaoAGpE9dSnsskqLPVKum59yGteoSqsniTopodM+miQozbpPlSjdiQnzGLroy5Afx5OZYClE616muNHUILXA== - dependencies: - "@react-stately/utils" "^3.9.0" - "@react-types/overlays" "^3.8.4" - "@swc/helpers" "^0.5.0" - -"@react-stately/overlays@^3.6.4", "@react-stately/overlays@^3.6.5": +"@react-stately/overlays@^3.6.5": version "3.6.5" resolved "https://registry.yarnpkg.com/@react-stately/overlays/-/overlays-3.6.5.tgz#f36f2a381fddd0e5573dded857962439d4bf1aef" integrity sha512-U4rCFj6TPJPXLUvYXAcvh+yP/CO2W+7f0IuqP7ZZGE+Osk9qFkT+zRK5/6ayhBDFpmueNfjIEAzT9gYPQwNHFw== @@ -2821,43 +2307,6 @@ "@react-types/overlays" "^3.8.5" "@swc/helpers" "^0.5.0" -"@react-stately/selection@^3.14.2": - version "3.14.2" - resolved "https://registry.npmjs.org/@react-stately/selection/-/selection-3.14.2.tgz" - integrity sha512-mL7OoiUgVWaaF7ks5XSxgbXeShijYmD4G3bkBHhqkpugU600QH6BM2hloCq8KOUupk1y8oTljPtF9EmCv375DA== - dependencies: - "@react-stately/collections" "^3.10.4" - "@react-stately/utils" "^3.9.0" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - -"@react-stately/toggle@^3.6.0": - version "3.7.0" - resolved "https://registry.npmjs.org/@react-stately/toggle/-/toggle-3.7.0.tgz" - integrity sha512-TRksHkCJk/Xogq4181g3CYgJf+EfsJCqX5UZDSw1Z1Kgpvonjmdf6FAfQfCh9QR2OuXUL6hOLUDVLte5OPI+5g== - dependencies: - "@react-stately/utils" "^3.9.0" - "@react-types/checkbox" "^3.6.0" - "@swc/helpers" "^0.5.0" - -"@react-stately/tree@^3.7.0": - version "3.7.5" - resolved "https://registry.npmjs.org/@react-stately/tree/-/tree-3.7.5.tgz" - integrity sha512-xTJVwvhAeY0N5rui4N/TxN7f8hjXdqApDuGDxMZeFAWoQz8Abf7LFKBVQ3OkT6qVr7P+23dgoisUDBhD5a45Hg== - dependencies: - "@react-stately/collections" "^3.10.4" - "@react-stately/selection" "^3.14.2" - "@react-stately/utils" "^3.9.0" - "@react-types/shared" "^3.22.0" - "@swc/helpers" "^0.5.0" - -"@react-stately/utils@^3.7.0", "@react-stately/utils@^3.9.0": - version "3.9.0" - resolved "https://registry.npmjs.org/@react-stately/utils/-/utils-3.9.0.tgz" - integrity sha512-yPKFY1F88HxuZ15BG2qwAYxtpE4HnIU0Ofi4CuBE0xC6I8mwo4OQjDzi+DZjxQngM9D6AeTTD6F1V8gkozA0Gw== - dependencies: - "@swc/helpers" "^0.5.0" - "@react-stately/utils@^3.9.1": version "3.9.1" resolved "https://registry.yarnpkg.com/@react-stately/utils/-/utils-3.9.1.tgz#5ce94ca4f88fc991263c7b3fa4690b09e2153484" @@ -2865,36 +2314,14 @@ dependencies: "@swc/helpers" "^0.5.0" -"@react-types/button@^3.7.3": - version "3.9.1" - resolved "https://registry.npmjs.org/@react-types/button/-/button-3.9.1.tgz" - integrity sha512-bf9iTar3PtqnyV9rA+wyFyrskZKhwmOuOd/ifYIjPs56YNVXWH5Wfqj6Dx3xdFBgtKx8mEVQxVhoX+WkHX+rtw== - dependencies: - "@react-types/shared" "^3.22.0" - -"@react-types/button@^3.9.1", "@react-types/button@^3.9.2": +"@react-types/button@^3.9.2": version "3.9.2" resolved "https://registry.yarnpkg.com/@react-types/button/-/button-3.9.2.tgz#7b8797f3e4a4da5d7227a63974b81b03320791fe" integrity sha512-EnPTkGHZRtiwAoJy5q9lDjoG30bEzA/qnvKG29VVXKYAGeqY2IlFs1ypmU+z1X/CpJgPcG3I5cakM7yTVm3pSg== dependencies: "@react-types/shared" "^3.22.1" -"@react-types/checkbox@^3.6.0": - version "3.6.0" - resolved "https://registry.npmjs.org/@react-types/checkbox/-/checkbox-3.6.0.tgz" - integrity sha512-vgbuJzQpVCNT5AZWV0OozXCnihqrXxoZKfJFIw0xro47pT2sn3t5UC4RA9wfjDGMoK4frw1K/4HQLsQIOsPBkw== - dependencies: - "@react-types/shared" "^3.22.0" - -"@react-types/dialog@^3.5.3": - version "3.5.7" - resolved "https://registry.npmjs.org/@react-types/dialog/-/dialog-3.5.7.tgz" - integrity sha512-geYoqAyQaTLG43AaXdMUVqZXYgkSifrD9cF7lR2kPAT0uGFv0YREi6ieU+aui8XJ83EW0xcxP+EPWd2YkN4D4w== - dependencies: - "@react-types/overlays" "^3.8.4" - "@react-types/shared" "^3.22.0" - -"@react-types/dialog@^3.5.7": +"@react-types/dialog@^3.5.8": version "3.5.8" resolved "https://registry.yarnpkg.com/@react-types/dialog/-/dialog-3.5.8.tgz#03b2248659000db1325961cb67725fa7e8d32628" integrity sha512-RX8JsMvty8ADHRqVEkppoynXLtN4IzUh8d5z88UEBbcvWKlHfd6bOBQjQcBH3AUue5wjfpPIt6brw2VzgBY/3Q== @@ -2902,21 +2329,6 @@ "@react-types/overlays" "^3.8.5" "@react-types/shared" "^3.22.1" -"@react-types/menu@^3.9.2": - version "3.9.6" - resolved "https://registry.npmjs.org/@react-types/menu/-/menu-3.9.6.tgz" - integrity sha512-w/RbFInOf4nNayQDv5c2L8IMJbcFOkBhsT3xvvpTy+CHvJcQdjggwaV1sRiw7eF/PwB81k2CwigmidUzHJhKDg== - dependencies: - "@react-types/overlays" "^3.8.4" - "@react-types/shared" "^3.22.0" - -"@react-types/overlays@^3.8.0", "@react-types/overlays@^3.8.4": - version "3.8.4" - resolved "https://registry.npmjs.org/@react-types/overlays/-/overlays-3.8.4.tgz" - integrity sha512-pfgNlQnbF6RB/R2oSxyqAP3Uzz0xE/k5q4n5gUeCDNLjY5qxFHGE8xniZZ503nZYw6VBa9XMN1efDOKQyeiO0w== - dependencies: - "@react-types/shared" "^3.22.0" - "@react-types/overlays@^3.8.5": version "3.8.5" resolved "https://registry.yarnpkg.com/@react-types/overlays/-/overlays-3.8.5.tgz#2dbee3ab6e5ff87d4bd443468ef7c2c6d63b5383" @@ -2924,11 +2336,6 @@ dependencies: "@react-types/shared" "^3.22.1" -"@react-types/shared@^3.18.1", "@react-types/shared@^3.22.0": - version "3.22.0" - resolved "https://registry.npmjs.org/@react-types/shared/-/shared-3.22.0.tgz" - integrity sha512-yVOekZWbtSmmiThGEIARbBpnmUIuePFlLyctjvCbgJgGhz8JnEJOipLQ/a4anaWfzAgzSceQP8j/K+VOOePleA== - "@react-types/shared@^3.22.1": version "3.22.1" resolved "https://registry.yarnpkg.com/@react-types/shared/-/shared-3.22.1.tgz#4e5de032fcb0b7bca50f6a9f8e133fd882821930" @@ -2944,16 +2351,6 @@ redux-thunk "^2.4.2" reselect "^4.1.8" -"@reduxjs/toolkit@1.9.6": - version "1.9.6" - resolved "https://registry.npmjs.org/@reduxjs/toolkit/-/toolkit-1.9.6.tgz" - integrity sha512-Gc4ikl90ORF4viIdAkY06JNUnODjKfGxZRwATM30EdHq8hLSVoSrwXne5dd739yenP5bJxAX7tLuOWK5RPGtrw== - dependencies: - immer "^9.0.21" - redux "^4.2.1" - redux-thunk "^2.4.2" - reselect "^4.1.8" - "@sentry-internal/feedback@7.102.0": version "7.102.0" resolved "https://registry.yarnpkg.com/@sentry-internal/feedback/-/feedback-7.102.0.tgz#c3c7f5cfe9726b6d4d1917bd5bd01238154f8ee7" @@ -3030,6 +2427,11 @@ resolved "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz" integrity sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA== +"@sindresorhus/merge-streams@^2.1.0": + version "2.3.0" + resolved "https://registry.yarnpkg.com/@sindresorhus/merge-streams/-/merge-streams-2.3.0.tgz#719df7fb41766bc143369eaa0dd56d8dc87c9958" + integrity sha512-LtoMMhxAlorcGhmFYI+LhPgbPZCkgP6ra1YL604EeF6U98pLlQ3iWIGMdWSC+vWmPBWBNgmDBAhnAobLROJmwg== + "@sinonjs/commons@^3.0.0": version "3.0.0" resolved "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.0.tgz" @@ -3046,7 +2448,7 @@ "@swc/core-darwin-arm64@1.3.75": version "1.3.75" - resolved "https://registry.npmjs.org/@swc/core-darwin-arm64/-/core-darwin-arm64-1.3.75.tgz" + resolved "https://registry.yarnpkg.com/@swc/core-darwin-arm64/-/core-darwin-arm64-1.3.75.tgz#f6b2fb9dd03839ff3153902e09f1772963a1bbb6" integrity sha512-anDnx9L465lGbjB2mvcV54NGHW6illr0IDvVV7JmkabYUVneaRdQvTr0tbHv3xjHnjrK1wuwVOHKV0LcQF2tnQ== "@swc/core-darwin-x64@1.3.75": @@ -3096,7 +2498,7 @@ "@swc/core@1.3.75": version "1.3.75" - resolved "https://registry.npmjs.org/@swc/core/-/core-1.3.75.tgz" + resolved "https://registry.yarnpkg.com/@swc/core/-/core-1.3.75.tgz#b06d32144a5be0b7b25dbbff09dcd1ab18e48b67" integrity sha512-YLqd5oZVnaOq/OzkjRSsJUQqAfKYiD0fzUyVUPVlNNCoQEfVfSMcXH80hLmYe9aDH0T/a7qEMjWyIr/0kWqy1A== optionalDependencies: "@swc/core-darwin-arm64" "1.3.75" @@ -3110,7 +2512,14 @@ "@swc/core-win32-ia32-msvc" "1.3.75" "@swc/core-win32-x64-msvc" "1.3.75" -"@swc/helpers@0.5.0", "@swc/helpers@^0.5.0": +"@swc/helpers@0.5.6": + version "0.5.6" + resolved "https://registry.yarnpkg.com/@swc/helpers/-/helpers-0.5.6.tgz#d16d8566b7aea2bef90d059757e2d77f48224160" + integrity sha512-aYX01Ke9hunpoCexYAgQucEpARGQ5w/cqHFrIR+e9gdKb1QWTsVJuTJ2ozQzIAxLyRQe/m+2RqzkyOOGiMKRQA== + dependencies: + tslib "^2.4.0" + +"@swc/helpers@^0.5.0": version "0.5.0" resolved "https://registry.npmjs.org/@swc/helpers/-/helpers-0.5.0.tgz" integrity sha512-SjY/p4MmECVVEWspzSRpQEM3sjR17sP8PbGxELWrT+YZMBfiUyt1MRUNjMV23zohwlG2HYtCQOsCwsTHguXkyg== @@ -3125,10 +2534,10 @@ "@jest/create-cache-key-function" "^27.4.2" jsonc-parser "^3.2.0" -"@testing-library/dom@9.3.1", "@testing-library/dom@>=7": - version "9.3.1" - resolved "https://registry.npmjs.org/@testing-library/dom/-/dom-9.3.1.tgz" - integrity sha512-0DGPd9AR3+iDTjGoMpxIkAsUihHZ3Ai6CneU6bRRrffXMgzCdlNk43jTrD2/5LT6CBb3MWTP8v510JzYtahD2w== +"@testing-library/dom@9.3.4": + version "9.3.4" + resolved "https://registry.yarnpkg.com/@testing-library/dom/-/dom-9.3.4.tgz#50696ec28376926fec0a1bf87d9dbac5e27f60ce" + integrity sha512-FlS4ZWlp97iiNWig0Muq8p+3rVDjRiYE+YKGbAqXOu9nwJFFOdL00kFpz42M+4huzYi86vAK1sOOfyOG45muIQ== dependencies: "@babel/code-frame" "^7.10.4" "@babel/runtime" "^7.12.5" @@ -3153,34 +2562,33 @@ lz-string "^1.5.0" pretty-format "^27.0.2" -"@testing-library/jest-dom@5.16.5": - version "5.16.5" - resolved "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-5.16.5.tgz" - integrity sha512-N5ixQ2qKpi5OLYfwQmUb/5mSV9LneAcaUfp32pn4yCnpb8r/Yz0pXFPck21dIicKmi+ta5WRAknkZCfA8refMA== +"@testing-library/jest-dom@6.4.2": + version "6.4.2" + resolved "https://registry.yarnpkg.com/@testing-library/jest-dom/-/jest-dom-6.4.2.tgz#38949f6b63722900e2d75ba3c6d9bf8cffb3300e" + integrity sha512-CzqH0AFymEMG48CpzXFriYYkOjk6ZGPCLMhW9e9jg3KMCn5OfJecF8GtGW7yGfR/IgCe3SX8BSwjdzI6BBbZLw== dependencies: - "@adobe/css-tools" "^4.0.1" + "@adobe/css-tools" "^4.3.2" "@babel/runtime" "^7.9.2" - "@types/testing-library__jest-dom" "^5.9.1" aria-query "^5.0.0" chalk "^3.0.0" css.escape "^1.5.1" - dom-accessibility-api "^0.5.6" + dom-accessibility-api "^0.6.3" lodash "^4.17.15" redent "^3.0.0" -"@testing-library/react@14.0.0": - version "14.0.0" - resolved "https://registry.npmjs.org/@testing-library/react/-/react-14.0.0.tgz" - integrity sha512-S04gSNJbYE30TlIMLTzv6QCTzt9AqIF5y6s6SzVFILNcNvbV/jU96GeiTPillGQo+Ny64M/5PV7klNYYgv5Dfg== +"@testing-library/react@14.2.1": + version "14.2.1" + resolved "https://registry.yarnpkg.com/@testing-library/react/-/react-14.2.1.tgz#bf69aa3f71c36133349976a4a2da3687561d8310" + integrity sha512-sGdjws32ai5TLerhvzThYFbpnF9XtL65Cjf+gB0Dhr29BGqK+mAeN7SURSdu+eqgET4ANcWoC7FQpkaiGvBr+A== dependencies: "@babel/runtime" "^7.12.5" "@testing-library/dom" "^9.0.0" "@types/react-dom" "^18.0.0" -"@testing-library/user-event@14.4.3": - version "14.4.3" - resolved "https://registry.npmjs.org/@testing-library/user-event/-/user-event-14.4.3.tgz" - integrity sha512-kCUc5MEwaEMakkO5x7aoD+DLi02ehmEM2QCGWvNqAS1dV/fAvORWEjnjsEIvml59M7Y5kCkWN6fCCyPOe8OL6Q== +"@testing-library/user-event@14.5.2": + version "14.5.2" + resolved "https://registry.yarnpkg.com/@testing-library/user-event/-/user-event-14.5.2.tgz#db7257d727c891905947bd1c1a99da20e03c2ebd" + integrity sha512-YAh82Wh4TIrxYLmfGcixwD18oIjyC1pFQC2Y01F2lzV2HTMiYrI0nze0FD0ocB//CKS/7jIUgae+adPqxK5yCQ== "@tootallnate/once@2": version "2.0.0" @@ -3419,10 +2827,10 @@ "@types/d3-interpolate" "*" "@types/d3-selection" "*" -"@types/d3@7.4.0": - version "7.4.0" - resolved "https://registry.npmjs.org/@types/d3/-/d3-7.4.0.tgz" - integrity sha512-jIfNVK0ZlxcuRDKtRS/SypEyOQ6UHaFQBKv032X45VvxSJ6Yi5G9behy9h6tNTHTDGh5Vq+KbmBjUWLgY4meCA== +"@types/d3@7.4.3": + version "7.4.3" + resolved "https://registry.yarnpkg.com/@types/d3/-/d3-7.4.3.tgz#d4550a85d08f4978faf0a4c36b848c61eaac07e2" + integrity sha512-lZXZ9ckh5R8uiFVt8ogUNf+pIrK4EsWrx2Np75WvF/eTpJ0FMHNhjXk8CKEx/+gpHbNQyJWehbFaTvqmHWB3ww== dependencies: "@types/d3-array" "*" "@types/d3-axis" "*" @@ -3455,10 +2863,10 @@ "@types/d3-transition" "*" "@types/d3-zoom" "*" -"@types/debounce-promise@3.1.7": - version "3.1.7" - resolved "https://registry.npmjs.org/@types/debounce-promise/-/debounce-promise-3.1.7.tgz" - integrity sha512-XzqG8zCd9n33gmusdQo0d4p9iRKg/mZbG52wfHxnuZZyeO68ryOT5xyv9Fk3vLAvQBUsHmSL14Cqpsx4jjzz1Q== +"@types/debounce-promise@3.1.9": + version "3.1.9" + resolved "https://registry.yarnpkg.com/@types/debounce-promise/-/debounce-promise-3.1.9.tgz#b59346fe5c24636ebe0fb88f2f7e41b888b1cd7c" + integrity sha512-awNxydYSU+E2vL7EiOAMtiSOfL5gUM5X4YSE2A92qpxDJQ/rXz6oMPYBFDcDywlUmvIDI6zsqgq17cGm5CITQw== "@types/eslint-scope@^3.7.3": version "3.7.6" @@ -3476,19 +2884,24 @@ "@types/estree" "*" "@types/json-schema" "*" -"@types/eslint@8.44.0": - version "8.44.0" - resolved "https://registry.npmjs.org/@types/eslint/-/eslint-8.44.0.tgz" - integrity sha512-gsF+c/0XOguWgaOgvFs+xnnRqt9GwgTvIks36WpE6ueeI4KCEHHd8K/CKHqhOqrJKsYH8m27kRzQEvWXAwXUTw== +"@types/eslint@8.56.2": + version "8.56.2" + resolved "https://registry.yarnpkg.com/@types/eslint/-/eslint-8.56.2.tgz#1c72a9b794aa26a8b94ad26d5b9aa51c8a6384bb" + integrity sha512-uQDwm1wFHmbBbCZCqAlq6Do9LYwByNZHWzXppSnay9SuwJ+VRbjkbLABer54kcPnMSlG6Fdiy2yaFXm/z9Z5gw== dependencies: "@types/estree" "*" "@types/json-schema" "*" -"@types/estree@*", "@types/estree@^1.0.0": +"@types/estree@*": version "1.0.3" resolved "https://registry.npmjs.org/@types/estree/-/estree-1.0.3.tgz" integrity sha512-CS2rOaoQ/eAgAfcTfq6amKG7bsN+EMcgGY4FAFQdvSj2y1ixvOZTUA9mOtCai7E1SYu283XNw7urKK30nP3wkQ== +"@types/estree@^1.0.5": + version "1.0.5" + resolved "https://registry.yarnpkg.com/@types/estree/-/estree-1.0.5.tgz#a6ce3e556e00fd9895dd872dd172ad0d4bd687f4" + integrity sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw== + "@types/geojson@*": version "7946.0.12" resolved "https://registry.npmjs.org/@types/geojson/-/geojson-7946.0.12.tgz" @@ -3536,10 +2949,10 @@ expect "^29.0.0" pretty-format "^29.0.0" -"@types/jest@29.5.5": - version "29.5.5" - resolved "https://registry.npmjs.org/@types/jest/-/jest-29.5.5.tgz" - integrity sha512-ebylz2hnsWR9mYvmBFbXJXr+33UPc4+ZdxyDXh5w0FlPBTfCVN3wPL+kuOiQt3xvrK419v7XWeAs+AeOksafXg== +"@types/jest@29.5.12": + version "29.5.12" + resolved "https://registry.yarnpkg.com/@types/jest/-/jest-29.5.12.tgz#7f7dc6eb4cf246d2474ed78744b05d06ce025544" + integrity sha512-eDC8bTvT/QhYdxJAulQikueigY5AsdBRH2yDKW3yveW7svY3+DzN84/2NUgkw10RTiJbWqZrTtoGVdYlvFJdLw== dependencies: expect "^29.0.0" pretty-format "^29.0.0" @@ -3563,6 +2976,11 @@ resolved "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.14.tgz" integrity sha512-U3PUjAudAdJBeC2pgN8uTIKgxrb4nlDF3SF0++EldXQvQBGkpFZMSnwQiIoDU77tv45VgNkl/L4ouD+rEomujw== +"@types/json-schema@^7.0.12": + version "7.0.15" + resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.15.tgz#596a1747233694d50f6ad8a7869fcb6f56cf5841" + integrity sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA== + "@types/json5@^0.0.29": version "0.0.29" resolved "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz" @@ -3575,16 +2993,28 @@ dependencies: "@types/lodash" "*" -"@types/lodash@*", "@types/lodash@4.14.199": +"@types/lodash@*": version "4.14.199" resolved "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.199.tgz" integrity sha512-Vrjz5N5Ia4SEzWWgIVwnHNEnb1UE1XMkvY5DGXrAeOGE9imk0hgTHh5GyDjLDJi9OTCn9oo9dXH1uToK1VRfrg== -"@types/node@*", "@types/node@20.8.2": +"@types/lodash@4.14.202": + version "4.14.202" + resolved "https://registry.yarnpkg.com/@types/lodash/-/lodash-4.14.202.tgz#f09dbd2fb082d507178b2f2a5c7e74bd72ff98f8" + integrity sha512-OvlIYQK9tNneDlS0VN54LLd5uiPCBOp7gS5Z0f1mjoJYBrtStzgmJBxONW3U6OZqdtNzZPmn9BS/7WI7BFFcFQ== + +"@types/node@*": version "20.8.2" resolved "https://registry.npmjs.org/@types/node/-/node-20.8.2.tgz" integrity sha512-Vvycsc9FQdwhxE3y3DzeIxuEJbWGDsnrxvMADzTDF/lcdR9/K+AQIeAghTQsHtotg/q0j3WEOYS/jQgSdWue3w== +"@types/node@20.11.19": + version "20.11.19" + resolved "https://registry.yarnpkg.com/@types/node/-/node-20.11.19.tgz#b466de054e9cb5b3831bee38938de64ac7f81195" + integrity sha512-7xMnVEcZFu0DikYjWOlRq7NTPETrm7teqUT2WkQjrTIkEgUyyGdWsj/Zg8bEJt5TNklzbPD1X3fqfsHw3SpapQ== + dependencies: + undici-types "~5.26.4" + "@types/node@^14.14.31": version "14.18.63" resolved "https://registry.npmjs.org/@types/node/-/node-14.18.63.tgz" @@ -3602,15 +3032,15 @@ resolved "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.1.tgz" integrity sha512-3YmXzzPAdOTVljVMkTMBdBEvlOLg2cDQaDhnnhT3nT9uDbnJzjWhKlzb+desT12Y7tGqaN6d+AbozcKzyL36Ng== -"@types/pluralize@0.0.30": - version "0.0.30" - resolved "https://registry.npmjs.org/@types/pluralize/-/pluralize-0.0.30.tgz" - integrity sha512-kVww6xZrW/db5BR9OqiT71J9huRdQ+z/r+LbDuT7/EK50mCmj5FoaIARnVv0rvjUS/YpDox0cDU9lpQT011VBA== +"@types/pluralize@^0.0.33": + version "0.0.33" + resolved "https://registry.yarnpkg.com/@types/pluralize/-/pluralize-0.0.33.tgz#8ad9018368c584d268667dd9acd5b3b806e8c82a" + integrity sha512-JOqsl+ZoCpP4e8TDke9W79FDcSgPAR0l6pixx2JHkhnRjvShyYiAYw2LVsnA7K08Y6DeOnaU6ujmENO4os/cYg== -"@types/prismjs@1.26.0": - version "1.26.0" - resolved "https://registry.npmjs.org/@types/prismjs/-/prismjs-1.26.0.tgz" - integrity sha512-ZTaqn/qSqUuAq1YwvOFQfVW1AR/oQJlLSZVustdjwI+GZ8kr0MSHBj0tsXPW1EqHubx50gtBEjbPGsdZwQwCjQ== +"@types/prismjs@1.26.3": + version "1.26.3" + resolved "https://registry.yarnpkg.com/@types/prismjs/-/prismjs-1.26.3.tgz#47fe8e784c2dee24fe636cab82e090d3da9b7dec" + integrity sha512-A0D0aTXvjlqJ5ZILMz3rNfDBOx9hHxLZYv2by47Sm/pqW35zzjusrZTryatjN/Rf8Us2gZrJD+KeHbUSTux1Cw== "@types/prop-types@*": version "15.7.9" @@ -3622,24 +3052,31 @@ resolved "https://registry.npmjs.org/@types/raf/-/raf-3.4.2.tgz" integrity sha512-sM4HyDVlDFl4goOXPF+g9nNHJFZQGot+HgySjM4cRjqXzjdatcEvYrtG4Ia8XumR9T6k8G2tW9B7hnUj51Uf0A== -"@types/react-beautiful-dnd@13.1.6": - version "13.1.6" - resolved "https://registry.npmjs.org/@types/react-beautiful-dnd/-/react-beautiful-dnd-13.1.6.tgz" - integrity sha512-FXAuaa52ux7HWQDumi3MFSAAsW8OKfDImy1pSZPKe85nV9mZ1f4spVzW0a2boYvkIhphjbWUi5EwUiRG8Rq/Qg== +"@types/react-beautiful-dnd@13.1.8": + version "13.1.8" + resolved "https://registry.yarnpkg.com/@types/react-beautiful-dnd/-/react-beautiful-dnd-13.1.8.tgz#f52d3ea07e1e19159d6c3c4a48c8da3d855e60b4" + integrity sha512-E3TyFsro9pQuK4r8S/OL6G99eq7p8v29sX0PM7oT8Z+PJfZvSQTx4zTQbUJ+QZXioAF0e7TGBEcA1XhYhCweyQ== + dependencies: + "@types/react" "*" + +"@types/react-dom@18.2.19": + version "18.2.19" + resolved "https://registry.yarnpkg.com/@types/react-dom/-/react-dom-18.2.19.tgz#b84b7c30c635a6c26c6a6dfbb599b2da9788be58" + integrity sha512-aZvQL6uUbIJpjZk4U8JZGbau9KDeAwMfmhyWorxgBkqDIEf6ROjRozcmPIicqsUwPUjbkDfHKgGee1Lq65APcA== dependencies: "@types/react" "*" -"@types/react-dom@18.2.14", "@types/react-dom@^18.0.0": +"@types/react-dom@^18.0.0": version "18.2.14" resolved "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.14.tgz" integrity sha512-V835xgdSVmyQmI1KLV2BEIUgqEuinxp9O4G6g3FqO/SqLac049E53aysv0oEFD2kHfejeKU+ZqL2bcFWj9gLAQ== dependencies: "@types/react" "*" -"@types/react-highlight-words@0.16.5": - version "0.16.5" - resolved "https://registry.npmjs.org/@types/react-highlight-words/-/react-highlight-words-0.16.5.tgz" - integrity sha512-5vUJpVzB3G15nwXB8OEfWgAhEnwAlDXkm8SH6qF8i5jCSTEG2JOygKMJIsvetgYBJS6Sq1I8x3YQcAUDMjKxzg== +"@types/react-highlight-words@0.16.7": + version "0.16.7" + resolved "https://registry.yarnpkg.com/@types/react-highlight-words/-/react-highlight-words-0.16.7.tgz#82fdd2d2abe4c4a5c0da44be749660f6ec42f0c2" + integrity sha512-+upXTIaRd3rGvh1aDQSs9z5X+sV3UM6Jrmjk03GN2GXl4v/+iOJKQj2LZHo6Vp2IoTvMdtxgME26feqo12xXLg== dependencies: "@types/react" "*" @@ -3670,14 +3107,14 @@ dependencies: "@types/react" "*" -"@types/react-window@1.8.7": - version "1.8.7" - resolved "https://registry.npmjs.org/@types/react-window/-/react-window-1.8.7.tgz" - integrity sha512-FpPHEhmGVOBKomuR4LD2nvua1Ajcw6PfnfbDysuCwwPae3JNulcq3+uZIpQNbDN2AI1z+Y4tKj2xQ4ELiQ4QDw== +"@types/react-window@1.8.8": + version "1.8.8" + resolved "https://registry.yarnpkg.com/@types/react-window/-/react-window-1.8.8.tgz#c20645414d142364fbe735818e1c1e0a145696e3" + integrity sha512-8Ls660bHR1AUA2kuRvVG9D/4XpRC6wjAaPT9dil7Ckc76eP9TKWZwwmgfq8Q1LANX3QNDnoU4Zp48A3w+zK69Q== dependencies: "@types/react" "*" -"@types/react@*", "@types/react@18.2.29": +"@types/react@*": version "18.2.29" resolved "https://registry.npmjs.org/@types/react/-/react-18.2.29.tgz" integrity sha512-Z+ZrIRocWtdD70j45izShRwDuiB4JZqDegqMFW/I8aG5DxxLKOzVNoq62UIO82v9bdgi+DO1jvsb9sTEZUSm+Q== @@ -3686,15 +3123,24 @@ "@types/scheduler" "*" csstype "^3.0.2" +"@types/react@18.2.55": + version "18.2.55" + resolved "https://registry.yarnpkg.com/@types/react/-/react-18.2.55.tgz#38141821b7084404b5013742bc4ae08e44da7a67" + integrity sha512-Y2Tz5P4yz23brwm2d7jNon39qoAtMMmalOQv6+fEFt1mT+FcM3D841wDpoUvFXhaYenuROCy3FZYqdTjM7qVyA== + dependencies: + "@types/prop-types" "*" + "@types/scheduler" "*" + csstype "^3.0.2" + "@types/scheduler@*": version "0.16.5" resolved "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.5.tgz" integrity sha512-s/FPdYRmZR8SjLWGMCuax7r3qCWQw9QKHzXVukAuuIJkXkDRwp+Pu5LMIVFi0Fxbav35WURicYr8u1QsoybnQw== -"@types/semver@7.5.0": - version "7.5.0" - resolved "https://registry.npmjs.org/@types/semver/-/semver-7.5.0.tgz" - integrity sha512-G8hZ6XJiHnuhQKR7ZmysCeJWE08o8T0AXtk5darsCaTVsYZhhgUrq53jizaR2FvsoeCwJhlmwTjkXBY5Pn/ZHw== +"@types/semver@7.5.7", "@types/semver@^7.5.0": + version "7.5.7" + resolved "https://registry.yarnpkg.com/@types/semver/-/semver-7.5.7.tgz#326f5fdda70d13580777bcaa1bc6fa772a5aef0e" + integrity sha512-/wdoPq1QqkSj9/QOeKkFquEuPzQbHTWAMPH/PaUMB+JuR31lXhlWXRZ52IpfDYVlDOUBvX09uBrPwxGT1hjNBg== "@types/semver@^7.3.12": version "7.5.4" @@ -3748,26 +3194,14 @@ resolved "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.2.tgz" integrity sha512-g7CK9nHdwjK2n0ymT2CW698FuWJRIx+RP6embAzZ2Qi8/ilIrA1Imt2LVSeHUzKvpoi7BhmmQcXz95eS0f2JXw== -"@types/string-hash@1.1.1": - version "1.1.1" - resolved "https://registry.npmjs.org/@types/string-hash/-/string-hash-1.1.1.tgz" - integrity sha512-ijt3zdHi2DmZxQpQTmozXszzDo78V4R3EdvX0jFMfnMH2ZzQSmCbaWOMPGXFUYSzSIdStv78HDjg32m5dxc+tA== - "@types/string-hash@1.1.3": version "1.1.3" resolved "https://registry.yarnpkg.com/@types/string-hash/-/string-hash-1.1.3.tgz#8d9a73cf25574d45daf11e3ae2bf6b50e69aa212" integrity sha512-p6skq756fJWiA59g2Uss+cMl6tpoDGuCBuxG0SI1t0NwJmYOU66LAMS6QiCgu7cUh3/hYCaMl5phcCW1JP5wOA== -"@types/testing-library__jest-dom@5.14.8": - version "5.14.8" - resolved "https://registry.npmjs.org/@types/testing-library__jest-dom/-/testing-library__jest-dom-5.14.8.tgz" - integrity sha512-NRfJE9Cgpmu4fx716q9SYmU4jxxhYRU1BQo239Txt/9N3EC745XZX1Yl7h/SBIDlo1ANVOCRB4YDXjaQdoKCHQ== - dependencies: - "@types/jest" "*" - -"@types/testing-library__jest-dom@^5.9.1": +"@types/testing-library__jest-dom@5.14.9": version "5.14.9" - resolved "https://registry.npmjs.org/@types/testing-library__jest-dom/-/testing-library__jest-dom-5.14.9.tgz" + resolved "https://registry.yarnpkg.com/@types/testing-library__jest-dom/-/testing-library__jest-dom-5.14.9.tgz#0fb1e6a0278d87b6737db55af5967570b67cb466" integrity sha512-FSYhIjFlfOpGSRyVoMBMuS3ws5ehFQODymf3vlI7U1K8c7PHwWwFY7VREfmsuzHSOnoKs/9/Y983ayOs7eRzqw== dependencies: "@types/jest" "*" @@ -3777,10 +3211,10 @@ resolved "https://registry.npmjs.org/@types/tough-cookie/-/tough-cookie-4.0.4.tgz" integrity sha512-95Sfz4nvMAb0Nl9DTxN3j64adfwfbBPEYq14VN7zT5J5O2M9V6iZMIIQU1U+pJyl9agHYHNCqhCXgyEtIRRa5A== -"@types/uuid@9.0.2": - version "9.0.2" - resolved "https://registry.npmjs.org/@types/uuid/-/uuid-9.0.2.tgz" - integrity sha512-kNnC1GFBLuhImSnV7w4njQkUiJi0ZXUycu1rUaouPqiKlXkh77JKgdRnTAp1x5eBwcIwbtI+3otwzuIDEuDoxQ== +"@types/uuid@9.0.8": + version "9.0.8" + resolved "https://registry.yarnpkg.com/@types/uuid/-/uuid-9.0.8.tgz#7545ba4fc3c003d6c756f651f3bf163d8f0f29ba" + integrity sha512-jg+97EGIcY9AGHJJRaaPVgetKDsrTgbRjQ5Msgjh/DQKEFl0DtyRr/VCOyD1T2R1MNeWPK/u7JoGhlDZnKBAfA== "@types/uuid@^8.3.3": version "8.3.4" @@ -3813,21 +3247,6 @@ dependencies: "@types/node" "*" -"@typescript-eslint/eslint-plugin@5.42.0": - version "5.42.0" - resolved "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.42.0.tgz" - integrity sha512-5TJh2AgL6+wpL8H/GTSjNb4WrjKoR2rqvFxR/DDTqYNk6uXn8BJMEcncLSpMbf/XV1aS0jAjYwn98uvVCiAywQ== - dependencies: - "@typescript-eslint/scope-manager" "5.42.0" - "@typescript-eslint/type-utils" "5.42.0" - "@typescript-eslint/utils" "5.42.0" - debug "^4.3.4" - ignore "^5.2.0" - natural-compare-lite "^1.4.0" - regexpp "^3.2.0" - semver "^7.3.7" - tsutils "^3.21.0" - "@typescript-eslint/eslint-plugin@5.59.9": version "5.59.9" resolved "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.59.9.tgz" @@ -3844,15 +3263,22 @@ semver "^7.3.7" tsutils "^3.21.0" -"@typescript-eslint/parser@5.42.0": - version "5.42.0" - resolved "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.42.0.tgz" - integrity sha512-Ixh9qrOTDRctFg3yIwrLkgf33AHyEIn6lhyf5cCfwwiGtkWhNpVKlEZApi3inGQR/barWnY7qY8FbGKBO7p3JA== +"@typescript-eslint/eslint-plugin@6.21.0": + version "6.21.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.21.0.tgz#30830c1ca81fd5f3c2714e524c4303e0194f9cd3" + integrity sha512-oy9+hTPCUFpngkEZUSzbf9MxI65wbKFoQYsgPdILTfbUldp5ovUuphZVe4i30emU9M/kP+T64Di0mxl7dSw3MA== dependencies: - "@typescript-eslint/scope-manager" "5.42.0" - "@typescript-eslint/types" "5.42.0" - "@typescript-eslint/typescript-estree" "5.42.0" + "@eslint-community/regexpp" "^4.5.1" + "@typescript-eslint/scope-manager" "6.21.0" + "@typescript-eslint/type-utils" "6.21.0" + "@typescript-eslint/utils" "6.21.0" + "@typescript-eslint/visitor-keys" "6.21.0" debug "^4.3.4" + graphemer "^1.4.0" + ignore "^5.2.4" + natural-compare "^1.4.0" + semver "^7.5.4" + ts-api-utils "^1.0.1" "@typescript-eslint/parser@5.59.9": version "5.59.9" @@ -3864,13 +3290,16 @@ "@typescript-eslint/typescript-estree" "5.59.9" debug "^4.3.4" -"@typescript-eslint/scope-manager@5.42.0": - version "5.42.0" - resolved "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.42.0.tgz" - integrity sha512-l5/3IBHLH0Bv04y+H+zlcLiEMEMjWGaCX6WyHE5Uk2YkSGAMlgdUPsT/ywTSKgu9D1dmmKMYgYZijObfA39Wow== +"@typescript-eslint/parser@6.21.0": + version "6.21.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-6.21.0.tgz#af8fcf66feee2edc86bc5d1cf45e33b0630bf35b" + integrity sha512-tbsV1jPne5CkFQCgPBcDOt30ItF7aJoZL997JSF7MhGQqOeT3svWRYxiqlfA5RUdlHN6Fi+EI9bxqbdyAUZjYQ== dependencies: - "@typescript-eslint/types" "5.42.0" - "@typescript-eslint/visitor-keys" "5.42.0" + "@typescript-eslint/scope-manager" "6.21.0" + "@typescript-eslint/types" "6.21.0" + "@typescript-eslint/typescript-estree" "6.21.0" + "@typescript-eslint/visitor-keys" "6.21.0" + debug "^4.3.4" "@typescript-eslint/scope-manager@5.59.9": version "5.59.9" @@ -3888,15 +3317,13 @@ "@typescript-eslint/types" "5.62.0" "@typescript-eslint/visitor-keys" "5.62.0" -"@typescript-eslint/type-utils@5.42.0": - version "5.42.0" - resolved "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.42.0.tgz" - integrity sha512-HW14TXC45dFVZxnVW8rnUGnvYyRC0E/vxXShFCthcC9VhVTmjqOmtqj6H5rm9Zxv+ORxKA/1aLGD7vmlLsdlOg== +"@typescript-eslint/scope-manager@6.21.0": + version "6.21.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-6.21.0.tgz#ea8a9bfc8f1504a6ac5d59a6df308d3a0630a2b1" + integrity sha512-OwLUIWZJry80O99zvqXVEioyniJMa+d2GrqpUTqi5/v5D5rOrppJVBPa0yKCblcigC0/aYAzxxqQ1B+DS2RYsg== dependencies: - "@typescript-eslint/typescript-estree" "5.42.0" - "@typescript-eslint/utils" "5.42.0" - debug "^4.3.4" - tsutils "^3.21.0" + "@typescript-eslint/types" "6.21.0" + "@typescript-eslint/visitor-keys" "6.21.0" "@typescript-eslint/type-utils@5.59.9": version "5.59.9" @@ -3908,10 +3335,15 @@ debug "^4.3.4" tsutils "^3.21.0" -"@typescript-eslint/types@5.42.0": - version "5.42.0" - resolved "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.42.0.tgz" - integrity sha512-t4lzO9ZOAUcHY6bXQYRuu+3SSYdD9TS8ooApZft4WARt4/f2Cj/YpvbTe8A4GuhT4bNW72goDMOy7SW71mZwGw== +"@typescript-eslint/type-utils@6.21.0": + version "6.21.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-6.21.0.tgz#6473281cfed4dacabe8004e8521cee0bd9d4c01e" + integrity sha512-rZQI7wHfao8qMX3Rd3xqeYSMCL3SoiSQLBATSiVKARdFGCYSRvmViieZjqc58jKgs8Y8i9YvVVhRbHSTA4VBag== + dependencies: + "@typescript-eslint/typescript-estree" "6.21.0" + "@typescript-eslint/utils" "6.21.0" + debug "^4.3.4" + ts-api-utils "^1.0.1" "@typescript-eslint/types@5.59.9": version "5.59.9" @@ -3923,18 +3355,10 @@ resolved "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.62.0.tgz" integrity sha512-87NVngcbVXUahrRTqIK27gD2t5Cu1yuCXxbLcFtCzZGlfyVWWh8mLHkoxzjsB6DDNnvdL+fW8MiwPEJyGJQDgQ== -"@typescript-eslint/typescript-estree@5.42.0": - version "5.42.0" - resolved "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.42.0.tgz" - integrity sha512-2O3vSq794x3kZGtV7i4SCWZWCwjEtkWfVqX4m5fbUBomOsEOyd6OAD1qU2lbvV5S8tgy/luJnOYluNyYVeOTTg== - dependencies: - "@typescript-eslint/types" "5.42.0" - "@typescript-eslint/visitor-keys" "5.42.0" - debug "^4.3.4" - globby "^11.1.0" - is-glob "^4.0.3" - semver "^7.3.7" - tsutils "^3.21.0" +"@typescript-eslint/types@6.21.0": + version "6.21.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-6.21.0.tgz#205724c5123a8fef7ecd195075fa6e85bac3436d" + integrity sha512-1kFmZ1rOm5epu9NZEZm1kckCDGj5UJEf7P1kliH4LKu/RkwpsfqqGmY2OOcUs18lSlQBKLDYBOGxRVtrMN5lpg== "@typescript-eslint/typescript-estree@5.59.9": version "5.59.9" @@ -3962,19 +3386,19 @@ semver "^7.3.7" tsutils "^3.21.0" -"@typescript-eslint/utils@5.42.0": - version "5.42.0" - resolved "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.42.0.tgz" - integrity sha512-JZ++3+h1vbeG1NUECXQZE3hg0kias9kOtcQr3+JVQ3whnjvKuMyktJAAIj6743OeNPnGBmjj7KEmiDL7qsdnCQ== +"@typescript-eslint/typescript-estree@6.21.0": + version "6.21.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-6.21.0.tgz#c47ae7901db3b8bddc3ecd73daff2d0895688c46" + integrity sha512-6npJTkZcO+y2/kr+z0hc4HwNfrrP4kNYh57ek7yCNlrBjWQ1Y0OS7jiZTkgumrvkX5HkEKXFZkkdFNkaW2wmUQ== dependencies: - "@types/json-schema" "^7.0.9" - "@types/semver" "^7.3.12" - "@typescript-eslint/scope-manager" "5.42.0" - "@typescript-eslint/types" "5.42.0" - "@typescript-eslint/typescript-estree" "5.42.0" - eslint-scope "^5.1.1" - eslint-utils "^3.0.0" - semver "^7.3.7" + "@typescript-eslint/types" "6.21.0" + "@typescript-eslint/visitor-keys" "6.21.0" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + minimatch "9.0.3" + semver "^7.5.4" + ts-api-utils "^1.0.1" "@typescript-eslint/utils@5.59.9": version "5.59.9" @@ -3990,6 +3414,19 @@ eslint-scope "^5.1.1" semver "^7.3.7" +"@typescript-eslint/utils@6.21.0": + version "6.21.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-6.21.0.tgz#4714e7a6b39e773c1c8e97ec587f520840cd8134" + integrity sha512-NfWVaC8HP9T8cbKQxHcsJBY5YE1O33+jpMwN45qzWWaPDZgLIbo12toGMWnmhvCpd3sIxkpDw3Wv1B3dYrbDQQ== + dependencies: + "@eslint-community/eslint-utils" "^4.4.0" + "@types/json-schema" "^7.0.12" + "@types/semver" "^7.5.0" + "@typescript-eslint/scope-manager" "6.21.0" + "@typescript-eslint/types" "6.21.0" + "@typescript-eslint/typescript-estree" "6.21.0" + semver "^7.5.4" + "@typescript-eslint/utils@^5.10.0": version "5.62.0" resolved "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.62.0.tgz" @@ -4004,14 +3441,6 @@ eslint-scope "^5.1.1" semver "^7.3.7" -"@typescript-eslint/visitor-keys@5.42.0": - version "5.42.0" - resolved "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.42.0.tgz" - integrity sha512-QHbu5Hf/2lOEOwy+IUw0GoSCuAzByTAWWrOTKzTzsotiUnWFpuKnXcAhC9YztAf2EElQ0VvIK+pHJUPkM0q7jg== - dependencies: - "@typescript-eslint/types" "5.42.0" - eslint-visitor-keys "^3.3.0" - "@typescript-eslint/visitor-keys@5.59.9": version "5.59.9" resolved "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.59.9.tgz" @@ -4028,6 +3457,19 @@ "@typescript-eslint/types" "5.62.0" eslint-visitor-keys "^3.3.0" +"@typescript-eslint/visitor-keys@6.21.0": + version "6.21.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-6.21.0.tgz#87a99d077aa507e20e238b11d56cc26ade45fe47" + integrity sha512-JJtkDduxLi9bivAB+cYOVMtbkqdPOhZ+ZI5LC47MIRrDV4Yn2o+ZnW10Nkmr28xRpSpdJ6Sm42Hjf2+REYXm0A== + dependencies: + "@typescript-eslint/types" "6.21.0" + eslint-visitor-keys "^3.4.1" + +"@ungap/structured-clone@^1.2.0": + version "1.2.0" + resolved "https://registry.yarnpkg.com/@ungap/structured-clone/-/structured-clone-1.2.0.tgz#756641adb587851b5ccb3e095daf27ae581c8406" + integrity sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ== + "@webassemblyjs/ast@1.11.6", "@webassemblyjs/ast@^1.11.5": version "1.11.6" resolved "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.6.tgz" @@ -4381,7 +3823,7 @@ aria-query@5.1.3: dependencies: deep-equal "^2.0.5" -aria-query@^5.0.0, aria-query@^5.1.3: +aria-query@^5.0.0, aria-query@^5.3.0: version "5.3.0" resolved "https://registry.npmjs.org/aria-query/-/aria-query-5.3.0.tgz" integrity sha512-b0P0sZPKtyu8HkeRAfCq0IfURZK+SuwMjY1UXGBU27wpAiTwQAIlq56IbIO+ytk/JjS1fMR14ee5WBBfKi5J6A== @@ -4396,7 +3838,15 @@ array-buffer-byte-length@^1.0.0: call-bind "^1.0.2" is-array-buffer "^3.0.1" -array-includes@^3.1.4, array-includes@^3.1.6: +array-buffer-byte-length@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz#1e5583ec16763540a27ae52eed99ff899223568f" + integrity sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg== + dependencies: + call-bind "^1.0.5" + is-array-buffer "^3.0.4" + +array-includes@^3.1.6, array-includes@^3.1.7: version "3.1.7" resolved "https://registry.npmjs.org/array-includes/-/array-includes-3.1.7.tgz" integrity sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ== @@ -4417,7 +3867,29 @@ array-union@^2.1.0: resolved "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz" integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== -array.prototype.flat@^1.2.5, array.prototype.flat@^1.3.1: +array.prototype.filter@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/array.prototype.filter/-/array.prototype.filter-1.0.3.tgz#423771edeb417ff5914111fff4277ea0624c0d0e" + integrity sha512-VizNcj/RGJiUyQBgzwxzE5oHdeuXY5hSbbmKMlphj1cy1Vl7Pn2asCGbSrru6hSQjmCzqTBPVWAF/whmEOVHbw== + dependencies: + call-bind "^1.0.2" + define-properties "^1.2.0" + es-abstract "^1.22.1" + es-array-method-boxes-properly "^1.0.0" + is-string "^1.0.7" + +array.prototype.findlastindex@^1.2.3: + version "1.2.4" + resolved "https://registry.yarnpkg.com/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.4.tgz#d1c50f0b3a9da191981ff8942a0aedd82794404f" + integrity sha512-hzvSHUshSpCflDR1QMUBLHGHP1VIEBegT4pix9H/Z92Xw3ySoy6c2qh7lJWTJnRJ8JCZ9bJNCgTyYaJGcJu6xQ== + dependencies: + call-bind "^1.0.5" + define-properties "^1.2.1" + es-abstract "^1.22.3" + es-errors "^1.3.0" + es-shim-unscopables "^1.0.2" + +array.prototype.flat@^1.3.1, array.prototype.flat@^1.3.2: version "1.3.2" resolved "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz" integrity sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA== @@ -4427,7 +3899,7 @@ array.prototype.flat@^1.2.5, array.prototype.flat@^1.3.1: es-abstract "^1.22.1" es-shim-unscopables "^1.0.0" -array.prototype.flatmap@^1.3.1: +array.prototype.flatmap@^1.3.1, array.prototype.flatmap@^1.3.2: version "1.3.2" resolved "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz" integrity sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ== @@ -4461,6 +3933,20 @@ arraybuffer.prototype.slice@^1.0.2: is-array-buffer "^3.0.2" is-shared-array-buffer "^1.0.2" +arraybuffer.prototype.slice@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz#097972f4255e41bc3425e37dc3f6421cf9aefde6" + integrity sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A== + dependencies: + array-buffer-byte-length "^1.0.1" + call-bind "^1.0.5" + define-properties "^1.2.1" + es-abstract "^1.22.3" + es-errors "^1.2.1" + get-intrinsic "^1.2.3" + is-array-buffer "^3.0.4" + is-shared-array-buffer "^1.0.2" + asap@~1.0.0: version "1.0.0" resolved "https://registry.npmjs.org/asap/-/asap-1.0.0.tgz" @@ -4478,10 +3964,10 @@ assert-plus@1.0.0, assert-plus@^1.0.0: resolved "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz" integrity sha512-NfJ4UzBCcQGLDlQq7nHxH+tv3kyZ0hHQqF5BO6J7tNJeP5do1llPr8dZ8zHonfhAu0PHAdMkSo+8o0wxg9lZWw== -ast-types-flow@^0.0.7: - version "0.0.7" - resolved "https://registry.npmjs.org/ast-types-flow/-/ast-types-flow-0.0.7.tgz" - integrity sha512-eBvWn1lvIApYMhzQMsu9ciLfkBY499mFZlNqG+/9WR7PVlroQw0vG30cOQQbaKz3sCEc44TAOu2ykzqXSNnwag== +ast-types-flow@^0.0.8: + version "0.0.8" + resolved "https://registry.yarnpkg.com/ast-types-flow/-/ast-types-flow-0.0.8.tgz#0a85e1c92695769ac13a428bb653e7538bea27d6" + integrity sha512-OH/2E5Fg20h2aPrbe+QL8JZQFko0YZaF+j4mnQ7BGhfavO7OpSLa8a0y9sBwomHdSbkhTS8TQNayBfnW5DwbvQ== astral-regex@^2.0.0: version "2.0.0" @@ -4500,6 +3986,13 @@ async@^3.2.0: resolved "https://registry.npmjs.org/async/-/async-3.2.4.tgz" integrity sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ== +asynciterator.prototype@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/asynciterator.prototype/-/asynciterator.prototype-1.0.0.tgz#8c5df0514936cdd133604dfcc9d3fb93f09b2b62" + integrity sha512-wwHYEIS0Q80f5mosx3L/dfG5t5rjEa9Ft51GTaNt862EnpyGHpgz2RkZvLPp1oF5TnAiTohkEKVEu8pQPJI7Vg== + dependencies: + has-symbols "^1.0.3" + asynckit@^0.4.0: version "0.4.0" resolved "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz" @@ -4525,6 +4018,13 @@ available-typed-arrays@^1.0.5: resolved "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz" integrity sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw== +available-typed-arrays@^1.0.6: + version "1.0.7" + resolved "https://registry.yarnpkg.com/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz#a5cc375d6a03c2efc87a553f3e0b1522def14846" + integrity sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ== + dependencies: + possible-typed-array-names "^1.0.0" + aws-sign2@~0.7.0: version "0.7.0" resolved "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz" @@ -4535,14 +4035,14 @@ aws4@^1.8.0: resolved "https://registry.npmjs.org/aws4/-/aws4-1.12.0.tgz" integrity sha512-NmWvPnx0F1SfrQbYwOi7OeaNGokp9XhzNioJ/CSBs8Qa4vxug81mhJEAVZwxXuBmYB5KDRfMq/F3RR0BIU7sWg== -axe-core@^4.6.2: - version "4.8.2" - resolved "https://registry.npmjs.org/axe-core/-/axe-core-4.8.2.tgz" - integrity sha512-/dlp0fxyM3R8YW7MFzaHWXrf4zzbr0vaYb23VBFCl83R7nWNPg/yaQw2Dc8jzCMmDVLhSdzH8MjrsuIUuvX+6g== +axe-core@=4.7.0: + version "4.7.0" + resolved "https://registry.yarnpkg.com/axe-core/-/axe-core-4.7.0.tgz#34ba5a48a8b564f67e103f0aa5768d76e15bbbbf" + integrity sha512-M0JtH+hlOL5pLQwHOLNYZaXuhqmvS8oExsqB1SBYgA4Dk7u/xx+YdGHXaK5pyUfed5mYXdlYiphWq3G8cRi5JQ== -axobject-query@^3.1.1: +axobject-query@^3.2.1: version "3.2.1" - resolved "https://registry.npmjs.org/axobject-query/-/axobject-query-3.2.1.tgz" + resolved "https://registry.yarnpkg.com/axobject-query/-/axobject-query-3.2.1.tgz#39c378a6e3b06ca679f29138151e45b2b32da62a" integrity sha512-jsyHu61e6N4Vbz/v18DHwWYKK0bSWLqn47eeDSKPB7m8tqMHF9YJ+mhIk2lVteyZrY8tnSj/jHOv4YiTCuCJgg== dependencies: dequal "^2.0.3" @@ -4749,7 +4249,17 @@ browser-stdout@1.3.1: resolved "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz" integrity sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw== -browserslist@^4.14.5, browserslist@^4.21.9, browserslist@^4.22.1: +browserslist@^4.21.10: + version "4.23.0" + resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.23.0.tgz#8f3acc2bbe73af7213399430890f86c63a5674ab" + integrity sha512-QW8HiM1shhT2GuzkvklfjcKDiWFXHOeFCIA/huJPwHsslwcydgk7X+z2zXpEijP98UCY7HbubZt5J2Zgvf0CaQ== + dependencies: + caniuse-lite "^1.0.30001587" + electron-to-chromium "^1.4.668" + node-releases "^2.0.14" + update-browserslist-db "^1.0.13" + +browserslist@^4.21.9, browserslist@^4.22.1: version "4.22.1" resolved "https://registry.npmjs.org/browserslist/-/browserslist-4.22.1.tgz" integrity sha512-FEVc202+2iuClEhZhrWy6ZiAcRLvNMyYcxZ8raemul1DYVOVdFsbqckWLdsixQZCpJlwe77Z3UTalE7jsjnKfQ== @@ -4817,6 +4327,17 @@ call-bind@^1.0.0, call-bind@^1.0.2: function-bind "^1.1.1" get-intrinsic "^1.0.2" +call-bind@^1.0.5, call-bind@^1.0.6, call-bind@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.7.tgz#06016599c40c56498c18769d2730be242b6fa3b9" + integrity sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w== + dependencies: + es-define-property "^1.0.0" + es-errors "^1.3.0" + function-bind "^1.1.2" + get-intrinsic "^1.2.4" + set-function-length "^1.2.1" + callsites@^3.0.0: version "3.1.0" resolved "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz" @@ -4837,6 +4358,11 @@ caniuse-lite@^1.0.30001541: resolved "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001551.tgz" integrity sha512-vtBAez47BoGMMzlbYhfXrMV1kvRF2WP/lqiMuDu1Sb4EE4LKEgjopFDSRtZfdVnslNRpOqV/woE+Xgrwj6VQlg== +caniuse-lite@^1.0.30001587: + version "1.0.30001588" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001588.tgz#07f16b65a7f95dba82377096923947fb25bce6e3" + integrity sha512-+hVY9jE44uKLkH0SrUTqxjxqNTOWHsbnQDIKjwkZ3lNTzUUVdBLBGXtj/q5Mp5u98r3droaZAewQuEDzjQdZlQ== + canvg@^3.0.6: version "3.0.10" resolved "https://registry.npmjs.org/canvg/-/canvg-3.0.10.tgz" @@ -4929,16 +4455,16 @@ cjs-module-lexer@^1.0.0: resolved "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.3.tgz" integrity sha512-0TNiGstbQmCFwt4akjjBg5pLRTSyj/PkWQ1ZoO2zntmg9yLqSRxwEa4iCfQLGjqhiqBfOJa7W/E8wfGrTDmlZQ== -classnames@2.3.2, classnames@2.x, classnames@^2.2.1, classnames@^2.2.5, classnames@^2.2.6, classnames@^2.3.1, classnames@^2.3.2: - version "2.3.2" - resolved "https://registry.npmjs.org/classnames/-/classnames-2.3.2.tgz" - integrity sha512-CSbhY4cFEJRe6/GQzIk5qXZ4Jeg5pcsP7b5peFSDpffpe1cqjASH/n9UTjBwOp6XpMSTwQ8Za2K5V02ueA7Tmw== - classnames@2.5.1: version "2.5.1" resolved "https://registry.yarnpkg.com/classnames/-/classnames-2.5.1.tgz#ba774c614be0f016da105c858e7159eae8e7687b" integrity sha512-saHYOzhIQs6wy2sVxTM6bUDsQO4F50V9RQ22qBpEdCW+I+/Wmke2HOl6lS6dTpdxVhb88/I6+Hs+438c3lfUow== +classnames@2.x, classnames@^2.2.1, classnames@^2.2.5, classnames@^2.2.6, classnames@^2.3.1, classnames@^2.3.2: + version "2.3.2" + resolved "https://registry.npmjs.org/classnames/-/classnames-2.3.2.tgz" + integrity sha512-CSbhY4cFEJRe6/GQzIk5qXZ4Jeg5pcsP7b5peFSDpffpe1cqjASH/n9UTjBwOp6XpMSTwQ8Za2K5V02ueA7Tmw== + clean-stack@^2.0.0: version "2.2.0" resolved "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz" @@ -4995,11 +4521,6 @@ clone-deep@^4.0.1: kind-of "^6.0.2" shallow-clone "^3.0.0" -clsx@^1.1.1, clsx@^1.2.1: - version "1.2.1" - resolved "https://registry.npmjs.org/clsx/-/clsx-1.2.1.tgz" - integrity sha512-EcR6r5a8bj6pu3ycsa/E/cKVGuTgZJZdsyUYHOksG/UHIiKfjxzRxYJpyVBwYaQeOvghal9fcc4PidlgzugAQg== - clsx@^2.0.0: version "2.1.0" resolved "https://registry.npmjs.org/clsx/-/clsx-2.1.0.tgz" @@ -5086,6 +4607,11 @@ comment-parser@1.3.1: resolved "https://registry.npmjs.org/comment-parser/-/comment-parser-1.3.1.tgz" integrity sha512-B52sN2VNghyq5ofvUsqZjmk6YkihBX5vMSChmSK9v4ShjKf3Vk5Xcmgpw4o+iIgtrnM/u5FiMpz9VKb8lpBveA== +comment-parser@1.4.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/comment-parser/-/comment-parser-1.4.1.tgz#bdafead37961ac079be11eb7ec65c4d021eaf9cc" + integrity sha512-buhp5kePrmda3vhc5B9t7pUQXAb2Tnd0qgpkIhPhkHXxJpiPJ11H0ZEU0oBpJ2QztSbzG/ZxMj/CHsYJqRHmyg== + common-path-prefix@^3.0.0: version "3.0.0" resolved "https://registry.npmjs.org/common-path-prefix/-/common-path-prefix-3.0.0.tgz" @@ -5135,17 +4661,17 @@ copy-to-clipboard@^3.3.1: dependencies: toggle-selection "^1.0.6" -copy-webpack-plugin@11.0.0: - version "11.0.0" - resolved "https://registry.npmjs.org/copy-webpack-plugin/-/copy-webpack-plugin-11.0.0.tgz" - integrity sha512-fX2MWpamkW0hZxMEg0+mYnA40LTosOSa5TqZ9GYIBzyJa9C3QUaMPSE2xAi/buNr8u89SfD9wHSQVBzrRa/SOQ== +copy-webpack-plugin@12.0.2: + version "12.0.2" + resolved "https://registry.yarnpkg.com/copy-webpack-plugin/-/copy-webpack-plugin-12.0.2.tgz#935e57b8e6183c82f95bd937df658a59f6a2da28" + integrity sha512-SNwdBeHyII+rWvee/bTnAYyO8vfVdcSTud4EIb6jcZ8inLeWucJE0DnxXQBjlQ5zlteuuvooGQy3LIyGxhvlOA== dependencies: - fast-glob "^3.2.11" + fast-glob "^3.3.2" glob-parent "^6.0.1" - globby "^13.1.1" + globby "^14.0.0" normalize-path "^3.0.0" - schema-utils "^4.0.0" - serialize-javascript "^6.0.0" + schema-utils "^4.2.0" + serialize-javascript "^6.0.2" core-js-compat@^3.31.0, core-js-compat@^3.33.1: version "3.33.1" @@ -5154,16 +4680,16 @@ core-js-compat@^3.31.0, core-js-compat@^3.33.1: dependencies: browserslist "^4.22.1" -core-js@3.33.0, core-js@^3.6.0, core-js@^3.8.3: - version "3.33.0" - resolved "https://registry.npmjs.org/core-js/-/core-js-3.33.0.tgz" - integrity sha512-HoZr92+ZjFEKar5HS6MC776gYslNOKHt75mEBKWKnPeFDpZ6nH5OeF3S6HFT1mUAUZKrzkez05VboaX8myjSuw== - core-js@^2.4.0: version "2.6.12" resolved "https://registry.npmjs.org/core-js/-/core-js-2.6.12.tgz" integrity sha512-Kb2wC0fvsWfQrgk8HU5lW6U/Lcs8+9aaYcy4ZFc6DDlo4nZ7n70dEgE5rtR0oG6ufKDUnrwfWL1mXR5ljDatrQ== +core-js@^3.6.0, core-js@^3.8.3: + version "3.33.0" + resolved "https://registry.npmjs.org/core-js/-/core-js-3.33.0.tgz" + integrity sha512-HoZr92+ZjFEKar5HS6MC776gYslNOKHt75mEBKWKnPeFDpZ6nH5OeF3S6HFT1mUAUZKrzkez05VboaX8myjSuw== + core-util-is@1.0.2: version "1.0.2" resolved "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz" @@ -5174,7 +4700,7 @@ core-util-is@~1.0.0: resolved "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz" integrity sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ== -cosmiconfig@^7.0.0, cosmiconfig@^7.0.1: +cosmiconfig@^7.0.0: version "7.1.0" resolved "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.1.0.tgz" integrity sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA== @@ -5185,6 +4711,16 @@ cosmiconfig@^7.0.0, cosmiconfig@^7.0.1: path-type "^4.0.0" yaml "^1.10.0" +cosmiconfig@^8.2.0: + version "8.3.6" + resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-8.3.6.tgz#060a2b871d66dba6c8538ea1118ba1ac16f5fae3" + integrity sha512-kcZ6+W5QzcJ3P1Mt+83OUv/oHFqZHIx8DuxG6eZ5RGMERoLqp4BuGjhHLYGK+Kf5XVkQvqBSmAy/nGWN3qDgEA== + dependencies: + import-fresh "^3.3.0" + js-yaml "^4.1.0" + parse-json "^5.2.0" + path-type "^4.0.0" + create-jest@^29.7.0: version "29.7.0" resolved "https://registry.npmjs.org/create-jest/-/create-jest-29.7.0.tgz" @@ -5241,19 +4777,19 @@ css-line-break@^2.1.0: dependencies: utrie "^1.0.2" -css-loader@6.7.3: - version "6.7.3" - resolved "https://registry.npmjs.org/css-loader/-/css-loader-6.7.3.tgz" - integrity sha512-qhOH1KlBMnZP8FzRO6YCH9UHXQhVMcEGLyNdb7Hv2cpcmJbW0YrddO+tG1ab5nT41KpHIYGsbeHqxB9xPu1pKQ== +css-loader@6.10.0: + version "6.10.0" + resolved "https://registry.yarnpkg.com/css-loader/-/css-loader-6.10.0.tgz#7c172b270ec7b833951b52c348861206b184a4b7" + integrity sha512-LTSA/jWbwdMlk+rhmElbDR2vbtQoTBPr7fkJE+mxrHj+7ru0hUmHafDRzWIjIHTwpitWVaqY2/UWGRca3yUgRw== dependencies: icss-utils "^5.1.0" - postcss "^8.4.19" + postcss "^8.4.33" postcss-modules-extract-imports "^3.0.0" - postcss-modules-local-by-default "^4.0.0" - postcss-modules-scope "^3.0.0" + postcss-modules-local-by-default "^4.0.4" + postcss-modules-scope "^3.1.1" postcss-modules-values "^4.0.0" postcss-value-parser "^4.2.0" - semver "^7.3.8" + semver "^7.5.4" css-tree@^1.1.2: version "1.1.3" @@ -5300,7 +4836,7 @@ cssstyle@^2.3.0: dependencies: cssom "~0.3.6" -csstype@^3.0.2, csstype@^3.0.6: +csstype@^3.0.2: version "3.1.2" resolved "https://registry.npmjs.org/csstype/-/csstype-3.1.2.tgz" integrity sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ== @@ -5628,13 +5164,6 @@ data-urls@^3.0.2: whatwg-mimetype "^3.0.0" whatwg-url "^11.0.0" -date-fns@2.30.0: - version "2.30.0" - resolved "https://registry.npmjs.org/date-fns/-/date-fns-2.30.0.tgz" - integrity sha512-fnULvOpxnC5/Vg3NCiWelDsLiUc9bRwAPs/+LfTLNvetFCtCTN+yQz15C/fs4AwX1R9K5GLtLfn8QW+dWisaAw== - dependencies: - "@babel/runtime" "^7.21.0" - date-fns@3.3.1: version "3.3.1" resolved "https://registry.yarnpkg.com/date-fns/-/date-fns-3.3.1.tgz#7581daca0892d139736697717a168afbb908cfed" @@ -5655,7 +5184,7 @@ debounce-promise@3.1.2: resolved "https://registry.npmjs.org/debounce-promise/-/debounce-promise-3.1.2.tgz" integrity sha512-rZHcgBkbYavBeD9ej6sP56XfG53d51CD4dnaw989YX/nZ/ZJfgRx/9ePKmTNiUiyQvh4mtrMoS3OAWW+yoYtpg== -debug@4, debug@4.3.4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.2, debug@^4.3.4: +debug@4, debug@4.3.4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.2, debug@^4.3.4: version "4.3.4" resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== @@ -5667,7 +5196,7 @@ debug@^0.7.2: resolved "https://registry.npmjs.org/debug/-/debug-0.7.4.tgz" integrity sha512-EohAb3+DSHSGx8carOSKJe8G0ayV5/i609OD0J2orCkuyae7SyZSz2aoLmQF2s0Pj5gITDebwPH7GFBlqOUQ1Q== -debug@^2.2.0, debug@^2.6.9: +debug@^2.2.0: version "2.6.9" resolved "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz" integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== @@ -5739,7 +5268,16 @@ define-data-property@^1.0.1: gopd "^1.0.1" has-property-descriptors "^1.0.0" -define-properties@^1.1.3, define-properties@^1.1.4, define-properties@^1.2.0: +define-data-property@^1.1.2, define-data-property@^1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/define-data-property/-/define-data-property-1.1.4.tgz#894dc141bb7d3060ae4366f6a0107e68fbe48c5e" + integrity sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A== + dependencies: + es-define-property "^1.0.0" + es-errors "^1.3.0" + gopd "^1.0.1" + +define-properties@^1.1.3, define-properties@^1.1.4, define-properties@^1.2.0, define-properties@^1.2.1: version "1.2.1" resolved "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz" integrity sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg== @@ -5816,11 +5354,16 @@ doctrine@^3.0.0: dependencies: esutils "^2.0.2" -dom-accessibility-api@^0.5.6, dom-accessibility-api@^0.5.9: +dom-accessibility-api@^0.5.9: version "0.5.16" resolved "https://registry.npmjs.org/dom-accessibility-api/-/dom-accessibility-api-0.5.16.tgz" integrity sha512-X7BJ2yElsnOJ30pZF4uIIDfBEVgF4XEBxL9Bxhy6dnrm5hkzqmsWHGTiHqRiITNhMyFLyAiWndIJP7Z1NTteDg== +dom-accessibility-api@^0.6.3: + version "0.6.3" + resolved "https://registry.yarnpkg.com/dom-accessibility-api/-/dom-accessibility-api-0.6.3.tgz#993e925cc1d73f2c662e7d75dd5a5445259a8fd8" + integrity sha512-7ZgogeTnjuHbo+ct10G9Ffp0mif17idi0IyWNVA/wcwcm7NPOD/WEHVP3n7n3MhXqxoIYm8d6MuZohYWIZ4T3w== + dom-align@^1.7.0: version "1.12.4" resolved "https://registry.npmjs.org/dom-align/-/dom-align-1.12.4.tgz" @@ -5850,7 +5393,7 @@ domexception@^4.0.0: dependencies: webidl-conversions "^7.0.0" -dompurify@^2.2.0, dompurify@^2.4.3: +dompurify@^2.2.0: version "2.4.7" resolved "https://registry.npmjs.org/dompurify/-/dompurify-2.4.7.tgz" integrity sha512-kxxKlPEDa6Nc5WJi+qRgPbOAbgTpSULL+vI3NUXsZMlkJxTqYI9wg5ZTay2sFrdZRWHPWNi+EdAhcJf81WtoMQ== @@ -5883,6 +5426,11 @@ electron-to-chromium@^1.4.535: resolved "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.559.tgz" integrity sha512-iS7KhLYCSJbdo3rUSkhDTVuFNCV34RKs2UaB9Ecr7VlqzjjWW//0nfsFF5dtDmyXlZQaDYYtID5fjtC/6lpRug== +electron-to-chromium@^1.4.668: + version "1.4.677" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.677.tgz#49ee77713516740bdde32ac2d1443c444f0dafe7" + integrity sha512-erDa3CaDzwJOpyvfKhOiJjBVNnMM0qxHq47RheVVwsSQrgBA9ZSGV9kdaOfZDPXcHzhG7lBxhj6A7KvfLJBd6Q== + emittery@^0.13.1: version "0.13.1" resolved "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz" @@ -5919,9 +5467,9 @@ enhanced-resolve@^4.0.0: memory-fs "^0.5.0" tapable "^1.0.0" -enhanced-resolve@^5.14.1: +enhanced-resolve@^5.15.0: version "5.15.0" - resolved "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.15.0.tgz" + resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.15.0.tgz#1af946c7d93603eb88e9896cee4904dc012e9c35" integrity sha512-LXYT42KJ7lpIKECr2mAXIaMldcNCh/7E0KBKOu4KSfkHmP+mZmSs+8V5gBAqisWBy0OO4W5Oyys0GO1Y8KtdKg== dependencies: graceful-fs "^4.2.4" @@ -6018,6 +5566,70 @@ es-abstract@^1.22.1: unbox-primitive "^1.0.2" which-typed-array "^1.1.11" +es-abstract@^1.22.3, es-abstract@^1.22.4: + version "1.22.4" + resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.22.4.tgz#26eb2e7538c3271141f5754d31aabfdb215f27bf" + integrity sha512-vZYJlk2u6qHYxBOTjAeg7qUxHdNfih64Uu2J8QqWgXZ2cri0ZpJAkzDUK/q593+mvKwlxyaxr6F1Q+3LKoQRgg== + dependencies: + array-buffer-byte-length "^1.0.1" + arraybuffer.prototype.slice "^1.0.3" + available-typed-arrays "^1.0.6" + call-bind "^1.0.7" + es-define-property "^1.0.0" + es-errors "^1.3.0" + es-set-tostringtag "^2.0.2" + es-to-primitive "^1.2.1" + function.prototype.name "^1.1.6" + get-intrinsic "^1.2.4" + get-symbol-description "^1.0.2" + globalthis "^1.0.3" + gopd "^1.0.1" + has-property-descriptors "^1.0.2" + has-proto "^1.0.1" + has-symbols "^1.0.3" + hasown "^2.0.1" + internal-slot "^1.0.7" + is-array-buffer "^3.0.4" + is-callable "^1.2.7" + is-negative-zero "^2.0.2" + is-regex "^1.1.4" + is-shared-array-buffer "^1.0.2" + is-string "^1.0.7" + is-typed-array "^1.1.13" + is-weakref "^1.0.2" + object-inspect "^1.13.1" + object-keys "^1.1.1" + object.assign "^4.1.5" + regexp.prototype.flags "^1.5.2" + safe-array-concat "^1.1.0" + safe-regex-test "^1.0.3" + string.prototype.trim "^1.2.8" + string.prototype.trimend "^1.0.7" + string.prototype.trimstart "^1.0.7" + typed-array-buffer "^1.0.1" + typed-array-byte-length "^1.0.0" + typed-array-byte-offset "^1.0.0" + typed-array-length "^1.0.4" + unbox-primitive "^1.0.2" + which-typed-array "^1.1.14" + +es-array-method-boxes-properly@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/es-array-method-boxes-properly/-/es-array-method-boxes-properly-1.0.0.tgz#873f3e84418de4ee19c5be752990b2e44718d09e" + integrity sha512-wd6JXUmyHmt8T5a2xreUwKcGPq6f1f+WwIJkijUqiGcJz1qqnZgP6XIK+QyIWU5lT7imeNxUll48bziG+TSYcA== + +es-define-property@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/es-define-property/-/es-define-property-1.0.0.tgz#c7faefbdff8b2696cf5f46921edfb77cc4ba3845" + integrity sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ== + dependencies: + get-intrinsic "^1.2.4" + +es-errors@^1.0.0, es-errors@^1.2.1, es-errors@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/es-errors/-/es-errors-1.3.0.tgz#05f75a25dab98e4fb1dcd5e1472c0546d5057c8f" + integrity sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw== + es-get-iterator@^1.1.3: version "1.1.3" resolved "https://registry.npmjs.org/es-get-iterator/-/es-get-iterator-1.1.3.tgz" @@ -6033,6 +5645,27 @@ es-get-iterator@^1.1.3: isarray "^2.0.5" stop-iteration-iterator "^1.0.0" +es-iterator-helpers@^1.0.12, es-iterator-helpers@^1.0.15: + version "1.0.17" + resolved "https://registry.yarnpkg.com/es-iterator-helpers/-/es-iterator-helpers-1.0.17.tgz#123d1315780df15b34eb181022da43e734388bb8" + integrity sha512-lh7BsUqelv4KUbR5a/ZTaGGIMLCjPGPqJ6q+Oq24YP0RdyptX1uzm4vvaqzk7Zx3bpl/76YLTTDj9L7uYQ92oQ== + dependencies: + asynciterator.prototype "^1.0.0" + call-bind "^1.0.7" + define-properties "^1.2.1" + es-abstract "^1.22.4" + es-errors "^1.3.0" + es-set-tostringtag "^2.0.2" + function-bind "^1.1.2" + get-intrinsic "^1.2.4" + globalthis "^1.0.3" + has-property-descriptors "^1.0.2" + has-proto "^1.0.1" + has-symbols "^1.0.3" + internal-slot "^1.0.7" + iterator.prototype "^1.1.2" + safe-array-concat "^1.1.0" + es-module-lexer@^1.2.1: version "1.3.1" resolved "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.3.1.tgz" @@ -6047,6 +5680,15 @@ es-set-tostringtag@^2.0.1: has "^1.0.3" has-tostringtag "^1.0.0" +es-set-tostringtag@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz#8bb60f0a440c2e4281962428438d58545af39777" + integrity sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ== + dependencies: + get-intrinsic "^1.2.4" + has-tostringtag "^1.0.2" + hasown "^2.0.1" + es-shim-unscopables@^1.0.0: version "1.0.0" resolved "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.0.tgz" @@ -6054,6 +5696,13 @@ es-shim-unscopables@^1.0.0: dependencies: has "^1.0.3" +es-shim-unscopables@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz#1f6942e71ecc7835ed1c8a83006d8771a63a3763" + integrity sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw== + dependencies: + hasown "^2.0.0" + es-to-primitive@^1.2.1: version "1.2.1" resolved "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz" @@ -6099,45 +5748,54 @@ eslint-config-prettier@8.8.0: resolved "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.8.0.tgz" integrity sha512-wLbQiFre3tdGgpDv67NQKnJuTlcUVYHas3k+DZCc2U2BadthoEY4B7hLPvAxaqdyOGCzuLfii2fqGph10va7oA== -eslint-import-resolver-node@^0.3.6: +eslint-config-prettier@9.1.0: + version "9.1.0" + resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-9.1.0.tgz#31af3d94578645966c082fcb71a5846d3c94867f" + integrity sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw== + +eslint-import-resolver-node@^0.3.9: version "0.3.9" - resolved "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz" + resolved "https://registry.yarnpkg.com/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz#d4eaac52b8a2e7c3cd1903eb00f7e053356118ac" integrity sha512-WFj2isz22JahUv+B788TlO3N6zL3nNJGU8CcZbPZvVEkBPaJdCV4vy5wyghty5ROFbCRnm132v8BScu5/1BQ8g== dependencies: debug "^3.2.7" is-core-module "^2.13.0" resolve "^1.22.4" -eslint-module-utils@^2.7.3: +eslint-module-utils@^2.8.0: version "2.8.0" - resolved "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz" + resolved "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz#e439fee65fc33f6bba630ff621efc38ec0375c49" integrity sha512-aWajIYfsqCKRDgUfjEXNN/JlrzauMuSEy5sbd7WXbtW3EH6A6MpwEh42c7qD+MqQo9QMJ6fWLAeIJynx0g6OAw== dependencies: debug "^3.2.7" -eslint-plugin-import@2.26.0: - version "2.26.0" - resolved "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.26.0.tgz" - integrity sha512-hYfi3FXaM8WPLf4S1cikh/r4IxnO6zrhZbEGz2b660EJRbuxgpDS5gkCuYgGWg2xxh2rBuIr4Pvhve/7c31koA== +eslint-plugin-import@^2.26.0: + version "2.29.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.29.1.tgz#d45b37b5ef5901d639c15270d74d46d161150643" + integrity sha512-BbPC0cuExzhiMo4Ff1BTVwHpjjv28C5R+btTOGaCRC7UEz801up0JadwkeSk5Ued6TG34uaczuVuH6qyy5YUxw== dependencies: - array-includes "^3.1.4" - array.prototype.flat "^1.2.5" - debug "^2.6.9" + array-includes "^3.1.7" + array.prototype.findlastindex "^1.2.3" + array.prototype.flat "^1.3.2" + array.prototype.flatmap "^1.3.2" + debug "^3.2.7" doctrine "^2.1.0" - eslint-import-resolver-node "^0.3.6" - eslint-module-utils "^2.7.3" - has "^1.0.3" - is-core-module "^2.8.1" + eslint-import-resolver-node "^0.3.9" + eslint-module-utils "^2.8.0" + hasown "^2.0.0" + is-core-module "^2.13.1" is-glob "^4.0.3" minimatch "^3.1.2" - object.values "^1.1.5" - resolve "^1.22.0" - tsconfig-paths "^3.14.1" + object.fromentries "^2.0.7" + object.groupby "^1.0.1" + object.values "^1.1.7" + semver "^6.3.1" + tsconfig-paths "^3.15.0" -eslint-plugin-jest@27.2.3: - version "27.2.3" - resolved "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-27.2.3.tgz" - integrity sha512-sRLlSCpICzWuje66Gl9zvdF6mwD5X86I4u55hJyFBsxYOsBCmT5+kSUjf+fkFWVMMgpzNEupjW8WzUqi83hJAQ== +eslint-plugin-jest@27.8.0: + version "27.8.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-jest/-/eslint-plugin-jest-27.8.0.tgz#c8900c3e74e4c6b8cee67ea77dbc8de9cbd9e093" + integrity sha512-347hVFiu4ZKMYl5xFp0X81gLNwBdno0dl0CMpUMjwuAux9X/M2a7z+ab2VHmPL6XCT87q8nv1vaVzhIO4TE/hw== dependencies: "@typescript-eslint/utils" "^5.10.0" @@ -6156,42 +5814,42 @@ eslint-plugin-jsdoc@46.2.6: semver "^7.5.1" spdx-expression-parse "^3.0.1" -eslint-plugin-jsdoc@46.4.3: - version "46.4.3" - resolved "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-46.4.3.tgz" - integrity sha512-Prc7ol+vCIghPeECpwZq5+P+VZfoi87suywvbYCiCnkI1kTmVSdcOC2M8mioglWxBbd28wbb1OVjg/8OzGzatA== +eslint-plugin-jsdoc@48.1.0: + version "48.1.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-48.1.0.tgz#565363770b433485bfc70dc862b50b7f780529ec" + integrity sha512-g9S8ukmTd1DVcV/xeBYPPXOZ6rc8WJ4yi0+MVxJ1jBOrz5kmxV9gJJQ64ltCqIWFnBChLIhLVx3tbTSarqVyFA== dependencies: - "@es-joy/jsdoccomment" "~0.39.4" + "@es-joy/jsdoccomment" "~0.42.0" are-docs-informative "^0.0.2" - comment-parser "1.3.1" + comment-parser "1.4.1" debug "^4.3.4" escape-string-regexp "^4.0.0" esquery "^1.5.0" is-builtin-module "^3.2.1" - semver "^7.5.1" - spdx-expression-parse "^3.0.1" + semver "^7.6.0" + spdx-expression-parse "^4.0.0" -eslint-plugin-jsx-a11y@6.7.1: - version "6.7.1" - resolved "https://registry.npmjs.org/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.7.1.tgz" - integrity sha512-63Bog4iIethyo8smBklORknVjB0T2dwB8Mr/hIC+fBS0uyHdYYpzM/Ed+YC8VxTjlXHEWFOdmgwcDn1U2L9VCA== +eslint-plugin-jsx-a11y@6.8.0: + version "6.8.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.8.0.tgz#2fa9c701d44fcd722b7c771ec322432857fcbad2" + integrity sha512-Hdh937BS3KdwwbBaKd5+PLCOmYY6U4f2h9Z2ktwtNKvIdIEu137rjYbcb9ApSbVJfWxANNuiKTD/9tOKjK9qOA== dependencies: - "@babel/runtime" "^7.20.7" - aria-query "^5.1.3" - array-includes "^3.1.6" - array.prototype.flatmap "^1.3.1" - ast-types-flow "^0.0.7" - axe-core "^4.6.2" - axobject-query "^3.1.1" + "@babel/runtime" "^7.23.2" + aria-query "^5.3.0" + array-includes "^3.1.7" + array.prototype.flatmap "^1.3.2" + ast-types-flow "^0.0.8" + axe-core "=4.7.0" + axobject-query "^3.2.1" damerau-levenshtein "^1.0.8" emoji-regex "^9.2.2" - has "^1.0.3" - jsx-ast-utils "^3.3.3" - language-tags "=1.0.5" + es-iterator-helpers "^1.0.15" + hasown "^2.0.0" + jsx-ast-utils "^3.3.5" + language-tags "^1.0.9" minimatch "^3.1.2" - object.entries "^1.1.6" - object.fromentries "^2.0.6" - semver "^6.3.0" + object.entries "^1.1.7" + object.fromentries "^2.0.7" eslint-plugin-lodash@7.4.0: version "7.4.0" @@ -6226,6 +5884,28 @@ eslint-plugin-react@7.32.2: semver "^6.3.0" string.prototype.matchall "^4.0.8" +eslint-plugin-react@7.33.2: + version "7.33.2" + resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.33.2.tgz#69ee09443ffc583927eafe86ffebb470ee737608" + integrity sha512-73QQMKALArI8/7xGLNI/3LylrEYrlKZSb5C9+q3OtOewTnMQi5cT+aE9E41sLCmli3I9PGGmD1yiZydyo4FEPw== + dependencies: + array-includes "^3.1.6" + array.prototype.flatmap "^1.3.1" + array.prototype.tosorted "^1.1.1" + doctrine "^2.1.0" + es-iterator-helpers "^1.0.12" + estraverse "^5.3.0" + jsx-ast-utils "^2.4.1 || ^3.0.0" + minimatch "^3.1.2" + object.entries "^1.1.6" + object.fromentries "^2.0.6" + object.hasown "^1.1.2" + object.values "^1.1.6" + prop-types "^15.8.1" + resolve "^2.0.0-next.4" + semver "^6.3.1" + string.prototype.matchall "^4.0.8" + eslint-scope@5.1.1, eslint-scope@^5.1.1: version "5.1.1" resolved "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz" @@ -6242,18 +5922,6 @@ eslint-scope@^7.2.0, eslint-scope@^7.2.2: esrecurse "^4.3.0" estraverse "^5.2.0" -eslint-utils@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz" - integrity sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA== - dependencies: - eslint-visitor-keys "^2.0.0" - -eslint-visitor-keys@^2.0.0: - version "2.1.0" - resolved "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz" - integrity sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw== - eslint-visitor-keys@^3.3.0, eslint-visitor-keys@^3.4.1, eslint-visitor-keys@^3.4.3: version "3.4.3" resolved "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz" @@ -6315,18 +5983,19 @@ eslint@8.42.0: strip-json-comments "^3.1.0" text-table "^0.2.0" -eslint@8.50.0: - version "8.50.0" - resolved "https://registry.npmjs.org/eslint/-/eslint-8.50.0.tgz" - integrity sha512-FOnOGSuFuFLv/Sa+FDVRZl4GGVAAFFi8LecRsI5a1tMO5HIE8nCm4ivAlzt4dT3ol/PaaGC0rJEEXQmHJBGoOg== +eslint@8.56.0: + version "8.56.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.56.0.tgz#4957ce8da409dc0809f99ab07a1b94832ab74b15" + integrity sha512-Go19xM6T9puCOWntie1/P997aXxFsOi37JIHRWI514Hc6ZnaHGKY9xFhrU65RT6CcBEzZoGG1e6Nq+DT04ZtZQ== dependencies: "@eslint-community/eslint-utils" "^4.2.0" "@eslint-community/regexpp" "^4.6.1" - "@eslint/eslintrc" "^2.1.2" - "@eslint/js" "8.50.0" - "@humanwhocodes/config-array" "^0.11.11" + "@eslint/eslintrc" "^2.1.4" + "@eslint/js" "8.56.0" + "@humanwhocodes/config-array" "^0.11.13" "@humanwhocodes/module-importer" "^1.0.1" "@nodelib/fs.walk" "^1.2.8" + "@ungap/structured-clone" "^1.2.0" ajv "^6.12.4" chalk "^4.0.0" cross-spawn "^7.0.2" @@ -6510,7 +6179,7 @@ fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: resolved "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz" integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== -fast-glob@^3.2.11, fast-glob@^3.2.9, fast-glob@^3.3.0: +fast-glob@^3.2.9: version "3.3.1" resolved "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.1.tgz" integrity sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg== @@ -6521,6 +6190,17 @@ fast-glob@^3.2.11, fast-glob@^3.2.9, fast-glob@^3.3.0: merge2 "^1.3.0" micromatch "^4.0.4" +fast-glob@^3.3.2: + version "3.3.2" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.3.2.tgz#a904501e57cfdd2ffcded45e99a54fef55e46129" + integrity sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow== + dependencies: + "@nodelib/fs.stat" "^2.0.2" + "@nodelib/fs.walk" "^1.2.3" + glob-parent "^5.1.2" + merge2 "^1.3.0" + micromatch "^4.0.4" + fast-json-stable-stringify@^2.0.0, fast-json-stable-stringify@^2.1.0: version "2.1.0" resolved "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz" @@ -6698,15 +6378,15 @@ forever-agent@~0.6.1: resolved "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz" integrity sha512-j0KLYPhm6zeac4lz3oJ3o65qvgQCcPubiyotZrXqEaG4hNagNYO8qdlUrX5vwqv9ohqeT/Z3j6+yW067yWWdUw== -fork-ts-checker-webpack-plugin@8.0.0: - version "8.0.0" - resolved "https://registry.npmjs.org/fork-ts-checker-webpack-plugin/-/fork-ts-checker-webpack-plugin-8.0.0.tgz" - integrity sha512-mX3qW3idpueT2klaQXBzrIM/pHw+T0B/V9KHEvNrqijTq9NFnMZU6oreVxDYcf33P8a5cW+67PjodNHthGnNVg== +fork-ts-checker-webpack-plugin@9.0.2: + version "9.0.2" + resolved "https://registry.yarnpkg.com/fork-ts-checker-webpack-plugin/-/fork-ts-checker-webpack-plugin-9.0.2.tgz#c12c590957837eb02b02916902dcf3e675fd2b1e" + integrity sha512-Uochze2R8peoN1XqlSi/rGUkDQpRogtLFocP9+PGu68zk1BDAKXfdeCdyVZpgTk8V8WFVQXdEz426VKjXLO1Gg== dependencies: "@babel/code-frame" "^7.16.7" chalk "^4.1.2" chokidar "^3.5.3" - cosmiconfig "^7.0.1" + cosmiconfig "^8.2.0" deepmerge "^4.2.2" fs-extra "^10.0.0" memfs "^3.4.1" @@ -6763,17 +6443,22 @@ fs.realpath@^1.0.0: resolved "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz" integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== +fsevents@2.3.2: + version "2.3.2" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" + integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== + fsevents@^2.3.2, fsevents@~2.3.2: version "2.3.3" resolved "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz" integrity sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw== -function-bind@^1.1.1: +function-bind@^1.1.1, function-bind@^1.1.2: version "1.1.2" resolved "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz" integrity sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA== -function.prototype.name@^1.1.6: +function.prototype.name@^1.1.5, function.prototype.name@^1.1.6: version "1.1.6" resolved "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz" integrity sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg== @@ -6826,6 +6511,17 @@ get-intrinsic@^1.0.2, get-intrinsic@^1.1.1, get-intrinsic@^1.1.3, get-intrinsic@ has-proto "^1.0.1" has-symbols "^1.0.3" +get-intrinsic@^1.2.2, get-intrinsic@^1.2.3, get-intrinsic@^1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.4.tgz#e385f5a4b5227d449c3eabbad05494ef0abbeadd" + integrity sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ== + dependencies: + es-errors "^1.3.0" + function-bind "^1.1.2" + has-proto "^1.0.1" + has-symbols "^1.0.3" + hasown "^2.0.0" + get-package-type@^0.1.0: version "0.1.0" resolved "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz" @@ -6851,6 +6547,15 @@ get-symbol-description@^1.0.0: call-bind "^1.0.2" get-intrinsic "^1.1.1" +get-symbol-description@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/get-symbol-description/-/get-symbol-description-1.0.2.tgz#533744d5aa20aca4e079c8e5daf7fd44202821f5" + integrity sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg== + dependencies: + call-bind "^1.0.5" + es-errors "^1.3.0" + get-intrinsic "^1.2.4" + get-user-locale@^2.2.1: version "2.3.1" resolved "https://registry.npmjs.org/get-user-locale/-/get-user-locale-2.3.1.tgz" @@ -6972,16 +6677,17 @@ globby@^11.1.0: merge2 "^1.4.1" slash "^3.0.0" -globby@^13.1.1: - version "13.2.2" - resolved "https://registry.npmjs.org/globby/-/globby-13.2.2.tgz" - integrity sha512-Y1zNGV+pzQdh7H39l9zgB4PJqjRNqydvdYCDG4HFXM4XuvSaQQlEc91IU1yALL8gUTDomgBAfz3XJdmUS+oo0w== +globby@^14.0.0: + version "14.0.1" + resolved "https://registry.yarnpkg.com/globby/-/globby-14.0.1.tgz#a1b44841aa7f4c6d8af2bc39951109d77301959b" + integrity sha512-jOMLD2Z7MAhyG8aJpNOpmziMOP4rPLcc95oQPKXBazW82z+CEgPFBQvEpRUa1KeIMUJo4Wsm+q6uzO/Q/4BksQ== dependencies: - dir-glob "^3.0.1" - fast-glob "^3.3.0" + "@sindresorhus/merge-streams" "^2.1.0" + fast-glob "^3.3.2" ignore "^5.2.4" - merge2 "^1.4.1" - slash "^4.0.0" + path-type "^5.0.0" + slash "^5.1.0" + unicorn-magic "^0.1.0" gopd@^1.0.1: version "1.0.1" @@ -7045,6 +6751,13 @@ has-property-descriptors@^1.0.0: dependencies: get-intrinsic "^1.1.1" +has-property-descriptors@^1.0.1, has-property-descriptors@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz#963ed7d071dc7bf5f084c5bfbe0d1b6222586854" + integrity sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg== + dependencies: + es-define-property "^1.0.0" + has-proto@^1.0.1: version "1.0.1" resolved "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz" @@ -7062,11 +6775,25 @@ has-tostringtag@^1.0.0: dependencies: has-symbols "^1.0.2" +has-tostringtag@^1.0.1, has-tostringtag@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/has-tostringtag/-/has-tostringtag-1.0.2.tgz#2cdc42d40bef2e5b4eeab7c01a73c54ce7ab5abc" + integrity sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw== + dependencies: + has-symbols "^1.0.3" + has@^1.0.3: version "1.0.4" resolved "https://registry.npmjs.org/has/-/has-1.0.4.tgz" integrity sha512-qdSAmqLF6209RFj4VVItywPMbm3vWylknmB3nvNiUIs72xAimcM8nVYxYr7ncvZq5qzk9MKIZR8ijqD/1QuYjQ== +hasown@^2.0.0, hasown@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.1.tgz#26f48f039de2c0f8d3356c223fb8d50253519faa" + integrity sha512-1/th4MHjnwncwXsIW6QMzlvYL9kG5e/CpVvLRZe4XPa8TOUNbCELqmvhDmnkNsAjwaG4+I8gJJL0JBvTTLO9qA== + dependencies: + function-bind "^1.1.2" + he@1.2.0: version "1.2.0" resolved "https://registry.npmjs.org/he/-/he-1.2.0.tgz" @@ -7185,13 +6912,6 @@ i18next-browser-languagedetector@^7.0.2: dependencies: "@babel/runtime" "^7.19.4" -i18next@^22.0.0: - version "22.5.1" - resolved "https://registry.npmjs.org/i18next/-/i18next-22.5.1.tgz" - integrity sha512-8TGPgM3pAD+VRsMtUMNknRz3kzqwp/gPALrWMsDnmC1mKqJwpWyooQRLMcbTwq8z8YwSmuj+ZYvc+xCuEpkssA== - dependencies: - "@babel/runtime" "^7.20.6" - i18next@^23.0.0: version "23.8.2" resolved "https://registry.yarnpkg.com/i18next/-/i18next-23.8.2.tgz#f3ff6ea929e0927d9717f0ed195ae46d05919900" @@ -7240,11 +6960,6 @@ immer@^9.0.21: resolved "https://registry.npmjs.org/immer/-/immer-9.0.21.tgz" integrity sha512-bc4NBHqOqSfRW7POMkHd51LvClaeMXpm8dx0e8oE2GORbq5aRK7Bxl4FyzVLdGtLmvLKL7BTDBG5ACQm4HWjTA== -immutable@4.3.1: - version "4.3.1" - resolved "https://registry.npmjs.org/immutable/-/immutable-4.3.1.tgz" - integrity sha512-lj9cnmB/kVS0QHsJnYKD1uo3o39nrbKxszjnqS9Fr6NB7bZzW45U6WSGBPKXDL/CvDKqDNPA4r3DoDQ8GTxo2A== - immutable@4.3.5: version "4.3.5" resolved "https://registry.yarnpkg.com/immutable/-/immutable-4.3.5.tgz#f8b436e66d59f99760dc577f5c99a4fd2a5cc5a0" @@ -7260,7 +6975,7 @@ immutable@^4.0.0: resolved "https://registry.npmjs.org/immutable/-/immutable-4.3.4.tgz" integrity sha512-fsXeu4J4i6WNWSikpI88v/PcVflZz+6kMhUfIwc5SY+poQRPnaf5V7qds6SUyUN3cVxEzuCab7QIoLOQ+DQ1wA== -import-fresh@^3.0.0, import-fresh@^3.2.1: +import-fresh@^3.0.0, import-fresh@^3.2.1, import-fresh@^3.3.0: version "3.3.0" resolved "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz" integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== @@ -7304,14 +7019,6 @@ ini@2.0.0: resolved "https://registry.npmjs.org/ini/-/ini-2.0.0.tgz" integrity sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA== -inline-style-prefixer@^6.0.0: - version "6.0.4" - resolved "https://registry.npmjs.org/inline-style-prefixer/-/inline-style-prefixer-6.0.4.tgz" - integrity sha512-FwXmZC2zbeeS7NzGjJ6pAiqRhXR0ugUShSNb6GApMl6da0/XGc4MOJsoWAywia52EEWbXNSy0pzkwz/+Y+swSg== - dependencies: - css-in-js-utils "^3.1.0" - fast-loops "^1.1.3" - inline-style-prefixer@^7.0.0: version "7.0.0" resolved "https://registry.npmjs.org/inline-style-prefixer/-/inline-style-prefixer-7.0.0.tgz" @@ -7329,6 +7036,15 @@ internal-slot@^1.0.4, internal-slot@^1.0.5: has "^1.0.3" side-channel "^1.0.4" +internal-slot@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.7.tgz#c06dcca3ed874249881007b0a5523b172a190802" + integrity sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g== + dependencies: + es-errors "^1.3.0" + hasown "^2.0.0" + side-channel "^1.0.4" + "internmap@1 - 2": version "2.0.3" resolved "https://registry.npmjs.org/internmap/-/internmap-2.0.3.tgz" @@ -7373,11 +7089,26 @@ is-array-buffer@^3.0.1, is-array-buffer@^3.0.2: get-intrinsic "^1.2.0" is-typed-array "^1.1.10" +is-array-buffer@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/is-array-buffer/-/is-array-buffer-3.0.4.tgz#7a1f92b3d61edd2bc65d24f130530ea93d7fae98" + integrity sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw== + dependencies: + call-bind "^1.0.2" + get-intrinsic "^1.2.1" + is-arrayish@^0.2.1: version "0.2.1" resolved "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz" integrity sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg== +is-async-function@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/is-async-function/-/is-async-function-2.0.0.tgz#8e4418efd3e5d3a6ebb0164c05ef5afb69aa9646" + integrity sha512-Y1JXKrfykRJGdlDwdKlLpLyMIiWqWvuSd17TvZk68PLAOGOoF4Xyav1z0Xhoi+gCYjZVeC5SI+hYFOfvXmGRCA== + dependencies: + has-tostringtag "^1.0.0" + is-bigint@^1.0.1: version "1.0.4" resolved "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz" @@ -7419,12 +7150,19 @@ is-ci@^3.0.0: dependencies: ci-info "^3.2.0" -is-core-module@^2.13.0, is-core-module@^2.8.1: +is-core-module@^2.13.0: version "2.13.0" resolved "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.0.tgz" integrity sha512-Z7dk6Qo8pOCp3l4tsX2C5ZVas4V+UxwQodwZhLopL91TX8UyyHEXafPcyoeeWuLrwzHcr3igO78wNLwHJHsMCQ== dependencies: - has "^1.0.3" + has "^1.0.3" + +is-core-module@^2.13.1: + version "2.13.1" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.13.1.tgz#ad0d7532c6fea9da1ebdc82742d74525c6273384" + integrity sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw== + dependencies: + hasown "^2.0.0" is-date-object@^1.0.1, is-date-object@^1.0.5: version "1.0.5" @@ -7438,6 +7176,13 @@ is-extglob@^2.1.1: resolved "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz" integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== +is-finalizationregistry@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-finalizationregistry/-/is-finalizationregistry-1.0.2.tgz#c8749b65f17c133313e661b1289b95ad3dbd62e6" + integrity sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw== + dependencies: + call-bind "^1.0.2" + is-fullwidth-code-point@^3.0.0: version "3.0.0" resolved "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz" @@ -7448,6 +7193,13 @@ is-generator-fn@^2.0.0: resolved "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz" integrity sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ== +is-generator-function@^1.0.10: + version "1.0.10" + resolved "https://registry.yarnpkg.com/is-generator-function/-/is-generator-function-1.0.10.tgz#f1558baf1ac17e0deea7c0415c438351ff2b3c72" + integrity sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A== + dependencies: + has-tostringtag "^1.0.0" + is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3, is-glob@~4.0.1: version "4.0.3" resolved "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz" @@ -7568,6 +7320,13 @@ is-typed-array@^1.1.10, is-typed-array@^1.1.12, is-typed-array@^1.1.9: dependencies: which-typed-array "^1.1.11" +is-typed-array@^1.1.13: + version "1.1.13" + resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.13.tgz#d6c5ca56df62334959322d7d7dd1cca50debe229" + integrity sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw== + dependencies: + which-typed-array "^1.1.14" + is-typedarray@~1.0.0: version "1.0.0" resolved "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz" @@ -7691,6 +7450,17 @@ istanbul-reports@^3.1.3: html-escaper "^2.0.0" istanbul-lib-report "^3.0.0" +iterator.prototype@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/iterator.prototype/-/iterator.prototype-1.1.2.tgz#5e29c8924f01916cb9335f1ff80619dcff22b0c0" + integrity sha512-DR33HMMr8EzwuRL8Y9D3u2BMj8+RqSE850jfGu59kS7tbmPLzGkZmVSfyCFSDxuZiEY6Rzt3T2NA/qU+NwVj1w== + dependencies: + define-properties "^1.2.1" + get-intrinsic "^1.2.1" + has-symbols "^1.0.3" + reflect.getprototypeof "^1.0.4" + set-function-name "^2.0.1" + jackspeak@^2.3.5: version "2.3.6" resolved "https://registry.npmjs.org/jackspeak/-/jackspeak-2.3.6.tgz" @@ -7735,9 +7505,9 @@ jest-circus@^29.7.0: slash "^3.0.0" stack-utils "^2.0.3" -jest-cli@^29.5.0: +jest-cli@^29.7.0: version "29.7.0" - resolved "https://registry.npmjs.org/jest-cli/-/jest-cli-29.7.0.tgz" + resolved "https://registry.yarnpkg.com/jest-cli/-/jest-cli-29.7.0.tgz#5592c940798e0cae677eec169264f2d839a37995" integrity sha512-OVVobw2IubN/GSYsxETi+gOe7Ka59EFMR/twOU3Jb2GnKKeMGJB5SGUUrEz3SFVmJASUdZUzy83sLNNQ2gZslg== dependencies: "@jest/core" "^29.7.0" @@ -7808,18 +7578,18 @@ jest-each@^29.7.0: jest-util "^29.7.0" pretty-format "^29.7.0" -jest-environment-jsdom@29.5.0: - version "29.5.0" - resolved "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-29.5.0.tgz" - integrity sha512-/KG8yEK4aN8ak56yFVdqFDzKNHgF4BAymCx2LbPNPsUshUlfAl0eX402Xm1pt+eoG9SLZEUVifqXtX8SK74KCw== +jest-environment-jsdom@29.7.0: + version "29.7.0" + resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-29.7.0.tgz#d206fa3551933c3fd519e5dfdb58a0f5139a837f" + integrity sha512-k9iQbsf9OyOfdzWH8HDmrRT0gSIcX+FLNW7IQq94tFX0gynPwqDTW0Ho6iMVNjGz/nb+l/vW3dWM2bbLLpkbXA== dependencies: - "@jest/environment" "^29.5.0" - "@jest/fake-timers" "^29.5.0" - "@jest/types" "^29.5.0" + "@jest/environment" "^29.7.0" + "@jest/fake-timers" "^29.7.0" + "@jest/types" "^29.6.3" "@types/jsdom" "^20.0.0" "@types/node" "*" - jest-mock "^29.5.0" - jest-util "^29.5.0" + jest-mock "^29.7.0" + jest-util "^29.7.0" jsdom "^20.0.0" jest-environment-node@^29.7.0: @@ -7891,7 +7661,7 @@ jest-message-util@^29.7.0: slash "^3.0.0" stack-utils "^2.0.3" -jest-mock@^29.5.0, jest-mock@^29.7.0: +jest-mock@^29.7.0: version "29.7.0" resolved "https://registry.npmjs.org/jest-mock/-/jest-mock-29.7.0.tgz" integrity sha512-ITOMZn+UkYS4ZFh83xYAOzWStloNzJFO2s8DWrE4lhtGD+AorgnbkiKERe4wQVBydIGPx059g6riW5Btp6Llnw== @@ -8014,7 +7784,7 @@ jest-snapshot@^29.7.0: pretty-format "^29.7.0" semver "^7.5.3" -jest-util@^29.5.0, jest-util@^29.7.0: +jest-util@^29.7.0: version "29.7.0" resolved "https://registry.npmjs.org/jest-util/-/jest-util-29.7.0.tgz" integrity sha512-z6EbKajIpqGKU56y5KBUgy1dt1ihhQJgWzUlZHArA/+X2ad7Cb5iF+AK1EWVL/Bo7Rz9uurpqw6SiBCefUbCGA== @@ -8071,20 +7841,15 @@ jest-worker@^29.5.0, jest-worker@^29.7.0: merge-stream "^2.0.0" supports-color "^8.0.0" -jest@29.5.0: - version "29.5.0" - resolved "https://registry.npmjs.org/jest/-/jest-29.5.0.tgz" - integrity sha512-juMg3he2uru1QoXX078zTa7pO85QyB9xajZc6bU+d9yEGwrKX6+vGmJQ3UdVZsvTEUARIdObzH68QItim6OSSQ== +jest@29.7.0: + version "29.7.0" + resolved "https://registry.yarnpkg.com/jest/-/jest-29.7.0.tgz#994676fc24177f088f1c5e3737f5697204ff2613" + integrity sha512-NIy3oAFp9shda19hy4HK0HRTWKtPJmGdnvywu01nOqNC2vZg+Z+fvJDxpMQA88eb2I9EcafcdjYgsDthnYTvGw== dependencies: - "@jest/core" "^29.5.0" - "@jest/types" "^29.5.0" + "@jest/core" "^29.7.0" + "@jest/types" "^29.6.3" import-local "^3.0.2" - jest-cli "^29.5.0" - -jquery@3.7.0: - version "3.7.0" - resolved "https://registry.npmjs.org/jquery/-/jquery-3.7.0.tgz" - integrity sha512-umpJ0/k8X0MvD1ds0P9SfowREz2LenHsQaxSohMZ5OMNEU2r0tf8pdeEFTHMFxWVxKNyU9rTtK3CWzUCTKJUeQ== + jest-cli "^29.7.0" jquery@3.7.1: version "3.7.1" @@ -8269,7 +8034,7 @@ jsprim@^2.0.2: json-schema "0.4.0" verror "1.10.0" -"jsx-ast-utils@^2.4.1 || ^3.0.0", jsx-ast-utils@^3.3.3: +"jsx-ast-utils@^2.4.1 || ^3.0.0", jsx-ast-utils@^3.3.5: version "3.3.5" resolved "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.5.tgz" integrity sha512-ZZow9HBI5O6EPgSJLUb8n2NKgmVWTwCvHGwFuJlMjvLFqlGG6pjirPhtdsseaLZjSibD8eegzmYpUZwoIlj2cQ== @@ -8296,17 +8061,17 @@ kleur@^3.0.3: resolved "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz" integrity sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w== -language-subtag-registry@~0.3.2: +language-subtag-registry@^0.3.20: version "0.3.22" - resolved "https://registry.npmjs.org/language-subtag-registry/-/language-subtag-registry-0.3.22.tgz" + resolved "https://registry.yarnpkg.com/language-subtag-registry/-/language-subtag-registry-0.3.22.tgz#2e1500861b2e457eba7e7ae86877cbd08fa1fd1d" integrity sha512-tN0MCzyWnoz/4nHS6uxdlFWoUZT7ABptwKPQ52Ea7URk6vll88bWBVhodtnlfEuCcKWNGoc+uGbw1cwa9IKh/w== -language-tags@=1.0.5: - version "1.0.5" - resolved "https://registry.npmjs.org/language-tags/-/language-tags-1.0.5.tgz" - integrity sha512-qJhlO9cGXi6hBGKoxEG/sKZDAHD5Hnu9Hs4WbOY3pCWXDhw0N8x1NenNzm2EnNLkLkk7J2SdxAkDSbb6ftT+UQ== +language-tags@^1.0.9: + version "1.0.9" + resolved "https://registry.yarnpkg.com/language-tags/-/language-tags-1.0.9.tgz#1ffdcd0ec0fafb4b1be7f8b11f306ad0f9c08777" + integrity sha512-MbjN408fEndfiQXbFQ1vnd+1NoLDsnQW41410oQBXiyXDMYH5z505juWa4KUE1LqxRC7DgOgZDbKLxHIwm27hA== dependencies: - language-subtag-registry "~0.3.2" + language-subtag-registry "^0.3.20" lazy-ass@^1.6.0: version "1.6.0" @@ -8449,11 +8214,6 @@ loose-envify@^1.0.0, loose-envify@^1.1.0, loose-envify@^1.2.0, loose-envify@^1.3 dependencies: js-tokens "^3.0.0 || ^4.0.0" -lru-cache@10.0.1, "lru-cache@^9.1.1 || ^10.0.0": - version "10.0.1" - resolved "https://registry.npmjs.org/lru-cache/-/lru-cache-10.0.1.tgz" - integrity sha512-IJ4uwUTi2qCccrioU6g9g/5rvvVl13bsdczUUcqbciD9iLr095yj8DQKdObriEvuNSx325N1rV1O0sJFszx75g== - lru-cache@10.2.0: version "10.2.0" resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-10.2.0.tgz#0bd445ca57363465900f4d1f9bd8db343a4d95c3" @@ -8473,6 +8233,11 @@ lru-cache@^6.0.0: dependencies: yallist "^4.0.0" +"lru-cache@^9.1.1 || ^10.0.0": + version "10.0.1" + resolved "https://registry.npmjs.org/lru-cache/-/lru-cache-10.0.1.tgz" + integrity sha512-IJ4uwUTi2qCccrioU6g9g/5rvvVl13bsdczUUcqbciD9iLr095yj8DQKdObriEvuNSx325N1rV1O0sJFszx75g== + lz-string@^1.5.0: version "1.5.0" resolved "https://registry.npmjs.org/lz-string/-/lz-string-1.5.0.tgz" @@ -8502,11 +8267,6 @@ mapbox-to-css-font@^2.4.1: resolved "https://registry.npmjs.org/mapbox-to-css-font/-/mapbox-to-css-font-2.4.2.tgz" integrity sha512-f+NBjJJY4T3dHtlEz1wCG7YFlkODEjFIYlxDdLIDMNpkSksqTt+l/d4rjuwItxuzkuMFvPyrjzV2lxRM4ePcIA== -marked-mangle@1.1.0: - version "1.1.0" - resolved "https://registry.npmjs.org/marked-mangle/-/marked-mangle-1.1.0.tgz" - integrity sha512-ed2W2gMB2HIBaYasBZveMFJfDRTL2OFycr0GgUSPcBSNl5dX+1r6lHG6u1eFXw7kej2hBTWa1m6YZqcfn4Coxw== - marked-mangle@1.1.7: version "1.1.7" resolved "https://registry.yarnpkg.com/marked-mangle/-/marked-mangle-1.1.7.tgz#07fed8f47ebdc51761aac0364723468644cea49d" @@ -8517,11 +8277,6 @@ marked@12.0.0: resolved "https://registry.yarnpkg.com/marked/-/marked-12.0.0.tgz#051ea8c8c7f65148a63003df1499515a2c6de716" integrity sha512-Vkwtq9rLqXryZnWaQc86+FHLC6tr/fycMfYAhiOIXkrNmeGAyhSxjqu0Rs1i0bBqw5u0S7+lV9fdH2ZSVaoa0w== -marked@5.1.1: - version "5.1.1" - resolved "https://registry.npmjs.org/marked/-/marked-5.1.1.tgz" - integrity sha512-bTmmGdEINWmOMDjnPWDxGPQ4qkDLeYorpYbEtFOXzOruTwUE671q4Guiuchn4N8h/v6NGd7916kXsm3Iz4iUSg== - mdn-data@2.0.14: version "2.0.14" resolved "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.14.tgz" @@ -8617,6 +8372,13 @@ minimatch@5.0.1: dependencies: brace-expansion "^2.0.1" +minimatch@9.0.3, minimatch@^9.0.1: + version "9.0.3" + resolved "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz" + integrity sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg== + dependencies: + brace-expansion "^2.0.1" + minimatch@^3.0.4, minimatch@^3.0.5, minimatch@^3.1.1, minimatch@^3.1.2: version "3.1.2" resolved "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz" @@ -8624,13 +8386,6 @@ minimatch@^3.0.4, minimatch@^3.0.5, minimatch@^3.1.1, minimatch@^3.1.2: dependencies: brace-expansion "^1.1.7" -minimatch@^9.0.1: - version "9.0.3" - resolved "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz" - integrity sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg== - dependencies: - brace-expansion "^2.0.1" - minimist@^1.2.0, minimist@^1.2.5, minimist@^1.2.6: version "1.2.8" resolved "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz" @@ -8675,13 +8430,6 @@ mocha@10.2.0: yargs-parser "20.2.4" yargs-unparser "2.0.0" -moment-timezone@0.5.43: - version "0.5.43" - resolved "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.43.tgz" - integrity sha512-72j3aNyuIsDxdF1i7CEgV2FfxM1r6aaqJyLB2vwb33mXYyoyLly+F1zbWqhA3/bVIoJ4szlUoMbUnVdid32NUQ== - dependencies: - moment "^2.29.4" - moment-timezone@0.5.45: version "0.5.45" resolved "https://registry.yarnpkg.com/moment-timezone/-/moment-timezone-0.5.45.tgz#cb685acd56bac10e69d93c536366eb65aa6bcf5c" @@ -8689,16 +8437,16 @@ moment-timezone@0.5.45: dependencies: moment "^2.29.4" -moment@2.29.4, moment@2.x, moment@^2.29.4: - version "2.29.4" - resolved "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz" - integrity sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w== - moment@2.30.1: version "2.30.1" resolved "https://registry.yarnpkg.com/moment/-/moment-2.30.1.tgz#f8c91c07b7a786e30c59926df530b4eac96974ae" integrity sha512-uEmtNhbDOrWPFS+hdjFCBfy9f2YoyzRpwcl+DqpC6taX21FzsTLQVbMV/W7PzNSX6x/bhC1zA3c2UQ5NzH6how== +moment@2.x, moment@^2.29.4: + version "2.29.4" + resolved "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz" + integrity sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w== + monaco-editor@0.34.0: version "0.34.0" resolved "https://registry.npmjs.org/monaco-editor/-/monaco-editor-0.34.0.tgz" @@ -8724,25 +8472,6 @@ ms@2.1.3, ms@^2.1.1: resolved "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== -murmurhash-js@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/murmurhash-js/-/murmurhash-js-1.0.0.tgz" - integrity sha512-TvmkNhkv8yct0SVBSy+o8wYzXjE4Zz3PCesbfs8HiCXXdcTuocApFv11UWlNFWKYsP2okqrhb7JNlSm9InBhIw== - -nano-css@^5.3.1: - version "5.3.5" - resolved "https://registry.npmjs.org/nano-css/-/nano-css-5.3.5.tgz" - integrity sha512-vSB9X12bbNu4ALBu7nigJgRViZ6ja3OU7CeuiV1zMIbXOdmkLahgtPmh3GBOlDxbKY0CitqlPdOReGlBLSp+yg== - dependencies: - css-tree "^1.1.2" - csstype "^3.0.6" - fastest-stable-stringify "^2.0.2" - inline-style-prefixer "^6.0.0" - rtl-css-js "^1.14.0" - sourcemap-codec "^1.4.8" - stacktrace-js "^2.0.2" - stylis "^4.0.6" - nano-css@^5.6.1: version "5.6.1" resolved "https://registry.npmjs.org/nano-css/-/nano-css-5.6.1.tgz" @@ -8762,10 +8491,10 @@ nanoid@3.3.3: resolved "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz" integrity sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w== -nanoid@^3.3.6: - version "3.3.6" - resolved "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz" - integrity sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA== +nanoid@^3.3.7: + version "3.3.7" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.7.tgz#d0c301a691bc8d54efa0a2226ccf3fe2fd656bd8" + integrity sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g== natural-compare-lite@^1.4.0: version "1.4.0" @@ -8797,6 +8526,11 @@ node-releases@^2.0.13: resolved "https://registry.npmjs.org/node-releases/-/node-releases-2.0.13.tgz" integrity sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ== +node-releases@^2.0.14: + version "2.0.14" + resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.14.tgz#2ffb053bceb8b2be8495ece1ab6ce600c4461b0b" + integrity sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw== + normalize-path@^3.0.0, normalize-path@~3.0.0: version "3.0.0" resolved "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz" @@ -8829,6 +8563,11 @@ object-inspect@^1.12.3, object-inspect@^1.9.0: resolved "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.0.tgz" integrity sha512-HQ4J+ic8hKrgIt3mqk6cVOVrW2ozL4KdvHlqpBv9vDYWx9ysAgENAdvy4FoGF+KFdhR7nQTNm5J0ctAeOwn+3g== +object-inspect@^1.13.1: + version "1.13.1" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.13.1.tgz#b96c6109324ccfef6b12216a956ca4dc2ff94bc2" + integrity sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ== + object-is@^1.1.5: version "1.1.5" resolved "https://registry.npmjs.org/object-is/-/object-is-1.1.5.tgz" @@ -8852,7 +8591,17 @@ object.assign@^4.1.4: has-symbols "^1.0.3" object-keys "^1.1.1" -object.entries@^1.1.6: +object.assign@^4.1.5: + version "4.1.5" + resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.5.tgz#3a833f9ab7fdb80fc9e8d2300c803d216d8fdbb0" + integrity sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ== + dependencies: + call-bind "^1.0.5" + define-properties "^1.2.1" + has-symbols "^1.0.3" + object-keys "^1.1.1" + +object.entries@^1.1.6, object.entries@^1.1.7: version "1.1.7" resolved "https://registry.npmjs.org/object.entries/-/object.entries-1.1.7.tgz" integrity sha512-jCBs/0plmPsOnrKAfFQXRG2NFjlhZgjjcBLSmTnEhU8U6vVTsVe8ANeQJCHTl3gSsI4J+0emOoCgoKlmQPMgmA== @@ -8861,7 +8610,7 @@ object.entries@^1.1.6: define-properties "^1.2.0" es-abstract "^1.22.1" -object.fromentries@^2.0.6: +object.fromentries@^2.0.6, object.fromentries@^2.0.7: version "2.0.7" resolved "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.7.tgz" integrity sha512-UPbPHML6sL8PI/mOqPwsH4G6iyXcCGzLin8KvEPenOZN5lpCNBZZQ+V62vdjB1mQHrmqGQt5/OJzemUA+KJmEA== @@ -8870,6 +8619,17 @@ object.fromentries@^2.0.6: define-properties "^1.2.0" es-abstract "^1.22.1" +object.groupby@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/object.groupby/-/object.groupby-1.0.2.tgz#494800ff5bab78fd0eff2835ec859066e00192ec" + integrity sha512-bzBq58S+x+uo0VjurFT0UktpKHOZmv4/xePiOA1nbB9pMqpGK7rUPNgf+1YC+7mE+0HzhTMqNUuCqvKhj6FnBw== + dependencies: + array.prototype.filter "^1.0.3" + call-bind "^1.0.5" + define-properties "^1.2.1" + es-abstract "^1.22.3" + es-errors "^1.0.0" + object.hasown@^1.1.2: version "1.1.3" resolved "https://registry.npmjs.org/object.hasown/-/object.hasown-1.1.3.tgz" @@ -8878,7 +8638,7 @@ object.hasown@^1.1.2: define-properties "^1.2.0" es-abstract "^1.22.1" -object.values@^1.1.5, object.values@^1.1.6: +object.values@^1.1.6, object.values@^1.1.7: version "1.1.7" resolved "https://registry.npmjs.org/object.values/-/object.values-1.1.7.tgz" integrity sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng== @@ -9092,6 +8852,11 @@ path-type@^4.0.0: resolved "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz" integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== +path-type@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-5.0.0.tgz#14b01ed7aea7ddf9c7c3f46181d4d04f9c785bb8" + integrity sha512-5HviZNaZcfqP95rwpv+1HDgUamezbqdSYTyzjTvwtJSnIH+3vnbmWsItli8OFEndS984VT55M3jduxZbX351gg== + pbf@3.2.1: version "3.2.1" resolved "https://registry.npmjs.org/pbf/-/pbf-3.2.1.tgz" @@ -9144,6 +8909,20 @@ pkg-dir@^7.0.0: dependencies: find-up "^6.3.0" +playwright-core@1.41.2: + version "1.41.2" + resolved "https://registry.yarnpkg.com/playwright-core/-/playwright-core-1.41.2.tgz#db22372c708926c697acc261f0ef8406606802d9" + integrity sha512-VaTvwCA4Y8kxEe+kfm2+uUUw5Lubf38RxF7FpBxLPmGe5sdNkSg5e3ChEigaGrX7qdqT3pt2m/98LiyvU2x6CA== + +playwright@1.41.2: + version "1.41.2" + resolved "https://registry.yarnpkg.com/playwright/-/playwright-1.41.2.tgz#4e760b1c79f33d9129a8c65cc27953be6dd35042" + integrity sha512-v0bOa6H2GJChDL8pAeLa/LZC4feoAMbSQm1/jF/ySsWWoaNItvrMP7GEkvEEFyCTUYKMxjQKaTSg5up7nR6/8A== + dependencies: + playwright-core "1.41.2" + optionalDependencies: + fsevents "2.3.2" + pluralize@8.0.0: version "8.0.0" resolved "https://registry.npmjs.org/pluralize/-/pluralize-8.0.0.tgz" @@ -9175,24 +8954,29 @@ portfinder@^1.0.17: debug "^3.2.7" mkdirp "^0.5.6" +possible-typed-array-names@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz#89bb63c6fada2c3e90adc4a647beeeb39cc7bf8f" + integrity sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q== + postcss-modules-extract-imports@^3.0.0: version "3.0.0" resolved "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.0.0.tgz" integrity sha512-bdHleFnP3kZ4NYDhuGlVK+CMrQ/pqUm8bx/oGL93K6gVwiclvX5x0n76fYMKuIGKzlABOy13zsvqjb0f92TEXw== -postcss-modules-local-by-default@^4.0.0: - version "4.0.3" - resolved "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.3.tgz" - integrity sha512-2/u2zraspoACtrbFRnTijMiQtb4GW4BvatjaG/bCjYQo8kLTdevCUlwuBHx2sCnSyrI3x3qj4ZK1j5LQBgzmwA== +postcss-modules-local-by-default@^4.0.4: + version "4.0.4" + resolved "https://registry.yarnpkg.com/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.4.tgz#7cbed92abd312b94aaea85b68226d3dec39a14e6" + integrity sha512-L4QzMnOdVwRm1Qb8m4x8jsZzKAaPAgrUF1r/hjDR2Xj7R+8Zsf97jAlSQzWtKx5YNiNGN8QxmPFIc/sh+RQl+Q== dependencies: icss-utils "^5.0.0" postcss-selector-parser "^6.0.2" postcss-value-parser "^4.1.0" -postcss-modules-scope@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz" - integrity sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg== +postcss-modules-scope@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/postcss-modules-scope/-/postcss-modules-scope-3.1.1.tgz#32cfab55e84887c079a19bbb215e721d683ef134" + integrity sha512-uZgqzdTleelWjzJY+Fhti6F3C9iF1JR/dODLs/JDefozYcKTBCdD8BIl6nNPbTbcLnGrk56hzwZC2DaGNvYjzA== dependencies: postcss-selector-parser "^6.0.4" @@ -9216,12 +9000,12 @@ postcss-value-parser@^4.1.0, postcss-value-parser@^4.2.0: resolved "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz" integrity sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ== -postcss@^8.4.19: - version "8.4.31" - resolved "https://registry.npmjs.org/postcss/-/postcss-8.4.31.tgz" - integrity sha512-PS08Iboia9mts/2ygV3eLpY5ghnUcfLV/EXTOW1E2qYxJKGGBUtNjN76FYHnMs36RmARn41bC0AZmn+rR0OVpQ== +postcss@^8.4.33: + version "8.4.35" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.35.tgz#60997775689ce09011edf083a549cea44aabe2f7" + integrity sha512-u5U8qYpBCpN13BsiEB0CbR1Hhh4Gc0zLFuedrHJKMctHCHAGrMdG0PRM/KErzAL3CU6/eckEtmHNB3x6e3c0vA== dependencies: - nanoid "^3.3.6" + nanoid "^3.3.7" picocolors "^1.0.0" source-map-js "^1.0.2" @@ -9243,10 +9027,10 @@ prelude-ls@^1.2.1: resolved "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz" integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== -prettier@3.0.3: - version "3.0.3" - resolved "https://registry.npmjs.org/prettier/-/prettier-3.0.3.tgz" - integrity sha512-L/4pUDMxcNa8R/EthV08Zt42WBO4h1rarVtK0K+QJG0X187OLo7l699jWw0GKuwzkPQ//jMFA/8Xm6Fh3J/DAg== +prettier@3.2.5: + version "3.2.5" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-3.2.5.tgz#e52bc3090586e824964a8813b09aba6233b28368" + integrity sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A== pretty-bytes@^5.6.0: version "5.6.0" @@ -9439,18 +9223,6 @@ rc-animate@2.x: rc-util "^4.15.3" react-lifecycles-compat "^3.0.4" -rc-cascader@3.18.1: - version "3.18.1" - resolved "https://registry.npmjs.org/rc-cascader/-/rc-cascader-3.18.1.tgz" - integrity sha512-M7Xr5Fs/E87ZGustfObtBYQjsvBCET0UX2JYXB2GmOP+2fsZgjaRGXK+CJBmmWXQ6o4OFinpBQBXG4wJOQ5MEg== - dependencies: - "@babel/runtime" "^7.12.5" - array-tree-filter "^2.1.0" - classnames "^2.3.1" - rc-select "~14.9.0" - rc-tree "~5.7.0" - rc-util "^5.35.0" - rc-cascader@3.21.2: version "3.21.2" resolved "https://registry.yarnpkg.com/rc-cascader/-/rc-cascader-3.21.2.tgz#3421841131cdc15157201fefd955da31f409ac85" @@ -9516,28 +9288,6 @@ rc-select@~14.11.0: rc-util "^5.16.1" rc-virtual-list "^3.5.2" -rc-select@~14.9.0: - version "14.9.2" - resolved "https://registry.npmjs.org/rc-select/-/rc-select-14.9.2.tgz" - integrity sha512-VQ15sRFgPURHb8ZcZNSDtb2rAw3+C9xlL0nDziwNHTEW1KvEpZ8y+0v5w24X/Bpl9b3cW1BOyW1F5UqSAq+7Dg== - dependencies: - "@babel/runtime" "^7.10.1" - "@rc-component/trigger" "^1.5.0" - classnames "2.x" - rc-motion "^2.0.1" - rc-overflow "^1.3.1" - rc-util "^5.16.1" - rc-virtual-list "^3.5.2" - -rc-slider@10.3.1: - version "10.3.1" - resolved "https://registry.npmjs.org/rc-slider/-/rc-slider-10.3.1.tgz" - integrity sha512-XszsZLkbjcG9ogQy/zUC0n2kndoKUAnY/Vnk1Go5Gx+JJQBz0Tl15d5IfSiglwBUZPS9vsUJZkfCmkIZSqWbcA== - dependencies: - "@babel/runtime" "^7.10.1" - classnames "^2.2.5" - rc-util "^5.27.0" - rc-slider@10.5.0: version "10.5.0" resolved "https://registry.yarnpkg.com/rc-slider/-/rc-slider-10.5.0.tgz#1bd4853d114cb3403b67c485125887adb6a2a117" @@ -9559,15 +9309,6 @@ rc-time-picker@^3.7.3: rc-trigger "^2.2.0" react-lifecycles-compat "^3.0.4" -rc-tooltip@6.1.1: - version "6.1.1" - resolved "https://registry.npmjs.org/rc-tooltip/-/rc-tooltip-6.1.1.tgz" - integrity sha512-YoxL0Ev4htsX37qgN23eKr0L5PIRpZaLVL9GX6aJ4x6UEnwgXZYUNCAEHfKlKT3eD1felDq3ob4+Cn9lprLDBw== - dependencies: - "@babel/runtime" "^7.11.2" - "@rc-component/trigger" "^1.17.0" - classnames "^2.3.1" - rc-tooltip@6.1.3: version "6.1.3" resolved "https://registry.yarnpkg.com/rc-tooltip/-/rc-tooltip-6.1.3.tgz#83b97004a1ab918ed4936bbf089bc754254efd1b" @@ -9577,17 +9318,6 @@ rc-tooltip@6.1.3: "@rc-component/trigger" "^1.18.0" classnames "^2.3.1" -rc-tree@~5.7.0: - version "5.7.12" - resolved "https://registry.npmjs.org/rc-tree/-/rc-tree-5.7.12.tgz" - integrity sha512-LXA5nY2hG5koIAlHW5sgXgLpOMz+bFRbnZZ+cCg0tQs4Wv1AmY7EDi1SK7iFXhslYockbqUerQan82jljoaItg== - dependencies: - "@babel/runtime" "^7.10.1" - classnames "2.x" - rc-motion "^2.0.1" - rc-util "^5.16.1" - rc-virtual-list "^3.5.1" - rc-tree@~5.8.1: version "5.8.5" resolved "https://registry.yarnpkg.com/rc-tree/-/rc-tree-5.8.5.tgz#f714a383be27bd87366cf32f7f85b2af1fbae6b6" @@ -9623,7 +9353,7 @@ rc-util@^4.0.4, rc-util@^4.15.3, rc-util@^4.4.0: react-lifecycles-compat "^3.0.4" shallowequal "^1.1.0" -rc-util@^5.16.1, rc-util@^5.21.0, rc-util@^5.24.4, rc-util@^5.27.0, rc-util@^5.35.0, rc-util@^5.36.0, rc-util@^5.37.0, rc-util@^5.38.0: +rc-util@^5.16.1, rc-util@^5.21.0, rc-util@^5.24.4, rc-util@^5.27.0, rc-util@^5.36.0, rc-util@^5.37.0, rc-util@^5.38.0: version "5.38.0" resolved "https://registry.npmjs.org/rc-util/-/rc-util-5.38.0.tgz" integrity sha512-yV/YBNdFn+edyBpBdCqkPE29Su0jWcHNgwx2dJbRqMrMfrUcMJUjCRV+ZPhcvWyKFJ63GzEerPrz9JIVo0zXmA== @@ -9654,17 +9384,6 @@ react-beautiful-dnd@13.1.1, react-beautiful-dnd@^13.1.1: redux "^4.0.4" use-memo-one "^1.1.1" -react-calendar@4.3.0: - version "4.3.0" - resolved "https://registry.npmjs.org/react-calendar/-/react-calendar-4.3.0.tgz" - integrity sha512-TyCv8NbXnqXADyXNtMG0szkGvJNH3NG/WMTEE2q6g3RqAsFNyHwYbQD5Kvb6jRV/CqO0WB+oMCtkxblprdeT5A== - dependencies: - "@types/react" "*" - "@wojtekmaj/date-utils" "^1.1.3" - clsx "^1.2.1" - get-user-locale "^2.2.1" - prop-types "^15.6.0" - react-calendar@4.8.0: version "4.8.0" resolved "https://registry.yarnpkg.com/react-calendar/-/react-calendar-4.8.0.tgz#61edbba6d17e7ef8a8012de9143b5e5ff41104c8" @@ -9726,11 +9445,6 @@ react-highlight-words@0.20.0: memoize-one "^4.0.0" prop-types "^15.5.8" -react-hook-form@7.5.3: - version "7.5.3" - resolved "https://registry.npmjs.org/react-hook-form/-/react-hook-form-7.5.3.tgz" - integrity sha512-5T0mfJ4kCPKljd7t3Rgp7lML4Y2+kaZIeMdN6Zo/J7gBQ+WkrDBHOftdOtz4X+7/eqHGak5yL5evNpYdA9abVA== - react-hook-form@^7.49.2: version "7.50.1" resolved "https://registry.yarnpkg.com/react-hook-form/-/react-hook-form-7.50.1.tgz#f6aeb17a863327e5a0252de8b35b4fc8990377ed" @@ -9779,11 +9493,6 @@ react-lifecycles-compat@^3.0.4: resolved "https://registry.npmjs.org/react-lifecycles-compat/-/react-lifecycles-compat-3.0.4.tgz" integrity sha512-fBASbA6LnOU9dOU2eW7aQ8xmYBSXUIWr+UmF9b1efZBazGNO+rcXT/icdKnYm2pTwcRylVUYwW7H1PHfLekVzA== -react-loading-skeleton@3.3.1: - version "3.3.1" - resolved "https://registry.npmjs.org/react-loading-skeleton/-/react-loading-skeleton-3.3.1.tgz" - integrity sha512-NilqqwMh2v9omN7LteiDloEVpFyMIa0VGqF+ukqp0ncVlYu1sKYbYGX9JEl+GtOT9TKsh04zCHAbavnQ2USldA== - react-loading-skeleton@3.4.0: version "3.4.0" resolved "https://registry.yarnpkg.com/react-loading-skeleton/-/react-loading-skeleton-3.4.0.tgz#c71a3a17259d08e4064974aa0b07f150a09dfd57" @@ -9859,28 +9568,6 @@ react-router@5.3.3: tiny-invariant "^1.0.2" tiny-warning "^1.0.0" -react-select-event@^5.1.0: - version "5.5.1" - resolved "https://registry.npmjs.org/react-select-event/-/react-select-event-5.5.1.tgz" - integrity sha512-goAx28y0+iYrbqZA2FeRTreHHs/ZtSuKxtA+J5jpKT5RHPCbVZJ4MqACfPnWyFXsEec+3dP5bCrNTxIX8oYe9A== - dependencies: - "@testing-library/dom" ">=7" - -react-select@5.7.4: - version "5.7.4" - resolved "https://registry.npmjs.org/react-select/-/react-select-5.7.4.tgz" - integrity sha512-NhuE56X+p9QDFh4BgeygHFIvJJszO1i1KSkg/JPcIJrbovyRtI+GuOEa4XzFCEpZRAEoEI8u/cAHK+jG/PgUzQ== - dependencies: - "@babel/runtime" "^7.12.0" - "@emotion/cache" "^11.4.0" - "@emotion/react" "^11.8.1" - "@floating-ui/dom" "^1.0.1" - "@types/react-transition-group" "^4.4.0" - memoize-one "^6.0.0" - prop-types "^15.6.0" - react-transition-group "^4.3.0" - use-isomorphic-layout-effect "^1.1.2" - react-select@5.8.0: version "5.8.0" resolved "https://registry.yarnpkg.com/react-select/-/react-select-5.8.0.tgz#bd5c467a4df223f079dd720be9498076a3f085b5" @@ -9916,26 +9603,6 @@ react-universal-interface@^0.6.2: resolved "https://registry.npmjs.org/react-universal-interface/-/react-universal-interface-0.6.2.tgz" integrity sha512-dg8yXdcQmvgR13RIlZbTRQOoUrDciFVoSBZILwjE2LFISxZZ8loVJKAkuzswl5js8BHda79bIb2b84ehU8IjXw== -react-use@17.4.0: - version "17.4.0" - resolved "https://registry.npmjs.org/react-use/-/react-use-17.4.0.tgz" - integrity sha512-TgbNTCA33Wl7xzIJegn1HndB4qTS9u03QUwyNycUnXaweZkE4Kq2SB+Yoxx8qbshkZGYBDvUXbXWRUmQDcZZ/Q== - dependencies: - "@types/js-cookie" "^2.2.6" - "@xobotyi/scrollbar-width" "^1.9.5" - copy-to-clipboard "^3.3.1" - fast-deep-equal "^3.1.3" - fast-shallow-equal "^1.0.0" - js-cookie "^2.2.1" - nano-css "^5.3.1" - react-universal-interface "^0.6.2" - resize-observer-polyfill "^1.5.1" - screenfull "^5.1.0" - set-harmonic-interval "^1.0.1" - throttle-debounce "^3.0.1" - ts-easing "^0.2.0" - tslib "^2.1.0" - react-use@17.5.0, react-use@^17.4.2: version "17.5.0" resolved "https://registry.npmjs.org/react-use/-/react-use-17.5.0.tgz" @@ -9964,14 +9631,6 @@ react-window@1.8.10: "@babel/runtime" "^7.0.0" memoize-one ">=3.1.1 <6" -react-window@1.8.9: - version "1.8.9" - resolved "https://registry.npmjs.org/react-window/-/react-window-1.8.9.tgz" - integrity sha512-+Eqx/fj1Aa5WnhRfj9dJg4VYATGwIUP2ItwItiJ6zboKWA6EX3lYDAXfGF2hyNqplEprhbtjbipiADEcwQ823Q== - dependencies: - "@babel/runtime" "^7.0.0" - memoize-one ">=3.1.1 <6" - react@18.2.0: version "18.2.0" resolved "https://registry.npmjs.org/react/-/react-18.2.0.tgz" @@ -10036,6 +9695,19 @@ redux@^4.0.0, redux@^4.0.4, redux@^4.2.1: dependencies: "@babel/runtime" "^7.9.2" +reflect.getprototypeof@^1.0.4: + version "1.0.5" + resolved "https://registry.yarnpkg.com/reflect.getprototypeof/-/reflect.getprototypeof-1.0.5.tgz#e0bd28b597518f16edaf9c0e292c631eb13e0674" + integrity sha512-62wgfC8dJWrmxv44CA36pLDnP6KKl3Vhxb7PL+8+qrrFMMoJij4vgiMP8zV4O8+CBMXY1mHxI5fITGHXFHVmQQ== + dependencies: + call-bind "^1.0.5" + define-properties "^1.2.1" + es-abstract "^1.22.3" + es-errors "^1.0.0" + get-intrinsic "^1.2.3" + globalthis "^1.0.3" + which-builtin-type "^1.1.3" + regenerate-unicode-properties@^10.1.0: version "10.1.1" resolved "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.1.tgz" @@ -10048,11 +9720,6 @@ regenerate@^1.4.2: resolved "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz" integrity sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A== -regenerator-runtime@0.13.11, regenerator-runtime@^0.13.7: - version "0.13.11" - resolved "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz" - integrity sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg== - regenerator-runtime@0.14.1: version "0.14.1" resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz#356ade10263f685dda125100cd862c1db895327f" @@ -10063,6 +9730,11 @@ regenerator-runtime@^0.11.0: resolved "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz" integrity sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg== +regenerator-runtime@^0.13.7: + version "0.13.11" + resolved "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz" + integrity sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg== + regenerator-runtime@^0.14.0: version "0.14.0" resolved "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.14.0.tgz" @@ -10084,10 +9756,15 @@ regexp.prototype.flags@^1.5.0, regexp.prototype.flags@^1.5.1: define-properties "^1.2.0" set-function-name "^2.0.0" -regexpp@^3.2.0: - version "3.2.0" - resolved "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz" - integrity sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg== +regexp.prototype.flags@^1.5.2: + version "1.5.2" + resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz#138f644a3350f981a858c44f6bb1a61ff59be334" + integrity sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw== + dependencies: + call-bind "^1.0.6" + define-properties "^1.2.1" + es-errors "^1.3.0" + set-function-name "^2.0.1" regexpu-core@^5.3.1: version "5.3.2" @@ -10212,7 +9889,7 @@ resolve.exports@^2.0.0: resolved "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz" integrity sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg== -resolve@^1.14.2, resolve@^1.19.0, resolve@^1.20.0, resolve@^1.22.0, resolve@^1.22.4: +resolve@^1.14.2, resolve@^1.19.0, resolve@^1.20.0, resolve@^1.22.4: version "1.22.8" resolved "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz" integrity sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw== @@ -10272,7 +9949,7 @@ robust-predicates@^3.0.0: resolved "https://registry.npmjs.org/robust-predicates/-/robust-predicates-3.0.2.tgz" integrity sha512-IXgzBWvWQwE6PrDI05OvmXUIruQTcoMDzRsOd5CDvHCVLcLHMTSYvOK5Cm46kWqlV3yAbuSpBZdJ5oP5OUoStg== -rtl-css-js@^1.14.0, rtl-css-js@^1.16.1: +rtl-css-js@^1.16.1: version "1.16.1" resolved "https://registry.npmjs.org/rtl-css-js/-/rtl-css-js-1.16.1.tgz" integrity sha512-lRQgou1mu19e+Ya0LsTvKrVJ5TYUbqCVPAiImX3UfLTenarvPUl1QFdvu5Z3PYmHT9RCcwIfbjRQBntExyj3Zg== @@ -10308,6 +9985,16 @@ safe-array-concat@^1.0.1: has-symbols "^1.0.3" isarray "^2.0.5" +safe-array-concat@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/safe-array-concat/-/safe-array-concat-1.1.0.tgz#8d0cae9cb806d6d1c06e08ab13d847293ebe0692" + integrity sha512-ZdQ0Jeb9Ofti4hbt5lX3T2JcAamT9hfzYU1MNB+z/jaEbB6wfFfPIR/zEORmZqobkCCJhSjodobH6WHNmJ97dg== + dependencies: + call-bind "^1.0.5" + get-intrinsic "^1.2.2" + has-symbols "^1.0.3" + isarray "^2.0.5" + safe-buffer@>=5.1.0, safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.2: version "5.2.1" resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz" @@ -10332,6 +10019,15 @@ safe-regex-test@^1.0.0: get-intrinsic "^1.1.3" is-regex "^1.1.4" +safe-regex-test@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/safe-regex-test/-/safe-regex-test-1.0.3.tgz#a5b4c0f06e0ab50ea2c395c14d8371232924c377" + integrity sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw== + dependencies: + call-bind "^1.0.6" + es-errors "^1.3.0" + is-regex "^1.1.4" + "safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0", safer-buffer@^2.0.2, safer-buffer@^2.1.0, safer-buffer@~2.1.0: version "2.1.2" resolved "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz" @@ -10344,10 +10040,10 @@ sass-loader@13.3.2: dependencies: neo-async "^2.6.2" -sass@1.68.0: - version "1.68.0" - resolved "https://registry.npmjs.org/sass/-/sass-1.68.0.tgz" - integrity sha512-Lmj9lM/fef0nQswm1J2HJcEsBUba4wgNx2fea6yJHODREoMFnwRpZydBnX/RjyXw2REIwdkbqE4hrTo4qfDBUA== +sass@1.70.0: + version "1.70.0" + resolved "https://registry.yarnpkg.com/sass/-/sass-1.70.0.tgz#761197419d97b5358cb25f9dd38c176a8a270a75" + integrity sha512-uUxNQ3zAHeAx5nRFskBnrWzDUJrrvpCPD5FNAoRvTi0WwremlheES3tg+56PaVtCs5QDRX5CBLxxKMDJMEa1WQ== dependencies: chokidar ">=3.0.0 <4.0.0" immutable "^4.0.0" @@ -10367,7 +10063,7 @@ scheduler@^0.23.0: dependencies: loose-envify "^1.1.0" -schema-utils@>1.0.0, schema-utils@^4.0.0: +schema-utils@>1.0.0, schema-utils@^4.0.0, schema-utils@^4.2.0: version "4.2.0" resolved "https://registry.npmjs.org/schema-utils/-/schema-utils-4.2.0.tgz" integrity sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw== @@ -10377,7 +10073,7 @@ schema-utils@>1.0.0, schema-utils@^4.0.0: ajv-formats "^2.1.1" ajv-keywords "^5.1.0" -schema-utils@^3.1.1, schema-utils@^3.1.2: +schema-utils@^3.1.1, schema-utils@^3.2.0: version "3.3.0" resolved "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz" integrity sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg== @@ -10396,14 +10092,7 @@ selection-is-backward@^1.0.0: resolved "https://registry.npmjs.org/selection-is-backward/-/selection-is-backward-1.0.0.tgz" integrity sha512-C+6PCOO55NLCfS8uQjUKV/6E5XMuUcfOVsix5m0QqCCCKi495NgeQVNfWtAaD71NKHsdmFCJoXUGfir3qWdr9A== -semver@7.5.4, semver@^7.3.2, semver@^7.3.4, semver@^7.3.5, semver@^7.3.7, semver@^7.3.8, semver@^7.5.1, semver@^7.5.3, semver@^7.5.4: - version "7.5.4" - resolved "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz" - integrity sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA== - dependencies: - lru-cache "^6.0.0" - -semver@7.6.0: +semver@7.6.0, semver@^7.6.0: version "7.6.0" resolved "https://registry.yarnpkg.com/semver/-/semver-7.6.0.tgz#1a46a4db4bffcccd97b743b5005c8325f23d4e2d" integrity sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg== @@ -10420,6 +10109,13 @@ semver@^6.3.0, semver@^6.3.1: resolved "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz" integrity sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA== +semver@^7.3.2, semver@^7.3.4, semver@^7.3.5, semver@^7.3.7, semver@^7.5.1, semver@^7.5.3, semver@^7.5.4: + version "7.5.4" + resolved "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz" + integrity sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA== + dependencies: + lru-cache "^6.0.0" + serialize-javascript@6.0.0: version "6.0.0" resolved "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz" @@ -10427,13 +10123,32 @@ serialize-javascript@6.0.0: dependencies: randombytes "^2.1.0" -serialize-javascript@^6.0.0, serialize-javascript@^6.0.1: +serialize-javascript@^6.0.1: version "6.0.1" resolved "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.1.tgz" integrity sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w== dependencies: randombytes "^2.1.0" +serialize-javascript@^6.0.2: + version "6.0.2" + resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.2.tgz#defa1e055c83bf6d59ea805d8da862254eb6a6c2" + integrity sha512-Saa1xPByTTq2gdeFZYLLo+RFE35NHZkAbqZeWNd3BpzppeVisAqpDjcp8dyf6uIvEqJRd46jemmyA4iFIeVk8g== + dependencies: + randombytes "^2.1.0" + +set-function-length@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/set-function-length/-/set-function-length-1.2.1.tgz#47cc5945f2c771e2cf261c6737cf9684a2a5e425" + integrity sha512-j4t6ccc+VsKwYHso+kElc5neZpjtq9EnRICFZtWyBsLojhmeF/ZBd/elqm22WJh/BziDe/SBiOeAt0m2mfLD0g== + dependencies: + define-data-property "^1.1.2" + es-errors "^1.3.0" + function-bind "^1.1.2" + get-intrinsic "^1.2.3" + gopd "^1.0.1" + has-property-descriptors "^1.0.1" + set-function-name@^2.0.0: version "2.0.1" resolved "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.1.tgz" @@ -10443,6 +10158,16 @@ set-function-name@^2.0.0: functions-have-names "^1.2.3" has-property-descriptors "^1.0.0" +set-function-name@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/set-function-name/-/set-function-name-2.0.2.tgz#16a705c5a0dc2f5e638ca96d8a8cd4e1c2b90985" + integrity sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ== + dependencies: + define-data-property "^1.1.4" + es-errors "^1.3.0" + functions-have-names "^1.2.3" + has-property-descriptors "^1.0.2" + set-harmonic-interval@^1.0.1: version "1.0.1" resolved "https://registry.npmjs.org/set-harmonic-interval/-/set-harmonic-interval-1.0.1.tgz" @@ -10501,10 +10226,10 @@ slash@^3.0.0: resolved "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz" integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== -slash@^4.0.0: - version "4.0.0" - resolved "https://registry.npmjs.org/slash/-/slash-4.0.0.tgz" - integrity sha512-3dOsAHXXUkQTpOYcoAxLIorMTp4gIQr5IW3iVb7A7lFIp0VHhnynm9izx6TssdrIcVIESAlVjtnO2K8bg+Coew== +slash@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-5.1.0.tgz#be3adddcdf09ac38eebe8dcdc7b1a57a75b095ce" + integrity sha512-ZA6oR3T/pEyuqwMgAKT0/hAv8oAXckzbkmR0UkUosQ+Mc4RxGoJkRmwHgHufaenlyAgE1Mxgpdcrf75y6XcnDg== slate-base64-serializer@^0.2.112: version "0.2.115" @@ -10651,11 +10376,6 @@ source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.1: resolved "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz" integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== -sourcemap-codec@^1.4.8: - version "1.4.8" - resolved "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz" - integrity sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA== - spdx-exceptions@^2.1.0: version "2.3.0" resolved "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz" @@ -10669,6 +10389,14 @@ spdx-expression-parse@^3.0.1: spdx-exceptions "^2.1.0" spdx-license-ids "^3.0.0" +spdx-expression-parse@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/spdx-expression-parse/-/spdx-expression-parse-4.0.0.tgz#a23af9f3132115465dac215c099303e4ceac5794" + integrity sha512-Clya5JIij/7C6bRR22+tnGXbc4VKlibKSVj2iHvVeX5iMW7s1SIQlqu699JkODJJIhh/pUu8L0/VLh8xflD+LQ== + dependencies: + spdx-exceptions "^2.1.0" + spdx-license-ids "^3.0.0" + spdx-license-ids@^3.0.0: version "3.0.16" resolved "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.16.tgz" @@ -10893,21 +10621,16 @@ strip-json-comments@3.1.1, strip-json-comments@^3.1.0, strip-json-comments@^3.1. resolved "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz" integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== -style-loader@3.3.3: - version "3.3.3" - resolved "https://registry.npmjs.org/style-loader/-/style-loader-3.3.3.tgz" - integrity sha512-53BiGLXAcll9maCYtZi2RCQZKa8NQQai5C4horqKyRmHj9H7QmcUyucrH+4KW/gBQbXM2AsB0axoEcFZPlfPcw== +style-loader@3.3.4: + version "3.3.4" + resolved "https://registry.yarnpkg.com/style-loader/-/style-loader-3.3.4.tgz#f30f786c36db03a45cbd55b6a70d930c479090e7" + integrity sha512-0WqXzrsMTyb8yjZJHDqwmnwRJvhALK9LfRtRc6B4UTWe8AijYLZYZ9thuJTZc2VfQWINADW/j+LiJnfy2RoC1w== stylis@4.2.0: version "4.2.0" resolved "https://registry.npmjs.org/stylis/-/stylis-4.2.0.tgz" integrity sha512-Orov6g6BB1sDfYgzWfTHDOxamtX1bE/zo104Dh9e6fqJ3PooipYyfJ0pUmrZO2wAvO8YbEyeFrkV91XTsGMSrw== -stylis@^4.0.6: - version "4.3.0" - resolved "https://registry.npmjs.org/stylis/-/stylis-4.3.0.tgz" - integrity sha512-E87pIogpwUsUwXw7dNyU4QDjdgVMy52m+XEOPEKUn161cCzWjjhPSQhByfd1CcNvrOLnXQ6OnnZDwnJrz/Z4YQ== - stylis@^4.3.0: version "4.3.1" resolved "https://registry.npmjs.org/stylis/-/stylis-4.3.1.tgz" @@ -10959,11 +10682,6 @@ systemjs-cjs-extra@0.2.0: resolved "https://registry.npmjs.org/systemjs-cjs-extra/-/systemjs-cjs-extra-0.2.0.tgz" integrity sha512-0dB6UkUNgXJ+GKt3OMONQmQV+stZPuy+0o5Bj4nP1YRtbCNtLg01sca3mSyOiBKAnqs5cjx7mTxwzomzsOFJnA== -systemjs@6.14.2: - version "6.14.2" - resolved "https://registry.npmjs.org/systemjs/-/systemjs-6.14.2.tgz" - integrity sha512-1TlOwvKWdXxAY9vba+huLu99zrQURDWA8pUTYsRIYDZYQbGyK+pyEP4h4dlySsqo7ozyJBmYD20F+iUHhAltEg== - systemjs@6.14.3: version "6.14.3" resolved "https://registry.yarnpkg.com/systemjs/-/systemjs-6.14.3.tgz#c1d6e4ff5f9ff7106e5bb3d451360b1a066bde8a" @@ -10984,21 +10702,21 @@ tapable@^2.1.1, tapable@^2.2.0, tapable@^2.2.1: resolved "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz" integrity sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ== -terser-webpack-plugin@^5.3.7: - version "5.3.9" - resolved "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.9.tgz" - integrity sha512-ZuXsqE07EcggTWQjXUj+Aot/OMcD0bMKGgF63f7UxYcu5/AJF53aIpK1YoP5xR9l6s/Hy2b+t1AM0bLNPRuhwA== +terser-webpack-plugin@^5.3.10: + version "5.3.10" + resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-5.3.10.tgz#904f4c9193c6fd2a03f693a2150c62a92f40d199" + integrity sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w== dependencies: - "@jridgewell/trace-mapping" "^0.3.17" + "@jridgewell/trace-mapping" "^0.3.20" jest-worker "^27.4.5" schema-utils "^3.1.1" serialize-javascript "^6.0.1" - terser "^5.16.8" + terser "^5.26.0" -terser@^5.16.8: - version "5.22.0" - resolved "https://registry.npmjs.org/terser/-/terser-5.22.0.tgz" - integrity sha512-hHZVLgRA2z4NWcN6aS5rQDc+7Dcy58HOf2zbYwmFcQ+ua3h6eEFf5lIDKTzbWwlazPyOZsFQO8V80/IjVNExEw== +terser@^5.26.0: + version "5.27.2" + resolved "https://registry.yarnpkg.com/terser/-/terser-5.27.2.tgz#577a362515ff5635f98ba149643793a3973ba77e" + integrity sha512-sHXmLSkImesJ4p5apTeT63DsV4Obe1s37qT8qvwHRmVxKTBH7Rv9Wr26VcAMmLbmk9UliiwK8z+657NyJHHy/w== dependencies: "@jridgewell/source-map" "^0.3.3" acorn "^8.8.2" @@ -11156,6 +10874,11 @@ tracelib@1.0.1: resolved "https://registry.npmjs.org/tracelib/-/tracelib-1.0.1.tgz" integrity sha512-T2Vkpa/7Vdm3sV8nXRn8vZ0tnq6wlnO4Zx7Pux+JA1W6DMlg5EtbNcPZu/L7XRTPc9S0eAKhEFR4p/u0GcsDpQ== +ts-api-utils@^1.0.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/ts-api-utils/-/ts-api-utils-1.2.1.tgz#f716c7e027494629485b21c0df6180f4d08f5e8b" + integrity sha512-RIYA36cJn2WiH9Hy77hdF9r7oEwxAtB/TS9/S4Qd90Ap4z5FSiin5zEiTL44OII1Y3IIlEvxwxFUVgrHSZ/UpA== + ts-easing@^0.2.0: version "0.2.0" resolved "https://registry.npmjs.org/ts-easing/-/ts-easing-0.2.0.tgz" @@ -11172,10 +10895,10 @@ ts-loader@8.4.0: micromatch "^4.0.0" semver "^7.3.4" -ts-node@10.9.1: - version "10.9.1" - resolved "https://registry.npmjs.org/ts-node/-/ts-node-10.9.1.tgz" - integrity sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw== +ts-node@10.9.2: + version "10.9.2" + resolved "https://registry.yarnpkg.com/ts-node/-/ts-node-10.9.2.tgz#70f021c9e185bccdca820e26dc413805c101c71f" + integrity sha512-f0FFpIdcHgn8zcPSbf1dRevwt047YMnaiJM3u2w2RewrB+fob/zePZcrOyQoLMMO7aBIddLcQIEK5dYjkLnGrQ== dependencies: "@cspotcode/source-map-support" "^0.8.0" "@tsconfig/node10" "^1.0.7" @@ -11200,10 +10923,10 @@ tsconfig-paths@4.2.0: minimist "^1.2.6" strip-bom "^3.0.0" -tsconfig-paths@^3.14.1: - version "3.14.2" - resolved "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.14.2.tgz" - integrity sha512-o/9iXgCYc5L/JxCHPe3Hvh8Q/2xm5Z+p18PESBU6Ff33695QnCHBEjcytY2q19ua7Mbl/DavtBOLq+oG0RCL+g== +tsconfig-paths@^3.15.0: + version "3.15.0" + resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.15.0.tgz#5299ec605e55b1abb23ec939ef15edaf483070d4" + integrity sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg== dependencies: "@types/json5" "^0.0.29" json5 "^1.0.2" @@ -11280,6 +11003,15 @@ typed-array-buffer@^1.0.0: get-intrinsic "^1.2.1" is-typed-array "^1.1.10" +typed-array-buffer@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz#1867c5d83b20fcb5ccf32649e5e2fc7424474ff3" + integrity sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ== + dependencies: + call-bind "^1.0.7" + es-errors "^1.3.0" + is-typed-array "^1.1.13" + typed-array-byte-length@^1.0.0: version "1.0.0" resolved "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz" @@ -11315,6 +11047,11 @@ typescript@4.8.4: resolved "https://registry.npmjs.org/typescript/-/typescript-4.8.4.tgz" integrity sha512-QCh+85mCy+h0IGff8r5XWzOVSbBO+KfeYrMQh7NJ58QujwcE22u+NUSmUxqF+un70P9GXKxa2HCNiTTMJknyjQ== +typescript@5.2.2: + version "5.2.2" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.2.2.tgz#5ebb5e5a5b75f085f22bc3f8460fba308310fa78" + integrity sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w== + typescript@5.3.3: version "5.3.3" resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.3.3.tgz#b3ce6ba258e72e6305ba66f5c9b452aaee3ffe37" @@ -11340,6 +11077,11 @@ underscore@1.7.0: resolved "https://registry.npmjs.org/underscore/-/underscore-1.7.0.tgz" integrity sha512-cp0oQQyZhUM1kpJDLdGO1jPZHgS/MpzoWYfe9+CM2h/QGDZlqwT2T3YGukuBdaNJ/CAPoeyAZRRHz8JFo176vA== +undici-types@~5.26.4: + version "5.26.5" + resolved "https://registry.yarnpkg.com/undici-types/-/undici-types-5.26.5.tgz#bcd539893d00b56e964fd2657a4866b221a65617" + integrity sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA== + unicode-canonical-property-names-ecmascript@^2.0.0: version "2.0.0" resolved "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz" @@ -11363,6 +11105,11 @@ unicode-property-aliases-ecmascript@^2.0.0: resolved "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz" integrity sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w== +unicorn-magic@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/unicorn-magic/-/unicorn-magic-0.1.0.tgz#1bb9a51c823aaf9d73a8bfcd3d1a23dde94b0ce4" + integrity sha512-lRfVq8fE8gz6QMBuDM6a+LO3IAzTi05H6gCVaUpir2E1Rwpo4ZUog45KpNXKC/Mn3Yb9UDuHumeFTo9iV/D9FQ== + universalify@^0.2.0: version "0.2.0" resolved "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz" @@ -11386,11 +11133,6 @@ update-browserslist-db@^1.0.13: escalade "^3.1.1" picocolors "^1.0.0" -uplot@1.6.26: - version "1.6.26" - resolved "https://registry.npmjs.org/uplot/-/uplot-1.6.26.tgz" - integrity sha512-qN0mveL6UsP40TnHzHAJkUQvpfA3y8zSLXtXKVlJo/sLfj2+vjan/Z3g81MCZjy/hEDUFNtnLftPmETDA4s7Rg== - uplot@1.6.30: version "1.6.30" resolved "https://registry.yarnpkg.com/uplot/-/uplot-1.6.30.tgz#1622a96b7cb2e50622c74330823c321847cbc147" @@ -11573,21 +11315,21 @@ webpack-sources@^3.2.3: resolved "https://registry.npmjs.org/webpack-sources/-/webpack-sources-3.2.3.tgz" integrity sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w== -webpack@5.86.0: - version "5.86.0" - resolved "https://registry.npmjs.org/webpack/-/webpack-5.86.0.tgz" - integrity sha512-3BOvworZ8SO/D4GVP+GoRC3fVeg5MO4vzmq8TJJEkdmopxyazGDxN8ClqN12uzrZW9Tv8EED8v5VSb6Sqyi0pg== +webpack@5.90.2: + version "5.90.2" + resolved "https://registry.yarnpkg.com/webpack/-/webpack-5.90.2.tgz#189686a8a292427076db9907d495625345805fab" + integrity sha512-ziXu8ABGr0InCMEYFnHrYweinHK2PWrMqnwdHk2oK3rRhv/1B+2FnfwYv5oD+RrknK/Pp/Hmyvu+eAsaMYhzCw== dependencies: "@types/eslint-scope" "^3.7.3" - "@types/estree" "^1.0.0" + "@types/estree" "^1.0.5" "@webassemblyjs/ast" "^1.11.5" "@webassemblyjs/wasm-edit" "^1.11.5" "@webassemblyjs/wasm-parser" "^1.11.5" acorn "^8.7.1" acorn-import-assertions "^1.9.0" - browserslist "^4.14.5" + browserslist "^4.21.10" chrome-trace-event "^1.0.2" - enhanced-resolve "^5.14.1" + enhanced-resolve "^5.15.0" es-module-lexer "^1.2.1" eslint-scope "5.1.1" events "^3.2.0" @@ -11597,9 +11339,9 @@ webpack@5.86.0: loader-runner "^4.2.0" mime-types "^2.1.27" neo-async "^2.6.2" - schema-utils "^3.1.2" + schema-utils "^3.2.0" tapable "^2.1.1" - terser-webpack-plugin "^5.3.7" + terser-webpack-plugin "^5.3.10" watchpack "^2.4.0" webpack-sources "^3.2.3" @@ -11624,11 +11366,6 @@ whatwg-encoding@^2.0.0: dependencies: iconv-lite "0.6.3" -whatwg-fetch@3.6.2: - version "3.6.2" - resolved "https://registry.npmjs.org/whatwg-fetch/-/whatwg-fetch-3.6.2.tgz" - integrity sha512-bJlen0FcuU/0EMLrdbJ7zOnW6ITZLrZMIarMUVmdKtsGvZna8vxKYaexICWPfZ8qwf9fzNq+UEIZrnSaApt6RA== - whatwg-fetch@3.6.20: version "3.6.20" resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-3.6.20.tgz#580ce6d791facec91d37c72890995a0b48d31c70" @@ -11658,6 +11395,24 @@ which-boxed-primitive@^1.0.2: is-string "^1.0.5" is-symbol "^1.0.3" +which-builtin-type@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/which-builtin-type/-/which-builtin-type-1.1.3.tgz#b1b8443707cc58b6e9bf98d32110ff0c2cbd029b" + integrity sha512-YmjsSMDBYsM1CaFiayOVT06+KJeXf0o5M/CAd4o1lTadFAtacTUM49zoYxr/oroopFDfhvN6iEcBxUyc3gvKmw== + dependencies: + function.prototype.name "^1.1.5" + has-tostringtag "^1.0.0" + is-async-function "^2.0.0" + is-date-object "^1.0.5" + is-finalizationregistry "^1.0.2" + is-generator-function "^1.0.10" + is-regex "^1.1.4" + is-weakref "^1.0.2" + isarray "^2.0.5" + which-boxed-primitive "^1.0.2" + which-collection "^1.0.1" + which-typed-array "^1.1.9" + which-collection@^1.0.1: version "1.0.1" resolved "https://registry.npmjs.org/which-collection/-/which-collection-1.0.1.tgz" @@ -11679,6 +11434,17 @@ which-typed-array@^1.1.11, which-typed-array@^1.1.9: gopd "^1.0.1" has-tostringtag "^1.0.0" +which-typed-array@^1.1.14: + version "1.1.14" + resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.14.tgz#1f78a111aee1e131ca66164d8bdc3ab062c95a06" + integrity sha512-VnXFiIW8yNn9kIHN88xvZ4yOWchftKDsRJ8fEPacX/wl1lOvBrhsJ/OeJCXq7B0AaijRuqgzSKalJoPk+D8MPg== + dependencies: + available-typed-arrays "^1.0.6" + call-bind "^1.0.5" + for-each "^0.3.3" + gopd "^1.0.1" + has-tostringtag "^1.0.1" + which@^2.0.1: version "2.0.2" resolved "https://registry.npmjs.org/which/-/which-2.0.2.tgz" @@ -11794,6 +11560,11 @@ yaml@^2.0.0: resolved "https://registry.npmjs.org/yaml/-/yaml-2.3.3.tgz" integrity sha512-zw0VAJxgeZ6+++/su5AFoqBbZbrEakwu+X0M5HmcwUiBL7AzcuPKjj5we4xfQLp78LkEMpD0cOnUhmgOVy3KdQ== +yaml@^2.3.4: + version "2.3.4" + resolved "https://registry.yarnpkg.com/yaml/-/yaml-2.3.4.tgz#53fc1d514be80aabf386dc6001eb29bf3b7523b2" + integrity sha512-8aAvwVUSHpfEqTQ4w/KMlf3HcRdt50E5ODIQJBw1fQ5RL34xabzxtUlzTXVqc4rkZsPbvrXKWnABCD7kWSmocA== + yargs-parser@20.2.4: version "20.2.4" resolved "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz" From 7bb3bb907fc4173d890f8f09edc6c704daabe801 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 21 Feb 2024 14:34:30 -0600 Subject: [PATCH 02/74] fix plugin.json for missing property --- src/plugin.json | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/plugin.json b/src/plugin.json index 1d462ae6..c47edbdb 100644 --- a/src/plugin.json +++ b/src/plugin.json @@ -102,5 +102,10 @@ "url": "https://prometheus.io/" } ] + }, + "dependencies": { + "grafanaVersion": "10.4.x", + "grafanaDependency": ">=10.4.0", + "plugins": [] } } From 7fa95b1eb23feb4fbc103b95caceb0c6190f0c58 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 21 Feb 2024 14:38:51 -0600 Subject: [PATCH 03/74] remove unnecessary @ts-ignore --- src/module.ts | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/src/module.ts b/src/module.ts index 57192a56..0ceca1c0 100644 --- a/src/module.ts +++ b/src/module.ts @@ -4,10 +4,7 @@ import { PromQueryEditorByApp, PrometheusDatasource, PromCheatSheet } from '@gra // custom config made with sigV4 auth import { ConfigEditor } from './configuration/ConfigEditor'; -// @ts-ignore -export const plugin = new DataSourcePlugin(PrometheusDatasource) - // @ts-ignore +export const plugin = new DataSourcePlugin(PrometheusDatasource) .setQueryEditor(PromQueryEditorByApp) .setConfigEditor(ConfigEditor) - // @ts-ignore .setQueryEditorHelp(PromCheatSheet); From 6eb91cb2a5b98f9d007f48c1e437d8a69859b1d2 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 21 Feb 2024 14:39:34 -0600 Subject: [PATCH 04/74] add plugin-e2e and playwright --- .github/workflows/playwright.yml | 27 ++ .gitignore | 6 +- e2e/example.spec.ts | 18 ++ playwright.config.ts | 77 +++++ tests-examples/demo-todo-app.spec.ts | 437 +++++++++++++++++++++++++++ 5 files changed, 564 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/playwright.yml create mode 100644 e2e/example.spec.ts create mode 100644 playwright.config.ts create mode 100644 tests-examples/demo-todo-app.spec.ts diff --git a/.github/workflows/playwright.yml b/.github/workflows/playwright.yml new file mode 100644 index 00000000..40cb1c0b --- /dev/null +++ b/.github/workflows/playwright.yml @@ -0,0 +1,27 @@ +name: e2e Tests +on: + push: + branches: [ main, master ] + pull_request: + branches: [ main, master ] +jobs: + test: + timeout-minutes: 60 + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - uses: actions/setup-node@v3 + with: + node-version: 18 + - name: Install dependencies + run: npm install -g yarn && yarn + - name: Install Playwright Browsers + run: yarn playwright install --with-deps + - name: Run Playwright tests + run: yarn playwright test + - uses: actions/upload-artifact@v3 + if: always() + with: + name: playwright-report + path: playwright-report/ + retention-days: 30 diff --git a/.gitignore b/.gitignore index df674430..d533361b 100644 --- a/.gitignore +++ b/.gitignore @@ -32,4 +32,8 @@ e2e-results/ # Editor .idea -.eslintcache \ No newline at end of file +.eslintcache +/test-results/ +/playwright-report/ +/blob-report/ +/playwright/.cache/ diff --git a/e2e/example.spec.ts b/e2e/example.spec.ts new file mode 100644 index 00000000..54a906a4 --- /dev/null +++ b/e2e/example.spec.ts @@ -0,0 +1,18 @@ +import { test, expect } from '@playwright/test'; + +test('has title', async ({ page }) => { + await page.goto('https://playwright.dev/'); + + // Expect a title "to contain" a substring. + await expect(page).toHaveTitle(/Playwright/); +}); + +test('get started link', async ({ page }) => { + await page.goto('https://playwright.dev/'); + + // Click the get started link. + await page.getByRole('link', { name: 'Get started' }).click(); + + // Expects page to have a heading with the name of Installation. + await expect(page.getByRole('heading', { name: 'Installation' })).toBeVisible(); +}); diff --git a/playwright.config.ts b/playwright.config.ts new file mode 100644 index 00000000..bfe3e830 --- /dev/null +++ b/playwright.config.ts @@ -0,0 +1,77 @@ +import { defineConfig, devices } from '@playwright/test'; + +/** + * Read environment variables from file. + * https://github.com/motdotla/dotenv + */ +// require('dotenv').config(); + +/** + * See https://playwright.dev/docs/test-configuration. + */ +export default defineConfig({ + testDir: './e2e', + /* Run tests in files in parallel */ + fullyParallel: true, + /* Fail the build on CI if you accidentally left test.only in the source code. */ + forbidOnly: !!process.env.CI, + /* Retry on CI only */ + retries: process.env.CI ? 2 : 0, + /* Opt out of parallel tests on CI. */ + workers: process.env.CI ? 1 : undefined, + /* Reporter to use. See https://playwright.dev/docs/test-reporters */ + reporter: 'html', + /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */ + use: { + /* Base URL to use in actions like `await page.goto('/')`. */ + // baseURL: 'http://127.0.0.1:3000', + + /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */ + trace: 'on-first-retry', + }, + + /* Configure projects for major browsers */ + projects: [ + { + name: 'chromium', + use: { ...devices['Desktop Chrome'] }, + }, + + { + name: 'firefox', + use: { ...devices['Desktop Firefox'] }, + }, + + { + name: 'webkit', + use: { ...devices['Desktop Safari'] }, + }, + + /* Test against mobile viewports. */ + // { + // name: 'Mobile Chrome', + // use: { ...devices['Pixel 5'] }, + // }, + // { + // name: 'Mobile Safari', + // use: { ...devices['iPhone 12'] }, + // }, + + /* Test against branded browsers. */ + // { + // name: 'Microsoft Edge', + // use: { ...devices['Desktop Edge'], channel: 'msedge' }, + // }, + // { + // name: 'Google Chrome', + // use: { ...devices['Desktop Chrome'], channel: 'chrome' }, + // }, + ], + + /* Run your local dev server before starting the tests */ + // webServer: { + // command: 'npm run start', + // url: 'http://127.0.0.1:3000', + // reuseExistingServer: !process.env.CI, + // }, +}); diff --git a/tests-examples/demo-todo-app.spec.ts b/tests-examples/demo-todo-app.spec.ts new file mode 100644 index 00000000..2fd6016f --- /dev/null +++ b/tests-examples/demo-todo-app.spec.ts @@ -0,0 +1,437 @@ +import { test, expect, type Page } from '@playwright/test'; + +test.beforeEach(async ({ page }) => { + await page.goto('https://demo.playwright.dev/todomvc'); +}); + +const TODO_ITEMS = [ + 'buy some cheese', + 'feed the cat', + 'book a doctors appointment' +]; + +test.describe('New Todo', () => { + test('should allow me to add todo items', async ({ page }) => { + // create a new todo locator + const newTodo = page.getByPlaceholder('What needs to be done?'); + + // Create 1st todo. + await newTodo.fill(TODO_ITEMS[0]); + await newTodo.press('Enter'); + + // Make sure the list only has one todo item. + await expect(page.getByTestId('todo-title')).toHaveText([ + TODO_ITEMS[0] + ]); + + // Create 2nd todo. + await newTodo.fill(TODO_ITEMS[1]); + await newTodo.press('Enter'); + + // Make sure the list now has two todo items. + await expect(page.getByTestId('todo-title')).toHaveText([ + TODO_ITEMS[0], + TODO_ITEMS[1] + ]); + + await checkNumberOfTodosInLocalStorage(page, 2); + }); + + test('should clear text input field when an item is added', async ({ page }) => { + // create a new todo locator + const newTodo = page.getByPlaceholder('What needs to be done?'); + + // Create one todo item. + await newTodo.fill(TODO_ITEMS[0]); + await newTodo.press('Enter'); + + // Check that input is empty. + await expect(newTodo).toBeEmpty(); + await checkNumberOfTodosInLocalStorage(page, 1); + }); + + test('should append new items to the bottom of the list', async ({ page }) => { + // Create 3 items. + await createDefaultTodos(page); + + // create a todo count locator + const todoCount = page.getByTestId('todo-count') + + // Check test using different methods. + await expect(page.getByText('3 items left')).toBeVisible(); + await expect(todoCount).toHaveText('3 items left'); + await expect(todoCount).toContainText('3'); + await expect(todoCount).toHaveText(/3/); + + // Check all items in one call. + await expect(page.getByTestId('todo-title')).toHaveText(TODO_ITEMS); + await checkNumberOfTodosInLocalStorage(page, 3); + }); +}); + +test.describe('Mark all as completed', () => { + test.beforeEach(async ({ page }) => { + await createDefaultTodos(page); + await checkNumberOfTodosInLocalStorage(page, 3); + }); + + test.afterEach(async ({ page }) => { + await checkNumberOfTodosInLocalStorage(page, 3); + }); + + test('should allow me to mark all items as completed', async ({ page }) => { + // Complete all todos. + await page.getByLabel('Mark all as complete').check(); + + // Ensure all todos have 'completed' class. + await expect(page.getByTestId('todo-item')).toHaveClass(['completed', 'completed', 'completed']); + await checkNumberOfCompletedTodosInLocalStorage(page, 3); + }); + + test('should allow me to clear the complete state of all items', async ({ page }) => { + const toggleAll = page.getByLabel('Mark all as complete'); + // Check and then immediately uncheck. + await toggleAll.check(); + await toggleAll.uncheck(); + + // Should be no completed classes. + await expect(page.getByTestId('todo-item')).toHaveClass(['', '', '']); + }); + + test('complete all checkbox should update state when items are completed / cleared', async ({ page }) => { + const toggleAll = page.getByLabel('Mark all as complete'); + await toggleAll.check(); + await expect(toggleAll).toBeChecked(); + await checkNumberOfCompletedTodosInLocalStorage(page, 3); + + // Uncheck first todo. + const firstTodo = page.getByTestId('todo-item').nth(0); + await firstTodo.getByRole('checkbox').uncheck(); + + // Reuse toggleAll locator and make sure its not checked. + await expect(toggleAll).not.toBeChecked(); + + await firstTodo.getByRole('checkbox').check(); + await checkNumberOfCompletedTodosInLocalStorage(page, 3); + + // Assert the toggle all is checked again. + await expect(toggleAll).toBeChecked(); + }); +}); + +test.describe('Item', () => { + + test('should allow me to mark items as complete', async ({ page }) => { + // create a new todo locator + const newTodo = page.getByPlaceholder('What needs to be done?'); + + // Create two items. + for (const item of TODO_ITEMS.slice(0, 2)) { + await newTodo.fill(item); + await newTodo.press('Enter'); + } + + // Check first item. + const firstTodo = page.getByTestId('todo-item').nth(0); + await firstTodo.getByRole('checkbox').check(); + await expect(firstTodo).toHaveClass('completed'); + + // Check second item. + const secondTodo = page.getByTestId('todo-item').nth(1); + await expect(secondTodo).not.toHaveClass('completed'); + await secondTodo.getByRole('checkbox').check(); + + // Assert completed class. + await expect(firstTodo).toHaveClass('completed'); + await expect(secondTodo).toHaveClass('completed'); + }); + + test('should allow me to un-mark items as complete', async ({ page }) => { + // create a new todo locator + const newTodo = page.getByPlaceholder('What needs to be done?'); + + // Create two items. + for (const item of TODO_ITEMS.slice(0, 2)) { + await newTodo.fill(item); + await newTodo.press('Enter'); + } + + const firstTodo = page.getByTestId('todo-item').nth(0); + const secondTodo = page.getByTestId('todo-item').nth(1); + const firstTodoCheckbox = firstTodo.getByRole('checkbox'); + + await firstTodoCheckbox.check(); + await expect(firstTodo).toHaveClass('completed'); + await expect(secondTodo).not.toHaveClass('completed'); + await checkNumberOfCompletedTodosInLocalStorage(page, 1); + + await firstTodoCheckbox.uncheck(); + await expect(firstTodo).not.toHaveClass('completed'); + await expect(secondTodo).not.toHaveClass('completed'); + await checkNumberOfCompletedTodosInLocalStorage(page, 0); + }); + + test('should allow me to edit an item', async ({ page }) => { + await createDefaultTodos(page); + + const todoItems = page.getByTestId('todo-item'); + const secondTodo = todoItems.nth(1); + await secondTodo.dblclick(); + await expect(secondTodo.getByRole('textbox', { name: 'Edit' })).toHaveValue(TODO_ITEMS[1]); + await secondTodo.getByRole('textbox', { name: 'Edit' }).fill('buy some sausages'); + await secondTodo.getByRole('textbox', { name: 'Edit' }).press('Enter'); + + // Explicitly assert the new text value. + await expect(todoItems).toHaveText([ + TODO_ITEMS[0], + 'buy some sausages', + TODO_ITEMS[2] + ]); + await checkTodosInLocalStorage(page, 'buy some sausages'); + }); +}); + +test.describe('Editing', () => { + test.beforeEach(async ({ page }) => { + await createDefaultTodos(page); + await checkNumberOfTodosInLocalStorage(page, 3); + }); + + test('should hide other controls when editing', async ({ page }) => { + const todoItem = page.getByTestId('todo-item').nth(1); + await todoItem.dblclick(); + await expect(todoItem.getByRole('checkbox')).not.toBeVisible(); + await expect(todoItem.locator('label', { + hasText: TODO_ITEMS[1], + })).not.toBeVisible(); + await checkNumberOfTodosInLocalStorage(page, 3); + }); + + test('should save edits on blur', async ({ page }) => { + const todoItems = page.getByTestId('todo-item'); + await todoItems.nth(1).dblclick(); + await todoItems.nth(1).getByRole('textbox', { name: 'Edit' }).fill('buy some sausages'); + await todoItems.nth(1).getByRole('textbox', { name: 'Edit' }).dispatchEvent('blur'); + + await expect(todoItems).toHaveText([ + TODO_ITEMS[0], + 'buy some sausages', + TODO_ITEMS[2], + ]); + await checkTodosInLocalStorage(page, 'buy some sausages'); + }); + + test('should trim entered text', async ({ page }) => { + const todoItems = page.getByTestId('todo-item'); + await todoItems.nth(1).dblclick(); + await todoItems.nth(1).getByRole('textbox', { name: 'Edit' }).fill(' buy some sausages '); + await todoItems.nth(1).getByRole('textbox', { name: 'Edit' }).press('Enter'); + + await expect(todoItems).toHaveText([ + TODO_ITEMS[0], + 'buy some sausages', + TODO_ITEMS[2], + ]); + await checkTodosInLocalStorage(page, 'buy some sausages'); + }); + + test('should remove the item if an empty text string was entered', async ({ page }) => { + const todoItems = page.getByTestId('todo-item'); + await todoItems.nth(1).dblclick(); + await todoItems.nth(1).getByRole('textbox', { name: 'Edit' }).fill(''); + await todoItems.nth(1).getByRole('textbox', { name: 'Edit' }).press('Enter'); + + await expect(todoItems).toHaveText([ + TODO_ITEMS[0], + TODO_ITEMS[2], + ]); + }); + + test('should cancel edits on escape', async ({ page }) => { + const todoItems = page.getByTestId('todo-item'); + await todoItems.nth(1).dblclick(); + await todoItems.nth(1).getByRole('textbox', { name: 'Edit' }).fill('buy some sausages'); + await todoItems.nth(1).getByRole('textbox', { name: 'Edit' }).press('Escape'); + await expect(todoItems).toHaveText(TODO_ITEMS); + }); +}); + +test.describe('Counter', () => { + test('should display the current number of todo items', async ({ page }) => { + // create a new todo locator + const newTodo = page.getByPlaceholder('What needs to be done?'); + + // create a todo count locator + const todoCount = page.getByTestId('todo-count') + + await newTodo.fill(TODO_ITEMS[0]); + await newTodo.press('Enter'); + + await expect(todoCount).toContainText('1'); + + await newTodo.fill(TODO_ITEMS[1]); + await newTodo.press('Enter'); + await expect(todoCount).toContainText('2'); + + await checkNumberOfTodosInLocalStorage(page, 2); + }); +}); + +test.describe('Clear completed button', () => { + test.beforeEach(async ({ page }) => { + await createDefaultTodos(page); + }); + + test('should display the correct text', async ({ page }) => { + await page.locator('.todo-list li .toggle').first().check(); + await expect(page.getByRole('button', { name: 'Clear completed' })).toBeVisible(); + }); + + test('should remove completed items when clicked', async ({ page }) => { + const todoItems = page.getByTestId('todo-item'); + await todoItems.nth(1).getByRole('checkbox').check(); + await page.getByRole('button', { name: 'Clear completed' }).click(); + await expect(todoItems).toHaveCount(2); + await expect(todoItems).toHaveText([TODO_ITEMS[0], TODO_ITEMS[2]]); + }); + + test('should be hidden when there are no items that are completed', async ({ page }) => { + await page.locator('.todo-list li .toggle').first().check(); + await page.getByRole('button', { name: 'Clear completed' }).click(); + await expect(page.getByRole('button', { name: 'Clear completed' })).toBeHidden(); + }); +}); + +test.describe('Persistence', () => { + test('should persist its data', async ({ page }) => { + // create a new todo locator + const newTodo = page.getByPlaceholder('What needs to be done?'); + + for (const item of TODO_ITEMS.slice(0, 2)) { + await newTodo.fill(item); + await newTodo.press('Enter'); + } + + const todoItems = page.getByTestId('todo-item'); + const firstTodoCheck = todoItems.nth(0).getByRole('checkbox'); + await firstTodoCheck.check(); + await expect(todoItems).toHaveText([TODO_ITEMS[0], TODO_ITEMS[1]]); + await expect(firstTodoCheck).toBeChecked(); + await expect(todoItems).toHaveClass(['completed', '']); + + // Ensure there is 1 completed item. + await checkNumberOfCompletedTodosInLocalStorage(page, 1); + + // Now reload. + await page.reload(); + await expect(todoItems).toHaveText([TODO_ITEMS[0], TODO_ITEMS[1]]); + await expect(firstTodoCheck).toBeChecked(); + await expect(todoItems).toHaveClass(['completed', '']); + }); +}); + +test.describe('Routing', () => { + test.beforeEach(async ({ page }) => { + await createDefaultTodos(page); + // make sure the app had a chance to save updated todos in storage + // before navigating to a new view, otherwise the items can get lost :( + // in some frameworks like Durandal + await checkTodosInLocalStorage(page, TODO_ITEMS[0]); + }); + + test('should allow me to display active items', async ({ page }) => { + const todoItem = page.getByTestId('todo-item'); + await page.getByTestId('todo-item').nth(1).getByRole('checkbox').check(); + + await checkNumberOfCompletedTodosInLocalStorage(page, 1); + await page.getByRole('link', { name: 'Active' }).click(); + await expect(todoItem).toHaveCount(2); + await expect(todoItem).toHaveText([TODO_ITEMS[0], TODO_ITEMS[2]]); + }); + + test('should respect the back button', async ({ page }) => { + const todoItem = page.getByTestId('todo-item'); + await page.getByTestId('todo-item').nth(1).getByRole('checkbox').check(); + + await checkNumberOfCompletedTodosInLocalStorage(page, 1); + + await test.step('Showing all items', async () => { + await page.getByRole('link', { name: 'All' }).click(); + await expect(todoItem).toHaveCount(3); + }); + + await test.step('Showing active items', async () => { + await page.getByRole('link', { name: 'Active' }).click(); + }); + + await test.step('Showing completed items', async () => { + await page.getByRole('link', { name: 'Completed' }).click(); + }); + + await expect(todoItem).toHaveCount(1); + await page.goBack(); + await expect(todoItem).toHaveCount(2); + await page.goBack(); + await expect(todoItem).toHaveCount(3); + }); + + test('should allow me to display completed items', async ({ page }) => { + await page.getByTestId('todo-item').nth(1).getByRole('checkbox').check(); + await checkNumberOfCompletedTodosInLocalStorage(page, 1); + await page.getByRole('link', { name: 'Completed' }).click(); + await expect(page.getByTestId('todo-item')).toHaveCount(1); + }); + + test('should allow me to display all items', async ({ page }) => { + await page.getByTestId('todo-item').nth(1).getByRole('checkbox').check(); + await checkNumberOfCompletedTodosInLocalStorage(page, 1); + await page.getByRole('link', { name: 'Active' }).click(); + await page.getByRole('link', { name: 'Completed' }).click(); + await page.getByRole('link', { name: 'All' }).click(); + await expect(page.getByTestId('todo-item')).toHaveCount(3); + }); + + test('should highlight the currently applied filter', async ({ page }) => { + await expect(page.getByRole('link', { name: 'All' })).toHaveClass('selected'); + + //create locators for active and completed links + const activeLink = page.getByRole('link', { name: 'Active' }); + const completedLink = page.getByRole('link', { name: 'Completed' }); + await activeLink.click(); + + // Page change - active items. + await expect(activeLink).toHaveClass('selected'); + await completedLink.click(); + + // Page change - completed items. + await expect(completedLink).toHaveClass('selected'); + }); +}); + +async function createDefaultTodos(page: Page) { + // create a new todo locator + const newTodo = page.getByPlaceholder('What needs to be done?'); + + for (const item of TODO_ITEMS) { + await newTodo.fill(item); + await newTodo.press('Enter'); + } +} + +async function checkNumberOfTodosInLocalStorage(page: Page, expected: number) { + return await page.waitForFunction(e => { + return JSON.parse(localStorage['react-todos']).length === e; + }, expected); +} + +async function checkNumberOfCompletedTodosInLocalStorage(page: Page, expected: number) { + return await page.waitForFunction(e => { + return JSON.parse(localStorage['react-todos']).filter((todo: any) => todo.completed).length === e; + }, expected); +} + +async function checkTodosInLocalStorage(page: Page, title: string) { + return await page.waitForFunction(t => { + return JSON.parse(localStorage['react-todos']).map((todo: any) => todo.title).includes(t); + }, title); +} From 8c87d930991da7f9be6ac05036ae1687688cb926 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 23 Feb 2024 22:58:09 -0600 Subject: [PATCH 05/74] add docker debug file with provisioning --- docker-compose-debug.yaml | 29 +++++++++++++++++++++++++++++ grafana/datasource.yml | 15 +++++++++++++++ prometheus/prometheus.yml | 21 +++++++++++++++++++++ provisioning/datasources.yml | 8 ++++++++ 4 files changed, 73 insertions(+) create mode 100644 docker-compose-debug.yaml create mode 100644 grafana/datasource.yml create mode 100644 prometheus/prometheus.yml create mode 100644 provisioning/datasources.yml diff --git a/docker-compose-debug.yaml b/docker-compose-debug.yaml new file mode 100644 index 00000000..a33fb0cb --- /dev/null +++ b/docker-compose-debug.yaml @@ -0,0 +1,29 @@ +version: "0.1" +services: + prometheus: + image: prom/prometheus + container_name: prometheus-debug + command: + - '--config.file=/etc/prometheus/prometheus.yml' + ports: + - 9090:9090 + restart: unless-stopped + volumes: + - ./prometheus:/etc/prometheus + - prom_data:/prometheus + grafana: + image: grafana/grafana-enterprise:${GF_VERSION:-main} + container_name: grafana-prometheus-amazon-debug + ports: + - 3000:3000 + restart: unless-stopped + environment: + - GF_DEFAULT_APP_MODE=development + - GF_AUTH_ANONYMOUS_ORG_ROLE=Admin + - GF_AUTH_ANONYMOUS_ENABLED=true + - GF_AUTH_BASIC_ENABLED=false + volumes: + - ./grafana:/etc/grafana/provisioning/datasources + - ./dist:/var/lib/grafana/plugins/prometheus-amazon +volumes: + prom_data: \ No newline at end of file diff --git a/grafana/datasource.yml b/grafana/datasource.yml new file mode 100644 index 00000000..447841db --- /dev/null +++ b/grafana/datasource.yml @@ -0,0 +1,15 @@ +apiVersion: 1 + +datasources: +# - name: Prometheus +# type: prometheus +# url: http://prometheus:9090 +# isDefault: true +# access: proxy +# editable: true + +- name: Prometheus-amazon + type: prometheus-amazon-datasource + url: http://prometheus:9090 + access: proxy + editable: true \ No newline at end of file diff --git a/prometheus/prometheus.yml b/prometheus/prometheus.yml new file mode 100644 index 00000000..18c44da7 --- /dev/null +++ b/prometheus/prometheus.yml @@ -0,0 +1,21 @@ +global: + scrape_interval: 15s + scrape_timeout: 10s + evaluation_interval: 15s +alerting: + alertmanagers: + - static_configs: + - targets: [] + scheme: http + timeout: 10s + api_version: v1 +scrape_configs: +- job_name: prometheus + honor_timestamps: true + scrape_interval: 15s + scrape_timeout: 10s + metrics_path: /metrics + scheme: http + static_configs: + - targets: + - localhost:9090 \ No newline at end of file diff --git a/provisioning/datasources.yml b/provisioning/datasources.yml new file mode 100644 index 00000000..a6f7fd48 --- /dev/null +++ b/provisioning/datasources.yml @@ -0,0 +1,8 @@ +apiVersion: 1 + +datasources: +- name: Prometheus-amazon + type: prometheus-amazon-datasource + url: http://prometheus:9090 + access: proxy + editable: true \ No newline at end of file From 748f079cbabcd7ef475d1235838bb4062d5dcec2 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 23 Feb 2024 23:00:55 -0600 Subject: [PATCH 06/74] update provisioning for docker --- docker-compose-debug.yaml | 2 +- grafana/datasource.yml | 15 --------------- 2 files changed, 1 insertion(+), 16 deletions(-) delete mode 100644 grafana/datasource.yml diff --git a/docker-compose-debug.yaml b/docker-compose-debug.yaml index a33fb0cb..f4a54772 100644 --- a/docker-compose-debug.yaml +++ b/docker-compose-debug.yaml @@ -23,7 +23,7 @@ services: - GF_AUTH_ANONYMOUS_ENABLED=true - GF_AUTH_BASIC_ENABLED=false volumes: - - ./grafana:/etc/grafana/provisioning/datasources + - ./provisioning:/etc/grafana/provisioning/datasources - ./dist:/var/lib/grafana/plugins/prometheus-amazon volumes: prom_data: \ No newline at end of file diff --git a/grafana/datasource.yml b/grafana/datasource.yml deleted file mode 100644 index 447841db..00000000 --- a/grafana/datasource.yml +++ /dev/null @@ -1,15 +0,0 @@ -apiVersion: 1 - -datasources: -# - name: Prometheus -# type: prometheus -# url: http://prometheus:9090 -# isDefault: true -# access: proxy -# editable: true - -- name: Prometheus-amazon - type: prometheus-amazon-datasource - url: http://prometheus:9090 - access: proxy - editable: true \ No newline at end of file From 2a40343fd0e239e0d58477652a555f0e585d799e Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 23 Feb 2024 23:02:00 -0600 Subject: [PATCH 07/74] update grafana deps with actual versions --- package.json | 14 +++--- yarn.lock | 126 +++++++++++++++++++++++++++------------------------ 2 files changed, 75 insertions(+), 65 deletions(-) diff --git a/package.json b/package.json index 81e65abb..315aab5e 100644 --- a/package.json +++ b/package.json @@ -19,8 +19,8 @@ "license": "Apache-2.0", "devDependencies": { "@emotion/eslint-plugin": "11.11.0", - "@grafana/e2e": "11.0.0-pre", - "@grafana/e2e-selectors": "11.0.0-pre", + "@grafana/e2e": "11.0.0-162805", + "@grafana/e2e-selectors": "11.0.0-162805", "@grafana/eslint-config": "6.0.1", "@grafana/plugin-e2e": "0.17.1", "@grafana/tsconfig": "1.3.0-rc1", @@ -94,13 +94,13 @@ "dependencies": { "@emotion/css": "11.11.2", "@grafana/aws-sdk": "0.3.1", - "@grafana/data": "11.0.0-pre", + "@grafana/data": "11.0.0-162805", "@grafana/experimental": "1.7.10", "@grafana/faro-web-sdk": "^1.3.6", - "@grafana/prometheus": "11.0.0-pre", - "@grafana/runtime": "11.0.0-pre", - "@grafana/schema": "11.0.0-pre", - "@grafana/ui": "11.0.0-pre", + "@grafana/prometheus": "11.0.0-162805", + "@grafana/runtime": "11.0.0-162805", + "@grafana/schema": "11.0.0-162805", + "@grafana/ui": "11.0.0-162805", "@leeoniya/ufuzzy": "1.0.14", "@lezer/common": "1.2.1", "@lezer/highlight": "1.2.0", diff --git a/yarn.lock b/yarn.lock index 870a16c0..ee3fc933 100644 --- a/yarn.lock +++ b/yarn.lock @@ -931,6 +931,13 @@ dependencies: regenerator-runtime "^0.14.0" +"@babel/runtime@^7.23.9": + version "7.23.9" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.23.9.tgz#47791a15e4603bb5f905bc0753801cf21d6345f7" + integrity sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw== + dependencies: + regenerator-runtime "^0.14.0" + "@babel/template@^7.22.15", "@babel/template@^7.22.5", "@babel/template@^7.3.3": version "7.22.15" resolved "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz" @@ -1347,13 +1354,13 @@ "@grafana/async-query-data" "0.1.4" "@grafana/experimental" "1.7.0" -"@grafana/data@11.0.0-162094", "@grafana/data@11.0.0-pre": - version "11.0.0-162094" - resolved "https://registry.yarnpkg.com/@grafana/data/-/data-11.0.0-162094.tgz#16cb9ab721dbca52b7ac8b13152b7ec98f442529" - integrity sha512-Czl8IKRauiDrGd1Bv6a0PUROifsS6TkqPqMd7QlkDJWtZCuxRcasrqxsvVH2OITPmw+cmH/Q7gkk5RpaBF1BQA== +"@grafana/data@11.0.0-162805": + version "11.0.0-162805" + resolved "https://registry.yarnpkg.com/@grafana/data/-/data-11.0.0-162805.tgz#41556a613ea43e646ecc34c0859553fd67a5284d" + integrity sha512-sy9wvym6pFQ81twAKxVG3BOefziPkp6AT5GoRaZt3w74AII30Oyq9ldZwFYhiryMBl1MOwgeCPYEfdRSEmDIrg== dependencies: "@braintree/sanitize-url" "7.0.0" - "@grafana/schema" "11.0.0-162094" + "@grafana/schema" "11.0.0-162805" "@types/d3-interpolate" "^3.0.0" "@types/string-hash" "1.1.3" d3-interpolate "3.0.1" @@ -1378,26 +1385,26 @@ uplot "1.6.30" xss "^1.0.14" -"@grafana/e2e-selectors@11.0.0-162094", "@grafana/e2e-selectors@11.0.0-pre": - version "11.0.0-162094" - resolved "https://registry.yarnpkg.com/@grafana/e2e-selectors/-/e2e-selectors-11.0.0-162094.tgz#8f5b538adaf9e79d4f4776c3fc9dfcc5a933b1db" - integrity sha512-n3+OmRvpRixc34yNGa+ifSRLshPpC1vmIKnkk6Sqcj+O1dd/E0lOJMipAiQmXV+jg7LXIyiRiGqelYmE1kcG7w== +"@grafana/e2e-selectors@11.0.0-162805": + version "11.0.0-162805" + resolved "https://registry.yarnpkg.com/@grafana/e2e-selectors/-/e2e-selectors-11.0.0-162805.tgz#f77abe718f779a42633cd5f7c339dea06060ba5a" + integrity sha512-JDAFwmFSkVNRra8UCH33wwatZyLC1qcrhpjl7augZMwYlLp2RZphObIAKKIE5GJKy9MTOgpo+0JWLEbCEs281A== dependencies: - "@grafana/tsconfig" "^1.2.0-rc1" + "@grafana/tsconfig" "^1.3.0-rc1" tslib "2.6.2" typescript "5.3.3" -"@grafana/e2e@11.0.0-pre": - version "11.0.0-162094" - resolved "https://registry.yarnpkg.com/@grafana/e2e/-/e2e-11.0.0-162094.tgz#c0eadf2fc244ca1e6f87d085c4444410a5aaeba9" - integrity sha512-52HBe3nxdi+vWlKjFPg2ttarnCCdTKZQKtMvnzyTzNgdumketZ4xVvjP6+LLrP2hKecqMKPhoVUKH5bTc+ofRA== +"@grafana/e2e@11.0.0-162805": + version "11.0.0-162805" + resolved "https://registry.yarnpkg.com/@grafana/e2e/-/e2e-11.0.0-162805.tgz#a9da13fdafe72fea81b130ed8a7a5142071d8b4f" + integrity sha512-TIt4xCkt2Fuilsi3/ghVBAWDdVpDLJsU5LFzgzSD/vXd/FKxyeJvD1awz0oJSO2Iz9s+gURSg6IsTC8pkA6ChA== dependencies: "@babel/core" "7.23.2" "@babel/preset-env" "7.23.2" "@cypress/webpack-preprocessor" "5.17.1" - "@grafana/e2e-selectors" "11.0.0-162094" - "@grafana/schema" "11.0.0-162094" - "@grafana/tsconfig" "^1.2.0-rc1" + "@grafana/e2e-selectors" "11.0.0-162805" + "@grafana/schema" "11.0.0-162805" + "@grafana/tsconfig" "^1.3.0-rc1" "@mochajs/json-file-reporter" "^1.2.0" babel-loader "9.1.3" blink-diff "1.0.13" @@ -1480,19 +1487,19 @@ uuid "^9.0.1" yaml "^2.3.4" -"@grafana/prometheus@11.0.0-pre": - version "11.0.0-162094" - resolved "https://registry.yarnpkg.com/@grafana/prometheus/-/prometheus-11.0.0-162094.tgz#0b3523cc53b3a8160e48a928cecdb1f5ee500e38" - integrity sha512-I+e3P7STmFgxZ/STySr4I0gt188D5w8gJ11flI51/TVq/H637xOQDh/ZLxPYcfnzi4mMQDmvlRAWv7skkg5QWQ== +"@grafana/prometheus@11.0.0-162805": + version "11.0.0-162805" + resolved "https://registry.yarnpkg.com/@grafana/prometheus/-/prometheus-11.0.0-162805.tgz#2b250d99e493e9ae2c81b26b697fc4167e1ed79a" + integrity sha512-Wb/SP4h+2yYVqFUlgrnD9AM8E6jNx5lSGgxsJJclRv9GkkxK+T44thWGAhrWRuNKD47JKcQCsPmCGVQONBY+2A== dependencies: "@emotion/css" "11.11.2" "@floating-ui/react" "0.26.9" - "@grafana/data" "11.0.0-162094" + "@grafana/data" "11.0.0-162805" "@grafana/experimental" "1.7.10" "@grafana/faro-web-sdk" "1.3.8" - "@grafana/runtime" "11.0.0-162094" - "@grafana/schema" "11.0.0-162094" - "@grafana/ui" "11.0.0-162094" + "@grafana/runtime" "11.0.0-162805" + "@grafana/schema" "11.0.0-162805" + "@grafana/ui" "11.0.0-162805" "@leeoniya/ufuzzy" "1.0.14" "@lezer/common" "1.2.1" "@lezer/highlight" "1.2.0" @@ -1523,16 +1530,16 @@ uuid "9.0.1" whatwg-fetch "3.6.20" -"@grafana/runtime@11.0.0-162094", "@grafana/runtime@11.0.0-pre": - version "11.0.0-162094" - resolved "https://registry.yarnpkg.com/@grafana/runtime/-/runtime-11.0.0-162094.tgz#866a6caf6227b898881468351a8c82f2514efa52" - integrity sha512-H7tbo+MQUoLeEGgSrQ272OfaKKc2XRn3/qWS2Ii8mg80bVhBItDoMiwWnkm2i7knNwngFcT2m5Bkbnv/sdeoPA== +"@grafana/runtime@11.0.0-162805": + version "11.0.0-162805" + resolved "https://registry.yarnpkg.com/@grafana/runtime/-/runtime-11.0.0-162805.tgz#84faa280ff9289ee9bbd31928a8f39ec733a3767" + integrity sha512-wxz0Aja+J997S18rcEwxT6N+vL1JO3WGK1CELwC4Xj8/tOVMpisT9NK65hjdk1mbncsPJzngYzPylkQDpiL1PA== dependencies: - "@grafana/data" "11.0.0-162094" - "@grafana/e2e-selectors" "11.0.0-162094" + "@grafana/data" "11.0.0-162805" + "@grafana/e2e-selectors" "11.0.0-162805" "@grafana/faro-web-sdk" "^1.3.6" - "@grafana/schema" "11.0.0-162094" - "@grafana/ui" "11.0.0-162094" + "@grafana/schema" "11.0.0-162805" + "@grafana/ui" "11.0.0-162805" history "4.10.1" lodash "4.17.21" rxjs "7.8.1" @@ -1540,35 +1547,30 @@ systemjs-cjs-extra "0.2.0" tslib "2.6.2" -"@grafana/schema@11.0.0-162094", "@grafana/schema@11.0.0-pre": - version "11.0.0-162094" - resolved "https://registry.yarnpkg.com/@grafana/schema/-/schema-11.0.0-162094.tgz#43518f9c775b4d441e11ac23cfdaea30b4c127f3" - integrity sha512-EWYBkqlyAAteerfGmJFljEC4uQGSwnhHpDWFy1MK5LE/NhMK/MfmX976WftQMh18RymEm0sdpZwQj9BngLku3Q== +"@grafana/schema@11.0.0-162805": + version "11.0.0-162805" + resolved "https://registry.yarnpkg.com/@grafana/schema/-/schema-11.0.0-162805.tgz#c00d81c04b3fe8072df5bddc943000e95b79487c" + integrity sha512-2BL7v0JHUxzVLVSPwjyRxQa9PJ6AN/7tt2l3g+bK3lg2otCgomJscKa94HkTfQV/+hGcHGfYT0sMVqjId0sJnQ== dependencies: tslib "2.6.2" -"@grafana/tsconfig@1.3.0-rc1": +"@grafana/tsconfig@1.3.0-rc1", "@grafana/tsconfig@^1.3.0-rc1": version "1.3.0-rc1" - resolved "https://registry.npmjs.org/@grafana/tsconfig/-/tsconfig-1.3.0-rc1.tgz" + resolved "https://registry.yarnpkg.com/@grafana/tsconfig/-/tsconfig-1.3.0-rc1.tgz#ca5ffa03edb3cb59bd503a7e6b3a3e15ac528d77" integrity sha512-bi+qFOptejg/a2/WmCDVxQLQtobhKd3y+B6mxFBOMmzElqgr30MPnN60THTou6dGwtfw+ExX1H5FGm9DM35Qrw== -"@grafana/tsconfig@^1.2.0-rc1": - version "1.2.0-rc1" - resolved "https://registry.npmjs.org/@grafana/tsconfig/-/tsconfig-1.2.0-rc1.tgz" - integrity sha512-+SgQeBQ1pT6D/E3/dEdADqTrlgdIGuexUZ8EU+8KxQFKUeFeU7/3z/ayI2q/wpJ/Kr6WxBBNlrST6aOKia19Ag== - -"@grafana/ui@11.0.0-162094", "@grafana/ui@11.0.0-pre": - version "11.0.0-162094" - resolved "https://registry.yarnpkg.com/@grafana/ui/-/ui-11.0.0-162094.tgz#adfc7fab0a755982d2cbeeb0989b10cb7ee89963" - integrity sha512-52hP39yD9M3v5L1hkuCq9T4p0H5M/YMVEXmO1Na8KnuB3+a5B2OnW7KJqTTfzDWskhKc/zwfs1RYo+LN9lCjog== +"@grafana/ui@11.0.0-162805": + version "11.0.0-162805" + resolved "https://registry.yarnpkg.com/@grafana/ui/-/ui-11.0.0-162805.tgz#726e0a1978fb5e1425e648264dadf22d83fb1897" + integrity sha512-asc+IAOpP15B5uUDhaNyy5gOPD74tRjtggtvivTcWi3oyEPZITkKDXtKqSQrh/opXgDPB1onuWW0q7hj6HZfMA== dependencies: "@emotion/css" "11.11.2" "@emotion/react" "11.11.3" "@floating-ui/react" "0.26.9" - "@grafana/data" "11.0.0-162094" - "@grafana/e2e-selectors" "11.0.0-162094" + "@grafana/data" "11.0.0-162805" + "@grafana/e2e-selectors" "11.0.0-162805" "@grafana/faro-web-sdk" "^1.3.6" - "@grafana/schema" "11.0.0-162094" + "@grafana/schema" "11.0.0-162805" "@leeoniya/ufuzzy" "1.0.14" "@monaco-editor/react" "4.6.0" "@popperjs/core" "2.11.8" @@ -1594,7 +1596,7 @@ ol "7.4.0" prismjs "1.29.0" rc-cascader "3.21.2" - rc-drawer "6.5.2" + rc-drawer "7.1.0" rc-slider "10.5.0" rc-time-picker "^3.7.3" rc-tooltip "6.1.3" @@ -9235,16 +9237,16 @@ rc-cascader@3.21.2: rc-tree "~5.8.1" rc-util "^5.37.0" -rc-drawer@6.5.2: - version "6.5.2" - resolved "https://registry.npmjs.org/rc-drawer/-/rc-drawer-6.5.2.tgz" - integrity sha512-QckxAnQNdhh4vtmKN0ZwDf3iakO83W9eZcSKWYYTDv4qcD2fHhRAZJJ/OE6v2ZlQ2kSqCJX5gYssF4HJFvsEPQ== +rc-drawer@7.1.0: + version "7.1.0" + resolved "https://registry.yarnpkg.com/rc-drawer/-/rc-drawer-7.1.0.tgz#2beabb8bab1784aea255d0d850bc206c3dc715da" + integrity sha512-nBE1rF5iZvpavoyqhSSz2mk/yANltA7g3aF0U45xkx381n3we/RKs9cJfNKp9mSWCedOKWt9FLEwZDaAaOGn2w== dependencies: - "@babel/runtime" "^7.10.1" + "@babel/runtime" "^7.23.9" "@rc-component/portal" "^1.1.1" classnames "^2.2.6" rc-motion "^2.6.1" - rc-util "^5.36.0" + rc-util "^5.38.1" rc-motion@^2.0.0, rc-motion@^2.0.1, rc-motion@^2.6.1: version "2.9.0" @@ -9361,6 +9363,14 @@ rc-util@^5.16.1, rc-util@^5.21.0, rc-util@^5.24.4, rc-util@^5.27.0, rc-util@^5.3 "@babel/runtime" "^7.18.3" react-is "^18.2.0" +rc-util@^5.38.1: + version "5.38.2" + resolved "https://registry.yarnpkg.com/rc-util/-/rc-util-5.38.2.tgz#240da546b51ee838e616f7a2e3fcf62c753b0330" + integrity sha512-yRGRPKyi84H7NkRSP6FzEIYBdUt4ufdsmXUZ7qM2H5qoByPax70NnGPkfo36N+UKUnUBj2f2Q2eUbwYMuAsIOQ== + dependencies: + "@babel/runtime" "^7.18.3" + react-is "^18.2.0" + rc-virtual-list@^3.5.1, rc-virtual-list@^3.5.2: version "3.11.4" resolved "https://registry.npmjs.org/rc-virtual-list/-/rc-virtual-list-3.11.4.tgz" From 8c6c62438b64f22f2e3933d7fc8c973bcdbaef6b Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 23 Feb 2024 23:42:09 -0600 Subject: [PATCH 08/74] update provisioning for plugin-e2e tests --- docker-compose-debug.yaml | 2 +- docker-compose.yaml | 2 +- provisioning/{ => datasources}/datasources.yml | 0 3 files changed, 2 insertions(+), 2 deletions(-) rename provisioning/{ => datasources}/datasources.yml (100%) diff --git a/docker-compose-debug.yaml b/docker-compose-debug.yaml index f4a54772..c6cb9516 100644 --- a/docker-compose-debug.yaml +++ b/docker-compose-debug.yaml @@ -23,7 +23,7 @@ services: - GF_AUTH_ANONYMOUS_ENABLED=true - GF_AUTH_BASIC_ENABLED=false volumes: - - ./provisioning:/etc/grafana/provisioning/datasources + - ./provisioning/datasources:/etc/grafana/provisioning/datasources - ./dist:/var/lib/grafana/plugins/prometheus-amazon volumes: prom_data: \ No newline at end of file diff --git a/docker-compose.yaml b/docker-compose.yaml index aa7bb67e..a40fc1dc 100644 --- a/docker-compose.yaml +++ b/docker-compose.yaml @@ -12,4 +12,4 @@ services: - 3000:3000/tcp volumes: - ./dist:/var/lib/grafana/plugins/prometheus-amazon-datasource - - ./provisioning:/etc/grafana/provisioning + - ./provisioning/datasources:/etc/grafana/provisioning diff --git a/provisioning/datasources.yml b/provisioning/datasources/datasources.yml similarity index 100% rename from provisioning/datasources.yml rename to provisioning/datasources/datasources.yml From ba04e71f8ad013af58bf5a2afb11eb2edc2f3266 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 23 Feb 2024 23:42:43 -0600 Subject: [PATCH 09/74] begin setting up integration tests --- e2e/auth.setup.ts | 5 +++++ e2e/datasource.spec.ts | 7 +++++++ e2e/example.spec.ts | 18 ------------------ playwright.config.ts | 33 ++++++++++++++++++++++----------- playwright/.auth/admin.json | 25 +++++++++++++++++++++++++ 5 files changed, 59 insertions(+), 29 deletions(-) create mode 100644 e2e/auth.setup.ts create mode 100644 e2e/datasource.spec.ts delete mode 100644 e2e/example.spec.ts create mode 100644 playwright/.auth/admin.json diff --git a/e2e/auth.setup.ts b/e2e/auth.setup.ts new file mode 100644 index 00000000..42402bae --- /dev/null +++ b/e2e/auth.setup.ts @@ -0,0 +1,5 @@ +import { test as setup } from '@grafana/plugin-e2e'; + +setup('authenticate', async ({ login }) => { + await login(); +}); diff --git a/e2e/datasource.spec.ts b/e2e/datasource.spec.ts new file mode 100644 index 00000000..08e80cf6 --- /dev/null +++ b/e2e/datasource.spec.ts @@ -0,0 +1,7 @@ +import { test, expect } from '@grafana/plugin-e2e'; + +test('should expand multi-valued variable before calling backend', async ({ + readProvisionedDataSource, +}) => { + const datasource = readProvisionedDataSource({ fileName: 'datasources.yml' }); +}); diff --git a/e2e/example.spec.ts b/e2e/example.spec.ts deleted file mode 100644 index 54a906a4..00000000 --- a/e2e/example.spec.ts +++ /dev/null @@ -1,18 +0,0 @@ -import { test, expect } from '@playwright/test'; - -test('has title', async ({ page }) => { - await page.goto('https://playwright.dev/'); - - // Expect a title "to contain" a substring. - await expect(page).toHaveTitle(/Playwright/); -}); - -test('get started link', async ({ page }) => { - await page.goto('https://playwright.dev/'); - - // Click the get started link. - await page.getByRole('link', { name: 'Get started' }).click(); - - // Expects page to have a heading with the name of Installation. - await expect(page.getByRole('heading', { name: 'Installation' })).toBeVisible(); -}); diff --git a/playwright.config.ts b/playwright.config.ts index bfe3e830..252c614f 100644 --- a/playwright.config.ts +++ b/playwright.config.ts @@ -24,7 +24,7 @@ export default defineConfig({ /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */ use: { /* Base URL to use in actions like `await page.goto('/')`. */ - // baseURL: 'http://127.0.0.1:3000', + baseURL: 'http://127.0.0.1:3000', /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */ trace: 'on-first-retry', @@ -33,19 +33,30 @@ export default defineConfig({ /* Configure projects for major browsers */ projects: [ { - name: 'chromium', - use: { ...devices['Desktop Chrome'] }, + name: 'authenticate', + testMatch: [/.*auth\.setup\.ts/], }, - { - name: 'firefox', - use: { ...devices['Desktop Firefox'] }, + name: 'data source', + use: { ...devices['Desktop Chrome'], storageState: 'playwright/.auth/user.json' }, + dependencies: ['authenticate'], }, + ], + // projects: [ + // { + // name: 'chromium', + // use: { ...devices['Desktop Chrome'] }, + // }, - { - name: 'webkit', - use: { ...devices['Desktop Safari'] }, - }, + // { + // name: 'firefox', + // use: { ...devices['Desktop Firefox'] }, + // }, + + // { + // name: 'webkit', + // use: { ...devices['Desktop Safari'] }, + // }, /* Test against mobile viewports. */ // { @@ -66,7 +77,7 @@ export default defineConfig({ // name: 'Google Chrome', // use: { ...devices['Desktop Chrome'], channel: 'chrome' }, // }, - ], + // ], /* Run your local dev server before starting the tests */ // webServer: { diff --git a/playwright/.auth/admin.json b/playwright/.auth/admin.json new file mode 100644 index 00000000..b96d16b3 --- /dev/null +++ b/playwright/.auth/admin.json @@ -0,0 +1,25 @@ +{ + "cookies": [ + { + "name": "grafana_session", + "value": "e42895e2d3ca7a816c689d5522d362ed", + "domain": "127.0.0.1", + "path": "/", + "expires": 1711345094.305, + "httpOnly": true, + "secure": false, + "sameSite": "Lax" + }, + { + "name": "grafana_session_expiry", + "value": "1708753689", + "domain": "127.0.0.1", + "path": "/", + "expires": 1711345094.305, + "httpOnly": false, + "secure": false, + "sameSite": "Lax" + } + ], + "origins": [] +} \ No newline at end of file From 4cb61f04a16f625e82c941e0ca466a679a87e8e0 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 29 Feb 2024 11:21:43 -0600 Subject: [PATCH 10/74] update README with instructions for e2e tests --- README.md | 34 ++++++++++++++++++---------------- 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/README.md b/README.md index 57b09f97..e4becb13 100644 --- a/README.md +++ b/README.md @@ -1,10 +1,12 @@ -# Grafana data source plugin template +# Prometheus Amazon Data Source -This template is a starting point for building a Data Source Plugin for Grafana. +This data source plugin is is for Amazon Prometheus. It has all the features of the Grafana core Prometheus plugin with Amazon specific authentication in the configuration page. -## What are Grafana data source plugins? +Amazon Managed Service for Prometheus is a Prometheus-compatible service that monitors and provides alerts on containerized applications and infrastructure at scale. -Grafana supports a wide range of data sources, including Prometheus, MySQL, and even Datadog. There’s a good chance you can already visualize metrics from the systems you have set up. In some cases, though, you already have an in-house metrics solution that you’d like to add to your Grafana dashboards. Grafana Data Source Plugins enables integrating such solutions with Grafana. +Read more about it here: + +[https://aws.amazon.com/prometheus/](https://aws.amazon.com/prometheus/) ## Getting started @@ -33,55 +35,55 @@ Grafana supports a wide range of data sources, including Prometheus, MySQL, and 1. Install dependencies ```bash - npm install + yarn install ``` 2. Build plugin in development mode and run in watch mode ```bash - npm run dev + yarn run dev ``` 3. Build plugin in production mode ```bash - npm run build + yarn run build ``` 4. Run the tests (using Jest) ```bash # Runs the tests and watches for changes, requires git init first - npm run test + yarn run test # Exits after running all the tests - npm run test:ci + yarn run test:ci ``` 5. Spin up a Grafana instance and run the plugin inside it (using Docker) ```bash - npm run server + yarn run server ``` -6. Run the E2E tests (using Cypress) +6. Run the E2E tests (using Playwright and @grafana/plugin-e2e) ```bash - # Spins up a Grafana instance first that we tests against - npm run server + # Spins up a Grafana docker instance (port 3099) with an actual Prometheus instance (port 9090) + yarn run server # Starts the tests - npm run e2e + yarn run test:e2e ``` 7. Run the linter ```bash - npm run lint + yarn run lint # or - npm run lint:fix + yarn run lint:fix ``` From b7d76914207084675b95817fe1e1838a3ccba594 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 29 Feb 2024 11:22:35 -0600 Subject: [PATCH 11/74] update docker debug to use grafana port that does not interfere with other running grafana instances --- docker-compose-debug.yaml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/docker-compose-debug.yaml b/docker-compose-debug.yaml index c6cb9516..1c051141 100644 --- a/docker-compose-debug.yaml +++ b/docker-compose-debug.yaml @@ -15,13 +15,14 @@ services: image: grafana/grafana-enterprise:${GF_VERSION:-main} container_name: grafana-prometheus-amazon-debug ports: - - 3000:3000 + - 3099:3099 restart: unless-stopped environment: - GF_DEFAULT_APP_MODE=development - GF_AUTH_ANONYMOUS_ORG_ROLE=Admin - GF_AUTH_ANONYMOUS_ENABLED=true - GF_AUTH_BASIC_ENABLED=false + - GF_SERVER_HTTP_PORT=3099 volumes: - ./provisioning/datasources:/etc/grafana/provisioning/datasources - ./dist:/var/lib/grafana/plugins/prometheus-amazon From 987f7c92321abc2a1374df3394298ca8ecd02f3c Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 29 Feb 2024 11:24:35 -0600 Subject: [PATCH 12/74] remove playwright auth dependency as not needed because we are turning off basic auth in grafana docker --- e2e/auth.setup.ts | 5 ----- playwright.config.ts | 12 ++++++------ playwright/.auth/admin.json | 25 ------------------------- 3 files changed, 6 insertions(+), 36 deletions(-) delete mode 100644 e2e/auth.setup.ts delete mode 100644 playwright/.auth/admin.json diff --git a/e2e/auth.setup.ts b/e2e/auth.setup.ts deleted file mode 100644 index 42402bae..00000000 --- a/e2e/auth.setup.ts +++ /dev/null @@ -1,5 +0,0 @@ -import { test as setup } from '@grafana/plugin-e2e'; - -setup('authenticate', async ({ login }) => { - await login(); -}); diff --git a/playwright.config.ts b/playwright.config.ts index 252c614f..603a7f84 100644 --- a/playwright.config.ts +++ b/playwright.config.ts @@ -24,7 +24,7 @@ export default defineConfig({ /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */ use: { /* Base URL to use in actions like `await page.goto('/')`. */ - baseURL: 'http://127.0.0.1:3000', + baseURL: 'http://127.0.0.1:3099', /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */ trace: 'on-first-retry', @@ -32,14 +32,14 @@ export default defineConfig({ /* Configure projects for major browsers */ projects: [ - { - name: 'authenticate', - testMatch: [/.*auth\.setup\.ts/], - }, + // { + // name: 'authenticate', + // testMatch: [/.*auth\.setup\.ts/], + // }, { name: 'data source', use: { ...devices['Desktop Chrome'], storageState: 'playwright/.auth/user.json' }, - dependencies: ['authenticate'], + // dependencies: ['authenticate'], }, ], // projects: [ diff --git a/playwright/.auth/admin.json b/playwright/.auth/admin.json deleted file mode 100644 index b96d16b3..00000000 --- a/playwright/.auth/admin.json +++ /dev/null @@ -1,25 +0,0 @@ -{ - "cookies": [ - { - "name": "grafana_session", - "value": "e42895e2d3ca7a816c689d5522d362ed", - "domain": "127.0.0.1", - "path": "/", - "expires": 1711345094.305, - "httpOnly": true, - "secure": false, - "sameSite": "Lax" - }, - { - "name": "grafana_session_expiry", - "value": "1708753689", - "domain": "127.0.0.1", - "path": "/", - "expires": 1711345094.305, - "httpOnly": false, - "secure": false, - "sameSite": "Lax" - } - ], - "origins": [] -} \ No newline at end of file From dd9b24bdbbfbc9fe366fc41fc2ebdfc2ad689ef3 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 29 Feb 2024 11:25:15 -0600 Subject: [PATCH 13/74] add script for playwright e2e tests --- package.json | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/package.json b/package.json index 315aab5e..1ed563c1 100644 --- a/package.json +++ b/package.json @@ -6,12 +6,11 @@ "build": "webpack -c ./.config/webpack/webpack.config.ts --env production", "dev": "webpack -w -c ./.config/webpack/webpack.config.ts --env development", "test": "jest --watch --onlyChanged", + "test:e2e": "yarn playwright test", "test:ci": "jest --passWithNoTests --maxWorkers 4", "typecheck": "tsc --noEmit", "lint": "eslint --cache --ignore-path ./.gitignore --ext .js,.jsx,.ts,.tsx .", "lint:fix": "npm run lint -- --fix", - "e2e": "npm exec cypress install && npm exec grafana-e2e run", - "e2e:update": "npm exec cypress install && npm exec grafana-e2e run --update-screenshots", "server": "docker-compose up --build", "sign": "npx --yes @grafana/sign-plugin@latest" }, From 93255e4c14a8c4cb420cf7aa79dbc770d10cc1c5 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 1 Mar 2024 12:21:48 -0600 Subject: [PATCH 14/74] get playwright working and update readme --- README.md | 2 +- playwright.config.ts | 7 +------ 2 files changed, 2 insertions(+), 7 deletions(-) diff --git a/README.md b/README.md index e4becb13..fc63d9aa 100644 --- a/README.md +++ b/README.md @@ -70,7 +70,7 @@ Read more about it here: ```bash # Spins up a Grafana docker instance (port 3099) with an actual Prometheus instance (port 9090) - yarn run server + docker compose -f docker-compose-debug.yaml # Starts the tests yarn run test:e2e diff --git a/playwright.config.ts b/playwright.config.ts index 603a7f84..641c555a 100644 --- a/playwright.config.ts +++ b/playwright.config.ts @@ -32,14 +32,9 @@ export default defineConfig({ /* Configure projects for major browsers */ projects: [ - // { - // name: 'authenticate', - // testMatch: [/.*auth\.setup\.ts/], - // }, { name: 'data source', - use: { ...devices['Desktop Chrome'], storageState: 'playwright/.auth/user.json' }, - // dependencies: ['authenticate'], + use: { ...devices['Desktop Chrome']}, }, ], // projects: [ From 7f3c6d7b47e674a9fcf8ae1a3cdb628aeac8bf03 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 1 Mar 2024 12:22:18 -0600 Subject: [PATCH 15/74] add first configuration test --- e2e/configuration.spec.ts | 83 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 e2e/configuration.spec.ts diff --git a/e2e/configuration.spec.ts b/e2e/configuration.spec.ts new file mode 100644 index 00000000..c8472803 --- /dev/null +++ b/e2e/configuration.spec.ts @@ -0,0 +1,83 @@ +import { E2ESelectors, Selectors, selectors } from '@grafana/e2e-selectors'; +import { test, expect } from '@grafana/plugin-e2e'; + +test(`should have the following components: + connection settings + managed alerts + scrape interval + query timeout + default editor + disable metric lookup + prometheus type + cache level + incremental querying + disable recording rules + custom query parameters + http method +`, async ({ + createDataSourceConfigPage +}) => { + const configPage = await createDataSourceConfigPage({type: "prometheus-amazon-datasource", deleteDataSourceAfterTest: true}); + + // connection settings + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.connectionSettings) + .isVisible(); + // managed alerts + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.manageAlerts) + .isVisible(); + + // scrape interval + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.scrapeInterval) + .isVisible(); + + + // query timeout + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.queryTimeout) + .isVisible(); + + // default editor + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.defaultEditor) + .isVisible(); + + + // disable metric lookup + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.disableMetricLookup) + .isVisible(); + + // prometheus type + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.prometheusType) + .isVisible(); + + + // cache level + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.cacheLevel) + .isVisible(); + + // incremental querying + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.incrementalQuerying) + .isVisible(); + + // disable recording rules + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.disableRecordingRules) + .isVisible(); + + // custom query parameters + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.customQueryParameters) + .isVisible(); + + // http method + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.httpMethod) + .isVisible(); +}); From d9f56b0eca6b9896a4a576775f621519605b0800 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 1 Mar 2024 22:40:06 -0600 Subject: [PATCH 16/74] update config spec e2e tests --- e2e/configuration.spec.ts | 236 +++++++++++++++++++++++++------------- 1 file changed, 157 insertions(+), 79 deletions(-) diff --git a/e2e/configuration.spec.ts b/e2e/configuration.spec.ts index c8472803..4076f97d 100644 --- a/e2e/configuration.spec.ts +++ b/e2e/configuration.spec.ts @@ -1,83 +1,161 @@ +import { DataSourcePluginOptionsEditorProps } from '@grafana/data'; import { E2ESelectors, Selectors, selectors } from '@grafana/e2e-selectors'; import { test, expect } from '@grafana/plugin-e2e'; +import { PromOptions } from '@grafana/prometheus'; -test(`should have the following components: - connection settings - managed alerts - scrape interval - query timeout - default editor - disable metric lookup - prometheus type - cache level - incremental querying - disable recording rules - custom query parameters - http method -`, async ({ - createDataSourceConfigPage -}) => { - const configPage = await createDataSourceConfigPage({type: "prometheus-amazon-datasource", deleteDataSourceAfterTest: true}); - - // connection settings - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.connectionSettings) - .isVisible(); - // managed alerts - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.manageAlerts) - .isVisible(); - - // scrape interval - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.scrapeInterval) - .isVisible(); - - - // query timeout - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.queryTimeout) - .isVisible(); - - // default editor - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.defaultEditor) - .isVisible(); - - - // disable metric lookup - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.disableMetricLookup) - .isVisible(); - - // prometheus type - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.prometheusType) - .isVisible(); - - - // cache level - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.cacheLevel) - .isVisible(); - - // incremental querying - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.incrementalQuerying) - .isVisible(); - - // disable recording rules - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.disableRecordingRules) - .isVisible(); - - // custom query parameters - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.customQueryParameters) - .isVisible(); - - // http method - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.httpMethod) - .isVisible(); +const DATA_SOURCE_NAME = 'prometheus-config'; + +test.describe('Configuration tests', () => { + + test(`should have the following components: + connection settings + managed alerts + scrape interval + query timeout + default editor + disable metric lookup + prometheus type + cache level + incremental querying + disable recording rules + custom query parameters + http method + `, async ({ + createDataSourceConfigPage, + readProvisionedDataSource, + page, + }) => { + const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + const configPage = await createDataSourceConfigPage({type: ds.type, deleteDataSourceAfterTest: true}); + + // connection settings + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.connectionSettings) + .isVisible(); + + // managed alerts + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.manageAlerts) + .isVisible(); + + // scrape interval + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.scrapeInterval) + .isVisible(); + + // query timeout + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.queryTimeout) + .isVisible(); + + // default editor + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.defaultEditor) + .isVisible(); + + // disable metric lookup + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.disableMetricLookup) + .isVisible(); + + // prometheus type + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.prometheusType) + .isVisible(); + + // cache level + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.cacheLevel) + .isVisible(); + + // incremental querying + await page.locator(`#${selectors.components.DataSource.Prometheus.configPage.incrementalQuerying}`) + .isVisible(); + + // disable recording rules + await page.locator(`#${selectors.components.DataSource.Prometheus.configPage.disableRecordingRules}`) + .isVisible(); + + // custom query parameters + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.customQueryParameters) + .isVisible(); + + // http method + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.httpMethod) + .isVisible(); + }); + + test('"Save & test" should be successful when configuration is valid', async ({ + createDataSourceConfigPage, + readProvisionedDataSource, + }) => { + const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + const configPage = await createDataSourceConfigPage({ type: ds.type, deleteDataSourceAfterTest: true, }); + + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.connectionSettings) + .fill(ds.url || ''); + + await expect(configPage.saveAndTest()).toBeOK(); + }); + + test('"Save & test" should fail when configuration is invalid', async ({ + createDataSourceConfigPage, + readProvisionedDataSource, + }) => { + const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + const configPage = await createDataSourceConfigPage({ type: ds.type, deleteDataSourceAfterTest: true, }); + await expect(configPage.saveAndTest()).not.toBeOK(); + const alertMessage = await configPage.getByTestIdOrAriaLabel('data-testid Alert error').textContent(); + await expect(alertMessage).toContain('empty url') + }); + + test('it should allow a user to add the version when the Prom type is selected', + async ({ + createDataSourceConfigPage, + readProvisionedDataSource, + }) => { + const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + const configPage = await createDataSourceConfigPage({ + type: "prometheus-amazon-datasource", + name: DATA_SOURCE_NAME, + deleteDataSourceAfterTest: true, + }); + + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.prometheusType) + .isVisible(); + + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.prometheusVersion) + .isVisible(); + }); + + test('it should allow a user to select a query overlap window when incremental querying is selected', + async ({ + createDataSourceConfigPage, + readProvisionedDataSource, + page, + }) => { + const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + const configPage = await createDataSourceConfigPage({ + type: "prometheus-amazon-datasource", + name: DATA_SOURCE_NAME, + deleteDataSourceAfterTest: true, + }); + + await page.locator(`#${selectors.components.DataSource.Prometheus.configPage.incrementalQuerying}`) + .isVisible(); + + await configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.queryOverlapWindow) + .isVisible(); + }); + +// exemplars tested in exemplar.spec }); + From 0141329244d8b2663f35e1c889ce985ea6fea35b Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 5 Mar 2024 15:18:38 -0600 Subject: [PATCH 17/74] make tests work correctly and test correctly --- e2e/configuration.spec.ts | 108 +++++++++++++---------- provisioning/datasources/datasources.yml | 11 ++- 2 files changed, 71 insertions(+), 48 deletions(-) diff --git a/e2e/configuration.spec.ts b/e2e/configuration.spec.ts index 4076f97d..1dd64eca 100644 --- a/e2e/configuration.spec.ts +++ b/e2e/configuration.spec.ts @@ -29,62 +29,58 @@ test.describe('Configuration tests', () => { const configPage = await createDataSourceConfigPage({type: ds.type, deleteDataSourceAfterTest: true}); // connection settings - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.connectionSettings) - .isVisible(); + await expect(configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.connectionSettings)).toBeVisible(); + + // expect(connectionSettings).toBe(true); // managed alerts - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.manageAlerts) - .isVisible(); + await expect( + page.locator(`#${selectors.components.DataSource.Prometheus.configPage.manageAlerts}`) + ).toBeVisible(); + + // expect(manageAlerts).toBe(true); + // scrape interval - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.scrapeInterval) - .isVisible(); + await expect(configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.scrapeInterval)).toBeVisible(); + // query timeout - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.queryTimeout) - .isVisible(); + await expect(configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.queryTimeout)).toBeVisible(); // default editor - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.defaultEditor) - .isVisible(); + await expect(configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.defaultEditor)).toBeVisible(); // disable metric lookup - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.disableMetricLookup) - .isVisible(); + await expect( + page.locator(`#${selectors.components.DataSource.Prometheus.configPage.disableMetricLookup}`) + ).toBeVisible(); // prometheus type - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.prometheusType) - .isVisible(); + await expect(configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.prometheusType)).toBeVisible(); // cache level - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.cacheLevel) - .isVisible(); + await expect(configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.cacheLevel)).toBeVisible(); // incremental querying - await page.locator(`#${selectors.components.DataSource.Prometheus.configPage.incrementalQuerying}`) - .isVisible(); + await expect(page.locator(`#${selectors.components.DataSource.Prometheus.configPage.incrementalQuerying}`)).toBeVisible(); // disable recording rules - await page.locator(`#${selectors.components.DataSource.Prometheus.configPage.disableRecordingRules}`) - .isVisible(); + await expect(page.locator(`#${selectors.components.DataSource.Prometheus.configPage.disableRecordingRules}`)).toBeVisible(); // custom query parameters - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.customQueryParameters) - .isVisible(); + await expect(configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.customQueryParameters)).toBeVisible(); // http method - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.httpMethod) - .isVisible(); + await expect(configPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.httpMethod)).toBeVisible(); }); test('"Save & test" should be successful when configuration is valid', async ({ @@ -116,6 +112,7 @@ test.describe('Configuration tests', () => { async ({ createDataSourceConfigPage, readProvisionedDataSource, + page, }) => { const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); @@ -125,13 +122,23 @@ test.describe('Configuration tests', () => { deleteDataSourceAfterTest: true, }); - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.prometheusType) - .isVisible(); + await expect(configPage + .getByTestIdOrAriaLabel( + selectors.components.DataSource.Prometheus.configPage.prometheusType + )).toBeVisible(); + - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.prometheusVersion) - .isVisible(); + // open the select dropdown + await page.getByLabel('Prometheus type').click(); + + // select a prometheus type + await page.getByText('Cortex').click(); + + // expect the version component to be displayed + await expect(configPage + .getByTestIdOrAriaLabel( + selectors.components.DataSource.Prometheus.configPage.prometheusVersion + )).toBeVisible(); }); test('it should allow a user to select a query overlap window when incremental querying is selected', @@ -140,20 +147,27 @@ test.describe('Configuration tests', () => { readProvisionedDataSource, page, }) => { - const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + // const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); const configPage = await createDataSourceConfigPage({ type: "prometheus-amazon-datasource", - name: DATA_SOURCE_NAME, + name: DATA_SOURCE_NAME + "check", deleteDataSourceAfterTest: true, }); + + const incrementalQuerying = await page + .locator(`#${selectors.components.DataSource.Prometheus.configPage.incrementalQuerying}`) - await page.locator(`#${selectors.components.DataSource.Prometheus.configPage.incrementalQuerying}`) - .isVisible(); + expect(await incrementalQuerying).toBeVisible(); - await configPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.queryOverlapWindow) - .isVisible(); + await page.getByLabel('Toggle switch').nth(3).setChecked(true); + + expect( + await configPage + .getByTestIdOrAriaLabel( + selectors.components.DataSource.Prometheus.configPage.queryOverlapWindow + ) + ).toBeVisible(); }); // exemplars tested in exemplar.spec diff --git a/provisioning/datasources/datasources.yml b/provisioning/datasources/datasources.yml index a6f7fd48..2712d429 100644 --- a/provisioning/datasources/datasources.yml +++ b/provisioning/datasources/datasources.yml @@ -5,4 +5,13 @@ datasources: type: prometheus-amazon-datasource url: http://prometheus:9090 access: proxy - editable: true \ No newline at end of file + editable: true + # jsonData: + # httpMethod: POST + # manageAlerts: true + # prometheusType: Prometheus + # prometheusVersion: 2.44.0 + # cacheLevel: 'High' + # disableRecordingRules: false + # incrementalQueryOverlapWindow: 10m + \ No newline at end of file From 55ff0cb01fd28144d19fc52bf414aa29485d7901 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 6 Mar 2024 08:31:37 -0600 Subject: [PATCH 18/74] remove unused imports --- e2e/configuration.spec.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/e2e/configuration.spec.ts b/e2e/configuration.spec.ts index 1dd64eca..7b3f5fe8 100644 --- a/e2e/configuration.spec.ts +++ b/e2e/configuration.spec.ts @@ -1,5 +1,5 @@ import { DataSourcePluginOptionsEditorProps } from '@grafana/data'; -import { E2ESelectors, Selectors, selectors } from '@grafana/e2e-selectors'; +import { selectors } from '@grafana/e2e-selectors'; import { test, expect } from '@grafana/plugin-e2e'; import { PromOptions } from '@grafana/prometheus'; From 514ecf4d8ee0e72090362627231547856e296a3f Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 6 Mar 2024 13:42:43 -0600 Subject: [PATCH 19/74] clean comments --- e2e/configuration.spec.ts | 6 ------ 1 file changed, 6 deletions(-) diff --git a/e2e/configuration.spec.ts b/e2e/configuration.spec.ts index 7b3f5fe8..2b24eda1 100644 --- a/e2e/configuration.spec.ts +++ b/e2e/configuration.spec.ts @@ -32,21 +32,15 @@ test.describe('Configuration tests', () => { await expect(configPage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.connectionSettings)).toBeVisible(); - // expect(connectionSettings).toBe(true); - // managed alerts await expect( page.locator(`#${selectors.components.DataSource.Prometheus.configPage.manageAlerts}`) ).toBeVisible(); - - - // expect(manageAlerts).toBe(true); // scrape interval await expect(configPage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.scrapeInterval)).toBeVisible(); - // query timeout await expect(configPage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.queryTimeout)).toBeVisible(); From b7865c370e602302b6d9e180ffe8fdb157865041 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 6 Mar 2024 13:43:30 -0600 Subject: [PATCH 20/74] update to latest version of prom --- docker-compose-debug.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docker-compose-debug.yaml b/docker-compose-debug.yaml index 1c051141..775d2681 100644 --- a/docker-compose-debug.yaml +++ b/docker-compose-debug.yaml @@ -1,7 +1,7 @@ version: "0.1" services: prometheus: - image: prom/prometheus + image: prom/prometheus:latest container_name: prometheus-debug command: - '--config.file=/etc/prometheus/prometheus.yml' From e0e3cbee3b9279b292ec8283d93b26664a26baec Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 6 Mar 2024 13:44:06 -0600 Subject: [PATCH 21/74] add special data source provisioning file for testing config --- provisioning/datasources/code-editor.yml | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) create mode 100644 provisioning/datasources/code-editor.yml diff --git a/provisioning/datasources/code-editor.yml b/provisioning/datasources/code-editor.yml new file mode 100644 index 00000000..4d6bdf2c --- /dev/null +++ b/provisioning/datasources/code-editor.yml @@ -0,0 +1,18 @@ +apiVersion: 1 + +datasources: +- name: Prometheus-amazon-code + type: prometheus-amazon-datasource + url: http://prometheus:9090 + access: proxy + editable: true + jsonData: + httpMethod: POST + manageAlerts: true + prometheusType: Prometheus + prometheusVersion: 2.44.0 + cacheLevel: 'High' + disableRecordingRules: false + incrementalQueryOverlapWindow: 10m + defaultEditor: code + \ No newline at end of file From 6506c6f72e702fd5011f11496d61bab9b4410e6a Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 6 Mar 2024 13:44:54 -0600 Subject: [PATCH 22/74] rewrite cypress tests in playwright for query editor --- e2e/query-editor.spec.ts | 253 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 253 insertions(+) create mode 100644 e2e/query-editor.spec.ts diff --git a/e2e/query-editor.spec.ts b/e2e/query-editor.spec.ts new file mode 100644 index 00000000..3c795b2c --- /dev/null +++ b/e2e/query-editor.spec.ts @@ -0,0 +1,253 @@ +import { DataSourcePluginOptionsEditorProps } from '@grafana/data'; +import { selectors } from '@grafana/e2e-selectors'; +import { test, expect } from '@grafana/plugin-e2e'; +import { PromOptions } from '@grafana/prometheus'; + +import { labelsResponse, metadataResponse, metricResponse } from './data'; + +const codeEditorProvFile = 'code-editor.yml'; + +const metric = 'process_cpu_seconds_total'; + +test.describe('Prometheus query editor', () => { + test(`should have the following components: + kickstart component + explain + editor toggle + options + legend + format + step + type + exemplars + `, async ({ + readProvisionedDataSource, + explorePage, + page, + }) => { + const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + explorePage.datasource.set(ds.name); + // query patterns + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.queryPatterns)).toBeVisible(); + + // explain + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.explain)).toBeVisible(); + + // editor toggle + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.editorToggle)).toBeVisible(); + + // options + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.options)).toBeVisible(); + + // open the options + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.options) + .click(); + + // legend + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.legend)).toBeVisible(); + + // format + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.format)).toBeVisible(); + + // step + await expect(page.locator(`#${selectors.components.DataSource.Prometheus.queryEditor.step}`)).toBeVisible(); + + // type + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.type)).toBeVisible(); + + // exemplars + await expect(page.locator(`#${selectors.components.DataSource.Prometheus.queryEditor.exemplars}`)).toBeVisible(); + }); + + test.describe('Code editor', () => { + test('it navigates to the code editor with editor type as code', async ({ + readProvisionedDataSource, + explorePage + }) => { + const dsCodeEditor = await readProvisionedDataSource>({ fileName: codeEditorProvFile }); + + explorePage.datasource.set(dsCodeEditor.name); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField)).toBeVisible(); + }); + + test('it navigates to the code editor and opens the metrics browser with metric search, labels, label values, and all components', async ({ + readProvisionedDataSource, + explorePage + }) => { + const dsCodeEditor = await readProvisionedDataSource>({ fileName: codeEditorProvFile }); + + explorePage.datasource.set(dsCodeEditor.name); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField)).toBeVisible(); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton) + .click() + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric)).toBeVisible(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelNamesFilter)).toBeVisible(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelValuesFilter)).toBeVisible(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useQuery)).toBeVisible(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useAsRateQuery)).toBeVisible(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.validateSelector)).toBeVisible(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.clear)).toBeVisible(); + }); + + test('selects a metric in the metrics browser and uses the query', async ({ + readProvisionedDataSource, + explorePage, + page + }) => { + const dsCodeEditor = await readProvisionedDataSource>({ fileName: codeEditorProvFile }); + + explorePage.datasource.set(dsCodeEditor.name); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField)).toBeVisible(); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton) + .click() + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric)).toBeVisible(); + + await page.getByRole('option', { name: 'go_gc_duration_seconds', exact: true }).click() + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useQuery).click(); + + const testMetric = await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField).textContent() + + expect(testMetric).toContain('go_gc_duration_seconds'); + }); + }); + + test.describe('Query builder', () => { + test('it navigates to the code editor with default editor type as builder', async ({ + readProvisionedDataSource, + explorePage + }) => { + const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); + }); + + test('the query builder contains metric select, label filters and operations', async ({ + readProvisionedDataSource, + explorePage + }) => { + const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect)).toBeVisible(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.matchOperatorSelect)).toBeVisible(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.valueSelect)).toBeVisible(); + }); + + test('it can select a metric and provide a hint', async ({ + readProvisionedDataSource, + explorePage, + page + }) => { + const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click() + + await page.getByText(metric, { exact: true }).click(); + + const hintText = await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.hints).textContent(); + + expect(hintText).toContain('hint: add rate'); + }); + + test('it can select a label filter and run a query', async ({ + readProvisionedDataSource, + explorePage, + page + }) => { + const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await explorePage.getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).click() + + await page.getByText('__name__', { exact: true }).click(); + + await explorePage.getByTestIdOrAriaLabel(selectors.components.QueryBuilder.valueSelect).click(); + + await page.getByText(metric, { exact: true }).click(); + + await explorePage.runQuery(); + }); + + test('it should have the metrics explorer opened via the metric select', async ({ + readProvisionedDataSource, + explorePage, + page + }) => { + const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click() + + await page.getByText('Metrics explorer', { exact: true }).click(); + + await expect(explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricsExplorer)).toBeVisible(); + }); + + // NEED TO COMPLETE QUEY ADVISOR WORK OR FIGURE OUT HOW TO ENABLE EXPERIMENTAL FEATURE TOGGLES + // it('should have a query advisor when enabled with feature toggle', () => { + // cy.window().then((win) => { + // win.localStorage.setItem('grafana.featureToggles', 'prometheusPromQAIL=0'); + + // navigateToEditor('Builder', 'prometheusBuilder'); + + // getResources(); + + // e2e.components.DataSource.Prometheus.queryEditor.builder.queryAdvisor().should('exist'); + // }); + // }); + }); +}); From fb73140569942b30354057a17eb40045369ea4b1 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 6 Mar 2024 15:10:33 -0600 Subject: [PATCH 23/74] remove unused data import --- e2e/query-editor.spec.ts | 2 -- 1 file changed, 2 deletions(-) diff --git a/e2e/query-editor.spec.ts b/e2e/query-editor.spec.ts index 3c795b2c..d5784dd4 100644 --- a/e2e/query-editor.spec.ts +++ b/e2e/query-editor.spec.ts @@ -3,8 +3,6 @@ import { selectors } from '@grafana/e2e-selectors'; import { test, expect } from '@grafana/plugin-e2e'; import { PromOptions } from '@grafana/prometheus'; -import { labelsResponse, metadataResponse, metricResponse } from './data'; - const codeEditorProvFile = 'code-editor.yml'; const metric = 'process_cpu_seconds_total'; From 3a80071acad635b20ca2967d7e027a65f119ff85 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 11:06:14 -0600 Subject: [PATCH 24/74] add tests for variable query editor --- e2e/variable-query-editor.spec.ts | 147 ++++++++++++++++++++++++++++++ 1 file changed, 147 insertions(+) create mode 100644 e2e/variable-query-editor.spec.ts diff --git a/e2e/variable-query-editor.spec.ts b/e2e/variable-query-editor.spec.ts new file mode 100644 index 00000000..dddeda29 --- /dev/null +++ b/e2e/variable-query-editor.spec.ts @@ -0,0 +1,147 @@ +import { DataSourcePluginOptionsEditorProps } from '@grafana/data'; +import { selectors } from '@grafana/e2e-selectors'; +import { test, expect } from '@grafana/plugin-e2e'; +import { PromOptions } from '@grafana/prometheus'; + +test.describe('Prometheus variable query editor', () => { + test.beforeEach('set query type', async ({ + readProvisionedDataSource, + variableEditPage + }) => { + const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + await variableEditPage.setVariableType('Query'); + + await variableEditPage.datasource.set(ds.name); + + await variableEditPage.getByTestIdOrAriaLabel( + selectors.components.DataSource.Prometheus.variableQueryEditor.queryType + ).focus(); + + expect(await variableEditPage.getByTestIdOrAriaLabel( + selectors.components.DataSource.Prometheus.variableQueryEditor.queryType) + ).toBeVisible(); + + await variableEditPage.getByTestIdOrAriaLabel( + selectors.components.DataSource.Prometheus.variableQueryEditor.queryType + ).click(); + }); + + test('label names query variable', async ({ + readProvisionedDataSource, + variableEditPage, + page, + }) => { + await expect(page.getByText('Label names', { exact: true })).toBeVisible(); + + await page.getByText('Label names', { exact: true }).click(); + + await expect(page.getByText('__name__')).toBeVisible(); + }); + + test('label values query variable', async ({ + readProvisionedDataSource, + variableEditPage, + page, + }) => { + await page.getByText('Label values').click(); + + const selector = 'data-testid label values label select'; + + await page.getByTestId(selector).click(); + + await page.getByText('__name__').click(); + + await expect(variableEditPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); + + await expect(variableEditPage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect)).toBeVisible(); + + await expect(variableEditPage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.matchOperatorSelect)).toBeVisible(); + + await expect(variableEditPage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.valueSelect)).toBeVisible(); + + await expect(page.getByText('go_goroutines')).toBeVisible(); + }); + + test('Metrics query variable', async ({ + readProvisionedDataSource, + variableEditPage, + page, + }) => { + await page.getByText('Metrics').click(); + + const selector = 'data-testid metric names metric regex'; + + await expect(variableEditPage.getByTestIdOrAriaLabel(selector)).toBeVisible(); + + await variableEditPage.getByTestIdOrAriaLabel(selector).fill('go_go'); + + await variableEditPage.runQuery(); + + await expect(page.getByText('go_goroutines')).toBeVisible(); + }); + + test('Query result query variable', async ({ + readProvisionedDataSource, + variableEditPage, + page, + }) => { + await page.getByText('Query result').click(); + + const selector = 'data-testid variable query result'; + + await expect(variableEditPage.getByTestIdOrAriaLabel(selector)).toBeVisible(); + + await variableEditPage.getByTestIdOrAriaLabel(selector).fill('go_goroutines'); + + await variableEditPage.getByTestIdOrAriaLabel(selector).blur(); + + await page.getByText('go_goroutines{').focus(); + + await expect(page.getByText('go_goroutines{')).toBeVisible(); + }); + + test('Series query variable', async ({ + readProvisionedDataSource, + variableEditPage, + page, + }) => { + await page.getByText('Series query').click(); + + const selector = 'data-testid prometheus series query'; + + await expect(variableEditPage.getByTestIdOrAriaLabel(selector)).toBeVisible(); + + await variableEditPage.getByTestIdOrAriaLabel(selector).fill('go_goroutines'); + + await variableEditPage.getByTestIdOrAriaLabel(selector).blur(); + + await page.getByText('go_goroutines{').focus(); + + await expect(page.getByText('go_goroutines{')).toBeVisible(); + }); + + test('Classic query variable', async ({ + readProvisionedDataSource, + variableEditPage, + page, + }) => { + await page.getByText('Classic query').click(); + + const selector = 'data-testid prometheus classic query'; + + await expect(variableEditPage.getByTestIdOrAriaLabel(selector)).toBeVisible(); + + await variableEditPage.getByTestIdOrAriaLabel(selector).fill('label_names()'); + + await variableEditPage.getByTestIdOrAriaLabel(selector).blur(); + + await page.getByText('__name__').focus(); + + await expect(page.getByText('__name__')).toBeVisible(); + }); +}); From 2c6f5fa97e6c1ebd3709601b94720ce5553d807b Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 13:15:37 -0600 Subject: [PATCH 25/74] add e2e test for annotation editor --- e2e/annotation-editor.spec.ts | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 e2e/annotation-editor.spec.ts diff --git a/e2e/annotation-editor.spec.ts b/e2e/annotation-editor.spec.ts new file mode 100644 index 00000000..4a4aa2e5 --- /dev/null +++ b/e2e/annotation-editor.spec.ts @@ -0,0 +1,20 @@ +import { DataSourcePluginOptionsEditorProps } from '@grafana/data'; +import { selectors } from '@grafana/e2e-selectors'; +import { test, expect } from '@grafana/plugin-e2e'; +import { PromOptions } from '@grafana/prometheus'; + +test.describe('Prometheus annotation query editor', () => { + test('Check that the editor uses the code editor', async ({ + readProvisionedDataSource, + annotationEditPage + }) => { + const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + await annotationEditPage.datasource.set(ds.name); + await annotationEditPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField).focus(); + + await expect(annotationEditPage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField)).toBeVisible(); + }); +}); From 34b0c1d48fe75b808b9ab3cc2954163428df93ab Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 13:34:47 -0600 Subject: [PATCH 26/74] removed unnecessary test --- e2e/datasource.spec.ts | 7 ------- 1 file changed, 7 deletions(-) delete mode 100644 e2e/datasource.spec.ts diff --git a/e2e/datasource.spec.ts b/e2e/datasource.spec.ts deleted file mode 100644 index 08e80cf6..00000000 --- a/e2e/datasource.spec.ts +++ /dev/null @@ -1,7 +0,0 @@ -import { test, expect } from '@grafana/plugin-e2e'; - -test('should expand multi-valued variable before calling backend', async ({ - readProvisionedDataSource, -}) => { - const datasource = readProvisionedDataSource({ fileName: 'datasources.yml' }); -}); From 78d3108f503ca463170b4f0c6c884c75de9382e3 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 13:35:28 -0600 Subject: [PATCH 27/74] add dashboard json for future tests --- provisioning/dashboards/e2e-dashboard.json | 185 +++++++++++++++++++++ provisioning/datasources/code-editor.yml | 1 + provisioning/datasources/datasources.yml | 1 + 3 files changed, 187 insertions(+) create mode 100644 provisioning/dashboards/e2e-dashboard.json diff --git a/provisioning/dashboards/e2e-dashboard.json b/provisioning/dashboards/e2e-dashboard.json new file mode 100644 index 00000000..64bbcc90 --- /dev/null +++ b/provisioning/dashboards/e2e-dashboard.json @@ -0,0 +1,185 @@ +{ + "annotations": { + "list": [ + { + "builtIn": 1, + "datasource": { + "type": "grafana", + "uid": "-- Grafana --" + }, + "enable": true, + "hide": true, + "iconColor": "rgba(0, 211, 255, 1)", + "name": "Annotations & Alerts", + "type": "dashboard" + }, + { + "datasource": { + "type": "prometheus-amazon-datasource", + "uid": "prometheus-amazon" + }, + "enable": true, + "expr": "go_goroutines", + "iconColor": "red", + "name": "go_goroutines_annotation", + "target": { + "lines": 10, + "refId": "Anno", + "scenarioId": "annotations" + } + } + ] + }, + "editable": true, + "fiscalYearStartMonth": 0, + "graphTooltip": 0, + "id": 128, + "links": [], + "panels": [ + { + "datasource": { + "type": "prometheus-amazon-datasource", + "uid": "prometheus-amazon" + }, + "fieldConfig": { + "defaults": { + "color": { + "mode": "palette-classic" + }, + "custom": { + "axisBorderShow": false, + "axisCenteredZero": false, + "axisColorMode": "text", + "axisLabel": "", + "axisPlacement": "auto", + "barAlignment": 0, + "drawStyle": "line", + "fillOpacity": 0, + "gradientMode": "none", + "hideFrom": { + "legend": false, + "tooltip": false, + "viz": false + }, + "insertNulls": false, + "lineInterpolation": "linear", + "lineWidth": 1, + "pointSize": 5, + "scaleDistribution": { + "type": "linear" + }, + "showPoints": "auto", + "spanNulls": false, + "stacking": { + "group": "A", + "mode": "none" + }, + "thresholdsStyle": { + "mode": "off" + } + }, + "mappings": [], + "thresholds": { + "mode": "absolute", + "steps": [ + { + "color": "green", + "value": null + }, + { + "color": "red", + "value": 80 + } + ] + } + }, + "overrides": [] + }, + "gridPos": { + "h": 8, + "w": 12, + "x": 0, + "y": 0 + }, + "id": 1, + "options": { + "legend": { + "calcs": [], + "displayMode": "list", + "placement": "bottom", + "showLegend": true + }, + "tooltip": { + "maxHeight": 600, + "mode": "single", + "sort": "none" + } + }, + "targets": [ + { + "datasource": { + "type": "prometheus", + "uid": "prometheus-amazon" + }, + "disableTextWrap": false, + "editorMode": "builder", + "expr": "go_goroutines", + "fullMetaSearch": false, + "includeNullMetadata": true, + "instant": false, + "legendFormat": "__auto", + "range": true, + "refId": "A", + "useBackend": false + } + ], + "title": "Panel Title", + "type": "timeseries" + } + ], + "refresh": "", + "schemaVersion": 39, + "tags": [], + "templating": { + "list": [ + { + "current": { + "selected": false, + "text": "__name__", + "value": "__name__" + }, + "datasource": { + "type": "prometheus-amazon-datasource", + "uid": "prometheus-amazon" + }, + "definition": "label_names()", + "hide": 0, + "includeAll": false, + "multi": false, + "name": "labelnames", + "options": [], + "query": { + "qryType": 0, + "query": "label_names()", + "refId": "PrometheusVariableQueryEditor-VariableQuery" + }, + "refresh": 1, + "regex": "", + "skipUrlSync": false, + "sort": 0, + "type": "query" + } + ] + }, + "time": { + "from": "2024-03-07T04:04:38.811Z", + "to": "2024-03-08T04:04:38.811Z" + }, + "timeRangeUpdatedDuringEditOrView": false, + "timepicker": {}, + "timezone": "browser", + "title": "prometheus-amazon", + "uid": "fdewz0hu7qccge", + "version": 2, + "weekStart": "" +} diff --git a/provisioning/datasources/code-editor.yml b/provisioning/datasources/code-editor.yml index 4d6bdf2c..8d0d4065 100644 --- a/provisioning/datasources/code-editor.yml +++ b/provisioning/datasources/code-editor.yml @@ -2,6 +2,7 @@ apiVersion: 1 datasources: - name: Prometheus-amazon-code + uid: prometheus-amazon type: prometheus-amazon-datasource url: http://prometheus:9090 access: proxy diff --git a/provisioning/datasources/datasources.yml b/provisioning/datasources/datasources.yml index 2712d429..ad88de3b 100644 --- a/provisioning/datasources/datasources.yml +++ b/provisioning/datasources/datasources.yml @@ -2,6 +2,7 @@ apiVersion: 1 datasources: - name: Prometheus-amazon + uid: prometheus-amazon type: prometheus-amazon-datasource url: http://prometheus:9090 access: proxy From 55264de873b1c65c4be26b8082a9b26482288d93 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 16:10:42 -0600 Subject: [PATCH 28/74] begin testing e2e workflow --- .github/workflows/e2e.yml | 69 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 .github/workflows/e2e.yml diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml new file mode 100644 index 00000000..a90a3e56 --- /dev/null +++ b/.github/workflows/e2e.yml @@ -0,0 +1,69 @@ +name: E2E Tests +on: + pull_request: + paths-ignore: + - 'docs/**' + push: + paths-ignore: + - 'docs/**' +concurrency: + group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} + cancel-in-progress: true +jobs: + test: + timeout-minutes: 60 + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v3 + - name: Setup Go environment + uses: actions/setup-go@v4 + with: + go-version: '1.21.6' + - name: Test backend + uses: magefile/mage-action@v2 + with: + version: latest + args: coverage + - name: Build backend + uses: magefile/mage-action@v2 + with: + version: latest + args: buildAll + - name: Setup Node + uses: actions/setup-node@v3 + with: + node-version: 20 + - name: Install dependencies + run: npm install -g yarn && yarn install --frozen-lockfile; + - name: Spellcheck + run: | + yarn spellcheck; + - name: Build Frontend + run: | + yarn build; + - name: Start the docker container for E2E + run: | + docker-compose pull + docker compose -f docker-compose-debug.yaml up + - name: Wait for grafana to start + uses: nev7n/wait_for_response@v1 + with: + url: 'http://localhost:3099/' + responseCode: 200 + timeout: 20000 + interval: 500 + - name: Install Playwright Browsers + run: yarn playwright install --with-deps + - name: Run E2E tests + run: yarn test:e2e + - name: Run E2E artifacts + uses: actions/upload-artifact@v3 + if: always() + with: + name: playwright-report + path: playwright-report/ + retention-days: 30 + - name: Stop the docker container + if: always() + run: docker-compose down \ No newline at end of file From 4a437174c3c64bb1661f642edcf8cfe4ac683c68 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 16:14:39 -0600 Subject: [PATCH 29/74] fix workflow for broken tests --- .github/workflows/e2e.yml | 11 ++++++----- .github/workflows/playwright.yml | 27 --------------------------- 2 files changed, 6 insertions(+), 32 deletions(-) delete mode 100644 .github/workflows/playwright.yml diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index a90a3e56..ee25ddc6 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -20,11 +20,12 @@ jobs: uses: actions/setup-go@v4 with: go-version: '1.21.6' - - name: Test backend - uses: magefile/mage-action@v2 - with: - version: latest - args: coverage + # tests failing so don't test backend until we get the library working + # - name: Test backend + # uses: magefile/mage-action@v2 + # with: + # version: latest + # args: coverage - name: Build backend uses: magefile/mage-action@v2 with: diff --git a/.github/workflows/playwright.yml b/.github/workflows/playwright.yml deleted file mode 100644 index 40cb1c0b..00000000 --- a/.github/workflows/playwright.yml +++ /dev/null @@ -1,27 +0,0 @@ -name: e2e Tests -on: - push: - branches: [ main, master ] - pull_request: - branches: [ main, master ] -jobs: - test: - timeout-minutes: 60 - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - uses: actions/setup-node@v3 - with: - node-version: 18 - - name: Install dependencies - run: npm install -g yarn && yarn - - name: Install Playwright Browsers - run: yarn playwright install --with-deps - - name: Run Playwright tests - run: yarn playwright test - - uses: actions/upload-artifact@v3 - if: always() - with: - name: playwright-report - path: playwright-report/ - retention-days: 30 From 5109b3150384b6b3db63d105e0b7f3849a8fa605 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 16:22:42 -0600 Subject: [PATCH 30/74] simplify workflow for only testing e2e tests --- .github/workflows/e2e.yml | 29 ----------------------------- 1 file changed, 29 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index ee25ddc6..2a162193 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -14,35 +14,6 @@ jobs: timeout-minutes: 60 runs-on: ubuntu-latest steps: - - name: Checkout - uses: actions/checkout@v3 - - name: Setup Go environment - uses: actions/setup-go@v4 - with: - go-version: '1.21.6' - # tests failing so don't test backend until we get the library working - # - name: Test backend - # uses: magefile/mage-action@v2 - # with: - # version: latest - # args: coverage - - name: Build backend - uses: magefile/mage-action@v2 - with: - version: latest - args: buildAll - - name: Setup Node - uses: actions/setup-node@v3 - with: - node-version: 20 - - name: Install dependencies - run: npm install -g yarn && yarn install --frozen-lockfile; - - name: Spellcheck - run: | - yarn spellcheck; - - name: Build Frontend - run: | - yarn build; - name: Start the docker container for E2E run: | docker-compose pull From 9b476743ae16aeeb22b262f260572ded0d3eb62d Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 16:25:24 -0600 Subject: [PATCH 31/74] fix docker command --- .github/workflows/e2e.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index 2a162193..39ee5d07 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -16,7 +16,7 @@ jobs: steps: - name: Start the docker container for E2E run: | - docker-compose pull + docker-compose -f docker-compose-debug.yaml pull docker compose -f docker-compose-debug.yaml up - name: Wait for grafana to start uses: nev7n/wait_for_response@v1 From 4bd17575dcd00e1b15242914014de8daa372bb14 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 16:32:08 -0600 Subject: [PATCH 32/74] checkout branch in workflow so files are available --- .github/workflows/e2e.yml | 33 +++++++++++++++++++++++++++++++-- 1 file changed, 31 insertions(+), 2 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index 39ee5d07..7beac9c0 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -14,9 +14,38 @@ jobs: timeout-minutes: 60 runs-on: ubuntu-latest steps: + - name: Checkout + uses: actions/checkout@v3 + - name: Setup Go environment + uses: actions/setup-go@v4 + with: + go-version: '1.21.6' + + # - name: Test backend + # uses: magefile/mage-action@v2 + # with: + # version: latest + # args: coverage + # - name: Build backend + # uses: magefile/mage-action@v2 + # with: + # version: latest + # args: buildAll + # - name: Setup Node + # uses: actions/setup-node@v3 + # with: + # node-version: 20 + # - name: Install dependencies + # run: npm install -g yarn && yarn install --frozen-lockfile; + # - name: Spellcheck + # run: | + # yarn spellcheck; + # - name: Build Frontend + # run: | + # yarn build; - name: Start the docker container for E2E run: | - docker-compose -f docker-compose-debug.yaml pull + docker compose -f docker-compose-debug.yaml pull docker compose -f docker-compose-debug.yaml up - name: Wait for grafana to start uses: nev7n/wait_for_response@v1 @@ -38,4 +67,4 @@ jobs: retention-days: 30 - name: Stop the docker container if: always() - run: docker-compose down \ No newline at end of file + run: docker-compose -f docker-compose-debug.yaml down \ No newline at end of file From 3a47d708620915df9a8031c8aee9e88ad688d1c6 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 16:34:45 -0600 Subject: [PATCH 33/74] fix provisioning error --- provisioning/datasources/code-editor.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/provisioning/datasources/code-editor.yml b/provisioning/datasources/code-editor.yml index 8d0d4065..f694e721 100644 --- a/provisioning/datasources/code-editor.yml +++ b/provisioning/datasources/code-editor.yml @@ -2,7 +2,7 @@ apiVersion: 1 datasources: - name: Prometheus-amazon-code - uid: prometheus-amazon + uid: prometheus-amazon-code-editor type: prometheus-amazon-datasource url: http://prometheus:9090 access: proxy From 7580e276a0188ed16d39af1dfbaa07d68ec9de67 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 20:03:07 -0600 Subject: [PATCH 34/74] run container detached --- .github/workflows/e2e.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index 7beac9c0..45fed298 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -46,7 +46,7 @@ jobs: - name: Start the docker container for E2E run: | docker compose -f docker-compose-debug.yaml pull - docker compose -f docker-compose-debug.yaml up + docker compose -f docker-compose-debug.yaml up -d - name: Wait for grafana to start uses: nev7n/wait_for_response@v1 with: From 4d60ae0da68a86555590edafe3aff35f69dfc4f2 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 20:09:35 -0600 Subject: [PATCH 35/74] update docker compose versions --- docker-compose-debug.yaml | 2 +- docker-compose.yaml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/docker-compose-debug.yaml b/docker-compose-debug.yaml index 775d2681..f6ed2656 100644 --- a/docker-compose-debug.yaml +++ b/docker-compose-debug.yaml @@ -1,4 +1,4 @@ -version: "0.1" +version: "3.7" services: prometheus: image: prom/prometheus:latest diff --git a/docker-compose.yaml b/docker-compose.yaml index a40fc1dc..65649c92 100644 --- a/docker-compose.yaml +++ b/docker-compose.yaml @@ -1,4 +1,4 @@ -version: '3.0' +version: '3.7' services: grafana: From b27af6fcb2f3ea8f861029d073f7362c6979f365 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 20:15:09 -0600 Subject: [PATCH 36/74] add node workflow --- .github/workflows/e2e.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index 45fed298..a1fc8bf1 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -31,10 +31,10 @@ jobs: # with: # version: latest # args: buildAll - # - name: Setup Node - # uses: actions/setup-node@v3 - # with: - # node-version: 20 + - name: Setup Node + uses: actions/setup-node@v3 + with: + node-version: 20 # - name: Install dependencies # run: npm install -g yarn && yarn install --frozen-lockfile; # - name: Spellcheck From 1441c9dac881373fc8f5a1cb64f6e49a58bfc4d3 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 20:19:11 -0600 Subject: [PATCH 37/74] install deps --- .github/workflows/e2e.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index a1fc8bf1..5fd14933 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -35,8 +35,8 @@ jobs: uses: actions/setup-node@v3 with: node-version: 20 - # - name: Install dependencies - # run: npm install -g yarn && yarn install --frozen-lockfile; + - name: Install dependencies + run: npm install -g yarn && yarn install --frozen-lockfile; # - name: Spellcheck # run: | # yarn spellcheck; From 6dfcbb7a3f8fc1b2847b957ad8d1dec625e3d9a2 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 20:23:52 -0600 Subject: [PATCH 38/74] remove package manager for workflow --- package.json | 1 - 1 file changed, 1 deletion(-) diff --git a/package.json b/package.json index 1ed563c1..846b2d0b 100644 --- a/package.json +++ b/package.json @@ -129,7 +129,6 @@ "uuid": "^9.0.1", "whatwg-fetch": "3.6.20" }, - "packageManager": "yarn@3.6.1", "dependenciesMeta": { "prettier@3.0.0": { "unplugged": true From b8b4c57beecc59cf576d23cec9d37322529964ce Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 21:56:20 -0600 Subject: [PATCH 39/74] test build --- .github/workflows/e2e.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index 5fd14933..53ed63fd 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -40,9 +40,9 @@ jobs: # - name: Spellcheck # run: | # yarn spellcheck; - # - name: Build Frontend - # run: | - # yarn build; + - name: Build Frontend + run: | + yarn build; - name: Start the docker container for E2E run: | docker compose -f docker-compose-debug.yaml pull From d36b94267f27f4ec957c1b3b521d30a637b2317b Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 21:56:56 -0600 Subject: [PATCH 40/74] fix for prometheus bug --- docker-compose-debug.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docker-compose-debug.yaml b/docker-compose-debug.yaml index f6ed2656..793076b4 100644 --- a/docker-compose-debug.yaml +++ b/docker-compose-debug.yaml @@ -1,7 +1,7 @@ version: "3.7" services: prometheus: - image: prom/prometheus:latest + image: prom/prometheus:v2.45.0 container_name: prometheus-debug command: - '--config.file=/etc/prometheus/prometheus.yml' From ec5bc4ec2d4a465c53fa2bcbe723d0afa142085a Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 21:57:28 -0600 Subject: [PATCH 41/74] add report --- .gitignore | 2 +- playwright-report/index.html | 69 ++++++++++++++++++++++++++++++++++++ 2 files changed, 70 insertions(+), 1 deletion(-) create mode 100644 playwright-report/index.html diff --git a/.gitignore b/.gitignore index d533361b..6c5768ba 100644 --- a/.gitignore +++ b/.gitignore @@ -34,6 +34,6 @@ e2e-results/ .eslintcache /test-results/ -/playwright-report/ +# /playwright-report/ /blob-report/ /playwright/.cache/ diff --git a/playwright-report/index.html b/playwright-report/index.html new file mode 100644 index 00000000..91a1d5dd --- /dev/null +++ b/playwright-report/index.html @@ -0,0 +1,69 @@ + + + + + + + + + Playwright Test Report + + + + +
+ + + + \ No newline at end of file From ece4d73c30fd34b1da4e80308403eb63e08a2b1a Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Thu, 7 Mar 2024 23:02:13 -0600 Subject: [PATCH 42/74] less flaky tests for github actions --- e2e/query-editor.spec.ts | 46 ++++++++++++++++++++++++++++++++++++++-- 1 file changed, 44 insertions(+), 2 deletions(-) diff --git a/e2e/query-editor.spec.ts b/e2e/query-editor.spec.ts index d5784dd4..851b1067 100644 --- a/e2e/query-editor.spec.ts +++ b/e2e/query-editor.spec.ts @@ -90,6 +90,15 @@ test.describe('Prometheus query editor', () => { await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField).focus(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton)).toBeVisible(); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).focus(); + await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton) .click() @@ -128,6 +137,15 @@ test.describe('Prometheus query editor', () => { await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField).focus(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton)).toBeVisible(); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).focus(); + await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton) .click() @@ -148,7 +166,7 @@ test.describe('Prometheus query editor', () => { }); test.describe('Query builder', () => { - test('it navigates to the code editor with default editor type as builder', async ({ + test('it navigates to the query builder with default editor type as builder', async ({ readProvisionedDataSource, explorePage }) => { @@ -156,6 +174,9 @@ test.describe('Prometheus query editor', () => { explorePage.datasource.set(dsDefaultEditorBuilder.name); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); + await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); }); @@ -168,15 +189,27 @@ test.describe('Prometheus query editor', () => { explorePage.datasource.set(dsDefaultEditorBuilder.name); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); + await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).focus(); + await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect)).toBeVisible(); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.matchOperatorSelect).focus(); await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.matchOperatorSelect)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.valueSelect).focus(); + await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.valueSelect)).toBeVisible(); }); @@ -190,6 +223,9 @@ test.describe('Prometheus query editor', () => { explorePage.datasource.set(dsDefaultEditorBuilder.name); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); + await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click() await page.getByText(metric, { exact: true }).click(); @@ -207,7 +243,13 @@ test.describe('Prometheus query editor', () => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); explorePage.datasource.set(dsDefaultEditorBuilder.name); - + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).focus(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect)).toBeVisible(); + await explorePage.getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).click() await page.getByText('__name__', { exact: true }).click(); From 6ce7ebf1b280c2f937cab123fc400907070935d8 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 8 Mar 2024 05:02:58 -0600 Subject: [PATCH 43/74] confirming components are visible means less flaky tests --- e2e/query-editor.spec.ts | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/e2e/query-editor.spec.ts b/e2e/query-editor.spec.ts index 851b1067..3ede0c35 100644 --- a/e2e/query-editor.spec.ts +++ b/e2e/query-editor.spec.ts @@ -270,6 +270,12 @@ test.describe('Prometheus query editor', () => { explorePage.datasource.set(dsDefaultEditorBuilder.name); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); + + await expect(explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); + await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click() await page.getByText('Metrics explorer', { exact: true }).click(); From a5275b1df19987c658e0f4e94d9cd434da3a0049 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 8 Mar 2024 05:03:37 -0600 Subject: [PATCH 44/74] wait for prometheus to be up in github workflow --- .github/workflows/e2e.yml | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index 53ed63fd..ce90de7f 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -54,6 +54,13 @@ jobs: responseCode: 200 timeout: 20000 interval: 500 + - name: Wait for prometheus to start + uses: nev7n/wait_for_response@v1 + with: + url: 'http://localhost:9090/' + responseCode: 200 + timeout: 20000 + interval: 500 - name: Install Playwright Browsers run: yarn playwright install --with-deps - name: Run E2E tests From 01724f41e4e37e145959db01f4eeadf261cd6d22 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 8 Mar 2024 05:11:41 -0600 Subject: [PATCH 45/74] more explicit route with response for wait for prometheus --- .github/workflows/e2e.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index ce90de7f..1c1eeed5 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -57,7 +57,7 @@ jobs: - name: Wait for prometheus to start uses: nev7n/wait_for_response@v1 with: - url: 'http://localhost:9090/' + url: 'http://localhost:9090/-/ready' responseCode: 200 timeout: 20000 interval: 500 From d37f5d1449530bc66600e93e6406bb216b4fbddd Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 8 Mar 2024 05:29:39 -0600 Subject: [PATCH 46/74] wait for prometheus health in grafana to be ok --- .github/workflows/e2e.yml | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index 1c1eeed5..dc737eae 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -61,6 +61,13 @@ jobs: responseCode: 200 timeout: 20000 interval: 500 + - name: Wait for prometheus to be configured in grafana + uses: nev7n/wait_for_response@v1 + with: + url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' + responseCode: 200 + timeout: 20000 + interval: 500 - name: Install Playwright Browsers run: yarn playwright install --with-deps - name: Run E2E tests From c1d974ee7f16874a03c6a12ddf7c23be750c7d77 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 8 Mar 2024 10:26:02 -0600 Subject: [PATCH 47/74] check that data source has been provisioned --- .github/workflows/e2e.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index dc737eae..b4d1834d 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -64,7 +64,7 @@ jobs: - name: Wait for prometheus to be configured in grafana uses: nev7n/wait_for_response@v1 with: - url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' + url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon' responseCode: 200 timeout: 20000 interval: 500 From ccce54e34730b9fbe0997f3f87c8f6626944465f Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 8 Mar 2024 10:31:52 -0600 Subject: [PATCH 48/74] add time to wait for grafana w/ prometheus --- .github/workflows/e2e.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index b4d1834d..4ede007f 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -64,9 +64,9 @@ jobs: - name: Wait for prometheus to be configured in grafana uses: nev7n/wait_for_response@v1 with: - url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon' + url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' responseCode: 200 - timeout: 20000 + timeout: 100000 interval: 500 - name: Install Playwright Browsers run: yarn playwright install --with-deps From 27b4f8a99f5ad0cc8358ceb7285c0c62b5a90954 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 8 Mar 2024 11:22:02 -0600 Subject: [PATCH 49/74] start prometheus service first --- .github/workflows/e2e.yml | 10 +++++----- docker-compose-debug.yaml | 3 +++ 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index 4ede007f..d630b259 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -47,17 +47,17 @@ jobs: run: | docker compose -f docker-compose-debug.yaml pull docker compose -f docker-compose-debug.yaml up -d - - name: Wait for grafana to start + - name: Wait for prometheus to start uses: nev7n/wait_for_response@v1 with: - url: 'http://localhost:3099/' + url: 'http://localhost:9090/-/ready' responseCode: 200 timeout: 20000 interval: 500 - - name: Wait for prometheus to start + - name: Wait for grafana to start uses: nev7n/wait_for_response@v1 with: - url: 'http://localhost:9090/-/ready' + url: 'http://localhost:3099/' responseCode: 200 timeout: 20000 interval: 500 @@ -66,7 +66,7 @@ jobs: with: url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' responseCode: 200 - timeout: 100000 + timeout: 20000 interval: 500 - name: Install Playwright Browsers run: yarn playwright install --with-deps diff --git a/docker-compose-debug.yaml b/docker-compose-debug.yaml index 793076b4..aaff2556 100644 --- a/docker-compose-debug.yaml +++ b/docker-compose-debug.yaml @@ -26,5 +26,8 @@ services: volumes: - ./provisioning/datasources:/etc/grafana/provisioning/datasources - ./dist:/var/lib/grafana/plugins/prometheus-amazon + depends_on: + prometheus: + condition: service_started volumes: prom_data: \ No newline at end of file From ed88f555614177e5dddb3e36667e743fb2231fdf Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Fri, 8 Mar 2024 11:32:50 -0600 Subject: [PATCH 50/74] remove healthcheck test --- .github/workflows/e2e.yml | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index d630b259..2c662a8a 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -61,13 +61,13 @@ jobs: responseCode: 200 timeout: 20000 interval: 500 - - name: Wait for prometheus to be configured in grafana - uses: nev7n/wait_for_response@v1 - with: - url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' - responseCode: 200 - timeout: 20000 - interval: 500 + # - name: Wait for prometheus to be configured in grafana + # uses: nev7n/wait_for_response@v1 + # with: + # url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' + # responseCode: 200 + # timeout: 20000 + # interval: 500 - name: Install Playwright Browsers run: yarn playwright install --with-deps - name: Run E2E tests From 685f3b17df553e0c4ec76005314227c5322f7c6b Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Mon, 11 Mar 2024 09:01:06 -0500 Subject: [PATCH 51/74] need to build the backend --- .github/workflows/e2e.yml | 29 +++++++++++++---------------- 1 file changed, 13 insertions(+), 16 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index 2c662a8a..8d2111e6 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -20,26 +20,23 @@ jobs: uses: actions/setup-go@v4 with: go-version: '1.21.6' - + # NOT TESTING THE BACKEND YET # - name: Test backend # uses: magefile/mage-action@v2 # with: # version: latest # args: coverage - # - name: Build backend - # uses: magefile/mage-action@v2 - # with: - # version: latest - # args: buildAll + - name: Build backend + uses: magefile/mage-action@v2 + with: + version: latest + args: buildAll - name: Setup Node uses: actions/setup-node@v3 with: node-version: 20 - name: Install dependencies run: npm install -g yarn && yarn install --frozen-lockfile; - # - name: Spellcheck - # run: | - # yarn spellcheck; - name: Build Frontend run: | yarn build; @@ -61,13 +58,13 @@ jobs: responseCode: 200 timeout: 20000 interval: 500 - # - name: Wait for prometheus to be configured in grafana - # uses: nev7n/wait_for_response@v1 - # with: - # url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' - # responseCode: 200 - # timeout: 20000 - # interval: 500 + - name: Wait for prometheus to be configured in grafana + uses: nev7n/wait_for_response@v1 + with: + url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' + responseCode: 200 + timeout: 20000 + interval: 500 - name: Install Playwright Browsers run: yarn playwright install --with-deps - name: Run E2E tests From bf4d7fab185f24a46e38a2245c687eb7f8c3b340 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Mon, 11 Mar 2024 10:46:49 -0500 Subject: [PATCH 52/74] update data source provisioning files to be simpler --- provisioning/datasources/code-editor.yml | 16 ++++++++-------- provisioning/datasources/datasources.yml | 17 +++++++++-------- 2 files changed, 17 insertions(+), 16 deletions(-) diff --git a/provisioning/datasources/code-editor.yml b/provisioning/datasources/code-editor.yml index f694e721..6c995dd0 100644 --- a/provisioning/datasources/code-editor.yml +++ b/provisioning/datasources/code-editor.yml @@ -8,12 +8,12 @@ datasources: access: proxy editable: true jsonData: - httpMethod: POST - manageAlerts: true - prometheusType: Prometheus - prometheusVersion: 2.44.0 - cacheLevel: 'High' - disableRecordingRules: false - incrementalQueryOverlapWindow: 10m - defaultEditor: code + # httpMethod: POST + # manageAlerts: true + # prometheusType: Prometheus + # prometheusVersion: 2.44.0 + # cacheLevel: 'High' + # disableRecordingRules: false + # incrementalQueryOverlapWindow: 10m + defaultEditor: code \ No newline at end of file diff --git a/provisioning/datasources/datasources.yml b/provisioning/datasources/datasources.yml index ad88de3b..82d47578 100644 --- a/provisioning/datasources/datasources.yml +++ b/provisioning/datasources/datasources.yml @@ -7,12 +7,13 @@ datasources: url: http://prometheus:9090 access: proxy editable: true - # jsonData: - # httpMethod: POST - # manageAlerts: true - # prometheusType: Prometheus - # prometheusVersion: 2.44.0 - # cacheLevel: 'High' - # disableRecordingRules: false - # incrementalQueryOverlapWindow: 10m + jsonData: + # httpMethod: POST + # manageAlerts: true + # prometheusType: Prometheus + # prometheusVersion: 2.44.0 + # cacheLevel: 'High' + # disableRecordingRules: false + # incrementalQueryOverlapWindow: 10m + defaultEditor: builder \ No newline at end of file From 60cff29b23253c09499b4858ab31c7e235c5d06c Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Mon, 11 Mar 2024 10:47:23 -0500 Subject: [PATCH 53/74] add timeouts to query editor e2e tests --- e2e/query-editor.spec.ts | 75 ++++++++++++++++++++++++++++------------ 1 file changed, 52 insertions(+), 23 deletions(-) diff --git a/e2e/query-editor.spec.ts b/e2e/query-editor.spec.ts index 3ede0c35..0bdaa4ad 100644 --- a/e2e/query-editor.spec.ts +++ b/e2e/query-editor.spec.ts @@ -7,6 +7,8 @@ const codeEditorProvFile = 'code-editor.yml'; const metric = 'process_cpu_seconds_total'; +const TIMEOUT = {timeout: 5000} + test.describe('Prometheus query editor', () => { test(`should have the following components: kickstart component @@ -98,10 +100,13 @@ test.describe('Prometheus query editor', () => { await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).focus(); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).isEnabled(TIMEOUT); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton) - .click() + .click(TIMEOUT) await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric)).toBeVisible(); @@ -145,10 +150,13 @@ test.describe('Prometheus query editor', () => { await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).focus(); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).isEnabled(TIMEOUT); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton) - .click() + .click(TIMEOUT) await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric)).toBeVisible(); @@ -175,10 +183,16 @@ test.describe('Prometheus query editor', () => { explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(TIMEOUT); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(TIMEOUT); await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(TIMEOUT); }); test('the query builder contains metric select, label filters and operations', async ({ @@ -190,17 +204,20 @@ test.describe('Prometheus query editor', () => { explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(TIMEOUT); await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); - + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(TIMEOUT); + await explorePage - .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).focus(); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(TIMEOUT); await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect)).toBeVisible(); - + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect)).toBeVisible(TIMEOUT); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).focus(TIMEOUT); + await explorePage .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.matchOperatorSelect).focus(); @@ -222,13 +239,19 @@ test.describe('Prometheus query editor', () => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(TIMEOUT); - await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click() + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(TIMEOUT); - await page.getByText(metric, { exact: true }).click(); + await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click(TIMEOUT) + + await page.getByText(metric, { exact: true }).click(TIMEOUT); const hintText = await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.hints).textContent(); @@ -245,14 +268,17 @@ test.describe('Prometheus query editor', () => { explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage - .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).focus(); + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).isVisible(TIMEOUT); - await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).isEnabled(TIMEOUT); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).focus(TIMEOUT); - await explorePage.getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).click() + await explorePage.getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).click(TIMEOUT) - await page.getByText('__name__', { exact: true }).click(); + await page.getByText('__name__', { exact: true }).click(TIMEOUT); await explorePage.getByTestIdOrAriaLabel(selectors.components.QueryBuilder.valueSelect).click(); @@ -271,14 +297,17 @@ test.describe('Prometheus query editor', () => { explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); - await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(TIMEOUT); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(TIMEOUT); - await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click() + await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click(TIMEOUT); - await page.getByText('Metrics explorer', { exact: true }).click(); + await page.getByText('Metrics explorer', { exact: true }).click(TIMEOUT); await expect(explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricsExplorer)).toBeVisible(); }); From 014ed0c74919385ba9f153b093b15ce132f6475d Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Mon, 11 Mar 2024 10:47:45 -0500 Subject: [PATCH 54/74] add timeouts to variable query editor e2e tests --- e2e/variable-query-editor.spec.ts | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/e2e/variable-query-editor.spec.ts b/e2e/variable-query-editor.spec.ts index dddeda29..581766f4 100644 --- a/e2e/variable-query-editor.spec.ts +++ b/e2e/variable-query-editor.spec.ts @@ -3,6 +3,8 @@ import { selectors } from '@grafana/e2e-selectors'; import { test, expect } from '@grafana/plugin-e2e'; import { PromOptions } from '@grafana/prometheus'; +const TIMEOUT = { timeout: 5000 }; + test.describe('Prometheus variable query editor', () => { test.beforeEach('set query type', async ({ readProvisionedDataSource, @@ -36,7 +38,11 @@ test.describe('Prometheus variable query editor', () => { await page.getByText('Label names', { exact: true }).click(); - await expect(page.getByText('__name__')).toBeVisible(); + await page.getByText('__name__').isVisible(TIMEOUT); + + await page.getByText('__name__').focus(TIMEOUT); + + await expect(page.getByText('__name__')).toBeVisible(TIMEOUT); }); test('label values query variable', async ({ @@ -50,7 +56,11 @@ test.describe('Prometheus variable query editor', () => { await page.getByTestId(selector).click(); - await page.getByText('__name__').click(); + await page.getByText('__name__').isVisible(TIMEOUT); + + await page.getByText('__name__').focus(TIMEOUT); + + await page.getByText('__name__').click(TIMEOUT); await expect(variableEditPage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); @@ -140,8 +150,10 @@ test.describe('Prometheus variable query editor', () => { await variableEditPage.getByTestIdOrAriaLabel(selector).blur(); - await page.getByText('__name__').focus(); + await page.getByText('__name__').isVisible(TIMEOUT); + + await page.getByText('__name__').focus(TIMEOUT); - await expect(page.getByText('__name__')).toBeVisible(); + await expect(page.getByText('__name__')).toBeVisible(TIMEOUT); }); }); From 3d3c3e38efe6fb563853fd1e893706342e2ef128 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Mon, 11 Mar 2024 11:16:12 -0500 Subject: [PATCH 55/74] test checking if visible --- e2e/query-editor.spec.ts | 31 +++++++++++++++++-------------- 1 file changed, 17 insertions(+), 14 deletions(-) diff --git a/e2e/query-editor.spec.ts b/e2e/query-editor.spec.ts index 0bdaa4ad..e5b10678 100644 --- a/e2e/query-editor.spec.ts +++ b/e2e/query-editor.spec.ts @@ -108,26 +108,29 @@ test.describe('Prometheus query editor', () => { .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton) .click(TIMEOUT) + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric).isVisible(TIMEOUT); + await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric)).toBeVisible(); - - await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelNamesFilter)).toBeVisible(); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric)).toBeVisible(TIMEOUT); + + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelNamesFilter).isVisible(TIMEOUT) - await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelValuesFilter)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelValuesFilter).isVisible(TIMEOUT) - await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useQuery)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useQuery).isVisible(TIMEOUT) - await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useAsRateQuery)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useAsRateQuery).isVisible(TIMEOUT) - await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.validateSelector)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.validateSelector).isVisible(TIMEOUT) - await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.clear)).toBeVisible(); + await explorePage + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.clear).isVisible(TIMEOUT) }); test('selects a metric in the metrics browser and uses the query', async ({ From 53cb73e6d3036b71b31e0f475793b6534e3cf412 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Mon, 11 Mar 2024 12:06:12 -0500 Subject: [PATCH 56/74] add e2e video storage --- .github/workflows/e2e.yml | 9 ++++++++- playwright.config.ts | 4 ++++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index 8d2111e6..b4ae5daa 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -69,13 +69,20 @@ jobs: run: yarn playwright install --with-deps - name: Run E2E tests run: yarn test:e2e - - name: Run E2E artifacts + - name: Run E2E report uses: actions/upload-artifact@v3 if: always() with: name: playwright-report path: playwright-report/ retention-days: 30 + - name: Run E2E videos + uses: actions/upload-artifact@v3 + if: always() + with: + name: test-results + path: test-results/ + retention-days: 30 - name: Stop the docker container if: always() run: docker-compose -f docker-compose-debug.yaml down \ No newline at end of file diff --git a/playwright.config.ts b/playwright.config.ts index 641c555a..7548956a 100644 --- a/playwright.config.ts +++ b/playwright.config.ts @@ -28,6 +28,10 @@ export default defineConfig({ /* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */ trace: 'on-first-retry', + + video: { + mode: 'on', + }, }, /* Configure projects for major browsers */ From 79b889af41c89f38a950ade4a25d4ca2d4ecf014 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Mon, 11 Mar 2024 12:32:38 -0500 Subject: [PATCH 57/74] use async await for setting data source --- e2e/query-editor.spec.ts | 37 ++++++++++++++++++++----------------- 1 file changed, 20 insertions(+), 17 deletions(-) diff --git a/e2e/query-editor.spec.ts b/e2e/query-editor.spec.ts index e5b10678..462e0b63 100644 --- a/e2e/query-editor.spec.ts +++ b/e2e/query-editor.spec.ts @@ -2,6 +2,7 @@ import { DataSourcePluginOptionsEditorProps } from '@grafana/data'; import { selectors } from '@grafana/e2e-selectors'; import { test, expect } from '@grafana/plugin-e2e'; import { PromOptions } from '@grafana/prometheus'; +import { chromium } from '@playwright/test'; const codeEditorProvFile = 'code-editor.yml'; @@ -27,7 +28,7 @@ test.describe('Prometheus query editor', () => { }) => { const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); - explorePage.datasource.set(ds.name); + await explorePage.datasource.set(ds.name); // query patterns await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.queryPatterns)).toBeVisible(); @@ -75,7 +76,7 @@ test.describe('Prometheus query editor', () => { }) => { const dsCodeEditor = await readProvisionedDataSource>({ fileName: codeEditorProvFile }); - explorePage.datasource.set(dsCodeEditor.name); + await explorePage.datasource.set(dsCodeEditor.name); await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField)).toBeVisible(); @@ -84,10 +85,10 @@ test.describe('Prometheus query editor', () => { test('it navigates to the code editor and opens the metrics browser with metric search, labels, label values, and all components', async ({ readProvisionedDataSource, explorePage - }) => { + }) => { const dsCodeEditor = await readProvisionedDataSource>({ fileName: codeEditorProvFile }); - explorePage.datasource.set(dsCodeEditor.name); + await explorePage.datasource.set(dsCodeEditor.name); await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField)).toBeVisible(); @@ -113,24 +114,26 @@ test.describe('Prometheus query editor', () => { await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric)).toBeVisible(TIMEOUT); - + await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelNamesFilter).isVisible(TIMEOUT) + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelNamesFilter).isVisible(TIMEOUT); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelValuesFilter).isVisible(TIMEOUT) + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelValuesFilter).isVisible(TIMEOUT); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useQuery).isVisible(TIMEOUT) + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useQuery).isVisible(TIMEOUT); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useAsRateQuery).isVisible(TIMEOUT) + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useAsRateQuery).isVisible(TIMEOUT); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.validateSelector).isVisible(TIMEOUT) + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.validateSelector).isVisible(TIMEOUT); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.clear).isVisible(TIMEOUT) + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.clear).isVisible(TIMEOUT); + + }); test('selects a metric in the metrics browser and uses the query', async ({ @@ -140,7 +143,7 @@ test.describe('Prometheus query editor', () => { }) => { const dsCodeEditor = await readProvisionedDataSource>({ fileName: codeEditorProvFile }); - explorePage.datasource.set(dsCodeEditor.name); + await explorePage.datasource.set(dsCodeEditor.name); await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField)).toBeVisible(); @@ -183,7 +186,7 @@ test.describe('Prometheus query editor', () => { }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); - explorePage.datasource.set(dsDefaultEditorBuilder.name); + await explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); @@ -204,7 +207,7 @@ test.describe('Prometheus query editor', () => { }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); - explorePage.datasource.set(dsDefaultEditorBuilder.name); + await explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(TIMEOUT); @@ -241,7 +244,7 @@ test.describe('Prometheus query editor', () => { }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); - explorePage.datasource.set(dsDefaultEditorBuilder.name); + await explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); @@ -268,7 +271,7 @@ test.describe('Prometheus query editor', () => { }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); - explorePage.datasource.set(dsDefaultEditorBuilder.name); + await explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).isVisible(TIMEOUT); @@ -297,7 +300,7 @@ test.describe('Prometheus query editor', () => { }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); - explorePage.datasource.set(dsDefaultEditorBuilder.name); + await explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); From 64e24978b00d91bb4102a5edfb97c4abcc7db292 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Mon, 11 Mar 2024 12:51:09 -0500 Subject: [PATCH 58/74] retain videos on failure --- playwright.config.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/playwright.config.ts b/playwright.config.ts index 7548956a..d297f220 100644 --- a/playwright.config.ts +++ b/playwright.config.ts @@ -30,7 +30,7 @@ export default defineConfig({ trace: 'on-first-retry', video: { - mode: 'on', + mode: 'retain-on-failure', }, }, From 2acd4020f03151bf6d52ce45e18dfe1d83cfb2cb Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Mon, 11 Mar 2024 12:59:38 -0500 Subject: [PATCH 59/74] test with explicit navigation to explore page --- e2e/query-editor.spec.ts | 20 ++++++++++++++++++-- 1 file changed, 18 insertions(+), 2 deletions(-) diff --git a/e2e/query-editor.spec.ts b/e2e/query-editor.spec.ts index 462e0b63..eb86550e 100644 --- a/e2e/query-editor.spec.ts +++ b/e2e/query-editor.spec.ts @@ -28,6 +28,8 @@ test.describe('Prometheus query editor', () => { }) => { const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + await explorePage.goto(); + await explorePage.datasource.set(ds.name); // query patterns await expect(explorePage @@ -76,6 +78,8 @@ test.describe('Prometheus query editor', () => { }) => { const dsCodeEditor = await readProvisionedDataSource>({ fileName: codeEditorProvFile }); + await explorePage.goto(); + await explorePage.datasource.set(dsCodeEditor.name); await expect(explorePage @@ -88,6 +92,8 @@ test.describe('Prometheus query editor', () => { }) => { const dsCodeEditor = await readProvisionedDataSource>({ fileName: codeEditorProvFile }); + await explorePage.goto(); + await explorePage.datasource.set(dsCodeEditor.name); await expect(explorePage @@ -132,8 +138,6 @@ test.describe('Prometheus query editor', () => { await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.clear).isVisible(TIMEOUT); - - }); test('selects a metric in the metrics browser and uses the query', async ({ @@ -143,6 +147,8 @@ test.describe('Prometheus query editor', () => { }) => { const dsCodeEditor = await readProvisionedDataSource>({ fileName: codeEditorProvFile }); + await explorePage.goto(); + await explorePage.datasource.set(dsCodeEditor.name); await expect(explorePage @@ -186,6 +192,8 @@ test.describe('Prometheus query editor', () => { }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + await explorePage.goto(); + await explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage @@ -207,6 +215,8 @@ test.describe('Prometheus query editor', () => { }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + await explorePage.goto(); + await explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage @@ -244,6 +254,8 @@ test.describe('Prometheus query editor', () => { }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + await explorePage.goto(); + await explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage @@ -271,6 +283,8 @@ test.describe('Prometheus query editor', () => { }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + await explorePage.goto(); + await explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage @@ -300,6 +314,8 @@ test.describe('Prometheus query editor', () => { }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + await explorePage.goto(); + await explorePage.datasource.set(dsDefaultEditorBuilder.name); await explorePage From 356176b8a78af3f752d9653b18c4c2eb34480b37 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Mon, 11 Mar 2024 13:37:49 -0500 Subject: [PATCH 60/74] explicitly change the data source picker --- e2e/query-editor.spec.ts | 54 +++++++++++++++++++----- provisioning/datasources/code-editor.yml | 4 +- 2 files changed, 45 insertions(+), 13 deletions(-) diff --git a/e2e/query-editor.spec.ts b/e2e/query-editor.spec.ts index eb86550e..35857ed5 100644 --- a/e2e/query-editor.spec.ts +++ b/e2e/query-editor.spec.ts @@ -188,13 +188,20 @@ test.describe('Prometheus query editor', () => { test.describe('Query builder', () => { test('it navigates to the query builder with default editor type as builder', async ({ readProvisionedDataSource, - explorePage + explorePage, + page, }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); await explorePage.goto(); - await explorePage.datasource.set(dsDefaultEditorBuilder.name); + // await explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await page.getByTestId('data-testid Select a data source').click(); + + await page.getByTestId('data-testid Select a data source').fill('Prometheus-amazon'); + + await page.getByRole('button', { name: 'Prometheus-amazon Prometheus' }).click(); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); @@ -211,13 +218,20 @@ test.describe('Prometheus query editor', () => { test('the query builder contains metric select, label filters and operations', async ({ readProvisionedDataSource, - explorePage + explorePage, + page, }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); await explorePage.goto(); - await explorePage.datasource.set(dsDefaultEditorBuilder.name); + // await explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await page.getByTestId('data-testid Select a data source').click(); + + await page.getByTestId('data-testid Select a data source').fill('Prometheus-amazon'); + + await page.getByRole('button', { name: 'Prometheus-amazon Prometheus' }).click(); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(TIMEOUT); @@ -250,14 +264,20 @@ test.describe('Prometheus query editor', () => { test('it can select a metric and provide a hint', async ({ readProvisionedDataSource, explorePage, - page + page, }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); await explorePage.goto(); - await explorePage.datasource.set(dsDefaultEditorBuilder.name); - + // await explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await page.getByTestId('data-testid Select a data source').click(); + + await page.getByTestId('data-testid Select a data source').fill('Prometheus-amazon'); + + await page.getByRole('button', { name: 'Prometheus-amazon Prometheus' }).click(); + await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); @@ -279,13 +299,19 @@ test.describe('Prometheus query editor', () => { test('it can select a label filter and run a query', async ({ readProvisionedDataSource, explorePage, - page + page, }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); await explorePage.goto(); - await explorePage.datasource.set(dsDefaultEditorBuilder.name); + // await explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await page.getByTestId('data-testid Select a data source').click(); + + await page.getByTestId('data-testid Select a data source').fill('Prometheus-amazon'); + + await page.getByRole('button', { name: 'Prometheus-amazon Prometheus' }).click(); await explorePage .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).isVisible(TIMEOUT); @@ -310,13 +336,19 @@ test.describe('Prometheus query editor', () => { test('it should have the metrics explorer opened via the metric select', async ({ readProvisionedDataSource, explorePage, - page + page, }) => { const dsDefaultEditorBuilder = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); await explorePage.goto(); - await explorePage.datasource.set(dsDefaultEditorBuilder.name); + // await explorePage.datasource.set(dsDefaultEditorBuilder.name); + + await page.getByTestId('data-testid Select a data source').click(); + + await page.getByTestId('data-testid Select a data source').fill('Prometheus-amazon'); + + await page.getByRole('button', { name: 'Prometheus-amazon Prometheus' }).click(); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); diff --git a/provisioning/datasources/code-editor.yml b/provisioning/datasources/code-editor.yml index 6c995dd0..e4341faf 100644 --- a/provisioning/datasources/code-editor.yml +++ b/provisioning/datasources/code-editor.yml @@ -1,8 +1,8 @@ apiVersion: 1 datasources: -- name: Prometheus-amazon-code - uid: prometheus-amazon-code-editor +- name: a-prometheus-code-editor + uid: a-prometheus-code-editor type: prometheus-amazon-datasource url: http://prometheus:9090 access: proxy From 297860e3c3110997cbf9e5c31a4f73aea2ab48bd Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 09:33:19 -0500 Subject: [PATCH 61/74] update checkout and setup go to use caching --- .github/workflows/e2e.yml | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index b4ae5daa..fe277d92 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -15,11 +15,15 @@ jobs: runs-on: ubuntu-latest steps: - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Setup Go environment - uses: actions/setup-go@v4 + uses: actions/setup-go@v5 with: go-version: '1.21.6' + check-latest: true + cache-dependency-path: | + subdir/go.sum + tools/go.sum # NOT TESTING THE BACKEND YET # - name: Test backend # uses: magefile/mage-action@v2 From 0576175235e5de2910dd31dd3fdbb421b0e2d2aa Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 09:43:14 -0500 Subject: [PATCH 62/74] remove reports from git --- .gitignore | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index 6c5768ba..43008d5f 100644 --- a/.gitignore +++ b/.gitignore @@ -34,6 +34,7 @@ e2e-results/ .eslintcache /test-results/ -# /playwright-report/ +/playwright-report/ /blob-report/ /playwright/.cache/ +/playwright/.auth/ From 9412e6a28844f479b5f6daec626839504df40903 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 16:19:52 -0500 Subject: [PATCH 63/74] remove unnecessary code --- e2e/annotation-editor.spec.ts | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/e2e/annotation-editor.spec.ts b/e2e/annotation-editor.spec.ts index 4a4aa2e5..13d90187 100644 --- a/e2e/annotation-editor.spec.ts +++ b/e2e/annotation-editor.spec.ts @@ -6,13 +6,16 @@ import { PromOptions } from '@grafana/prometheus'; test.describe('Prometheus annotation query editor', () => { test('Check that the editor uses the code editor', async ({ readProvisionedDataSource, - annotationEditPage + annotationEditPage, + page, }) => { const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); + + await page.getByTestId('data-testid Select a data source').click(); - await annotationEditPage.datasource.set(ds.name); - await annotationEditPage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField).focus(); + await page.getByTestId('data-testid Select a data source').fill(ds.name); + + await page.getByRole('button', { name: `${ds.name} Prometheus` }).click(); await expect(annotationEditPage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.queryField)).toBeVisible(); From b68ceb614fac81926e890e9f00315d32e9d0254f Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 16:23:11 -0500 Subject: [PATCH 64/74] remove deleteDataSourceAfterTest and use toHaveAlert in config tests --- e2e/configuration.spec.ts | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/e2e/configuration.spec.ts b/e2e/configuration.spec.ts index 2b24eda1..c5cdd2d4 100644 --- a/e2e/configuration.spec.ts +++ b/e2e/configuration.spec.ts @@ -26,7 +26,7 @@ test.describe('Configuration tests', () => { page, }) => { const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); - const configPage = await createDataSourceConfigPage({type: ds.type, deleteDataSourceAfterTest: true}); + const configPage = await createDataSourceConfigPage({ type: ds.type }); // connection settings await expect(configPage @@ -82,7 +82,7 @@ test.describe('Configuration tests', () => { readProvisionedDataSource, }) => { const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); - const configPage = await createDataSourceConfigPage({ type: ds.type, deleteDataSourceAfterTest: true, }); + const configPage = await createDataSourceConfigPage({ type: ds.type }); await configPage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.configPage.connectionSettings) @@ -96,10 +96,9 @@ test.describe('Configuration tests', () => { readProvisionedDataSource, }) => { const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); - const configPage = await createDataSourceConfigPage({ type: ds.type, deleteDataSourceAfterTest: true, }); + const configPage = await createDataSourceConfigPage({ type: ds.type }); await expect(configPage.saveAndTest()).not.toBeOK(); - const alertMessage = await configPage.getByTestIdOrAriaLabel('data-testid Alert error').textContent(); - await expect(alertMessage).toContain('empty url') + await expect(configPage).toHaveAlert('error', { hasText: 'empty url' }); }); test('it should allow a user to add the version when the Prom type is selected', @@ -113,7 +112,6 @@ test.describe('Configuration tests', () => { const configPage = await createDataSourceConfigPage({ type: "prometheus-amazon-datasource", name: DATA_SOURCE_NAME, - deleteDataSourceAfterTest: true, }); await expect(configPage @@ -146,7 +144,6 @@ test.describe('Configuration tests', () => { const configPage = await createDataSourceConfigPage({ type: "prometheus-amazon-datasource", name: DATA_SOURCE_NAME + "check", - deleteDataSourceAfterTest: true, }); const incrementalQuerying = await page From 8e3b0cd9335728baf5dc2ff6ca0ada9d7dd5bcaf Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 16:29:22 -0500 Subject: [PATCH 65/74] update plugin-e2e version --- package.json | 2 +- yarn.lock | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/package.json b/package.json index 846b2d0b..f91a439f 100644 --- a/package.json +++ b/package.json @@ -21,7 +21,7 @@ "@grafana/e2e": "11.0.0-162805", "@grafana/e2e-selectors": "11.0.0-162805", "@grafana/eslint-config": "6.0.1", - "@grafana/plugin-e2e": "0.17.1", + "@grafana/plugin-e2e": "0.19.0", "@grafana/tsconfig": "1.3.0-rc1", "@playwright/test": "^1.41.2", "@sentry/browser": "7.102.0", diff --git a/yarn.lock b/yarn.lock index ee3fc933..a236077d 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1478,10 +1478,10 @@ ua-parser-js "^1.0.32" web-vitals "^3.1.1" -"@grafana/plugin-e2e@0.17.1": - version "0.17.1" - resolved "https://registry.yarnpkg.com/@grafana/plugin-e2e/-/plugin-e2e-0.17.1.tgz#c8cbcda5e60c2a4e0b10e3966e8ab27fae6bb93b" - integrity sha512-VyFJKwGzK+/f0R/SitPmDoRLe952gOcJWgkaUikxr/58KFLAPwuwZvvPhK4Gyjkz2Rwcl6NE3AplU2jgoS0r6A== +"@grafana/plugin-e2e@0.19.0": + version "0.19.0" + resolved "https://registry.yarnpkg.com/@grafana/plugin-e2e/-/plugin-e2e-0.19.0.tgz#17710d7cf2ad75685b6b1aee7ac54ae972e3fe7d" + integrity sha512-oPtqIdUX8+dkZPz02lkbnGKYSCZPcMoYNvqLKqfSIgC0aM/7AEO1HsihteP0ZfPcDig7CPV/IBlpG6Nm0BJCtw== dependencies: semver "^7.5.4" uuid "^9.0.1" From 62955e18112de2836136bbae047c8b91f733d1f4 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 16:40:16 -0500 Subject: [PATCH 66/74] test with plugin-e2e auth instead of anonymous admin --- docker-compose-debug.yaml | 4 ++-- playwright.config.ts | 16 ++++++++++++++-- 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/docker-compose-debug.yaml b/docker-compose-debug.yaml index aaff2556..2b2bdd1e 100644 --- a/docker-compose-debug.yaml +++ b/docker-compose-debug.yaml @@ -19,8 +19,8 @@ services: restart: unless-stopped environment: - GF_DEFAULT_APP_MODE=development - - GF_AUTH_ANONYMOUS_ORG_ROLE=Admin - - GF_AUTH_ANONYMOUS_ENABLED=true + # - GF_AUTH_ANONYMOUS_ORG_ROLE=Admin + # - GF_AUTH_ANONYMOUS_ENABLED=true - GF_AUTH_BASIC_ENABLED=false - GF_SERVER_HTTP_PORT=3099 volumes: diff --git a/playwright.config.ts b/playwright.config.ts index d297f220..dfed64d3 100644 --- a/playwright.config.ts +++ b/playwright.config.ts @@ -1,4 +1,7 @@ import { defineConfig, devices } from '@playwright/test'; +import { dirname } from 'path'; + +const pluginE2eAuth = `${dirname(require.resolve('@grafana/plugin-e2e'))}/auth`; /** * Read environment variables from file. @@ -37,9 +40,18 @@ export default defineConfig({ /* Configure projects for major browsers */ projects: [ { - name: 'data source', - use: { ...devices['Desktop Chrome']}, + name: 'auth', + testDir: pluginE2eAuth, + testMatch: [/.*\.js/], }, + { + name: 'run-tests', + use: { + ...devices['Desktop Chrome'], + storageState: 'playwright/.auth/admin.json', + }, + dependencies: ['auth'], + } ], // projects: [ // { From e6cb8bffb40b09c310a9ede00947528641e6ea99 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 16:43:19 -0500 Subject: [PATCH 67/74] remove await from autowaiting actions --- e2e/configuration.spec.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/e2e/configuration.spec.ts b/e2e/configuration.spec.ts index c5cdd2d4..4a42bc05 100644 --- a/e2e/configuration.spec.ts +++ b/e2e/configuration.spec.ts @@ -149,12 +149,12 @@ test.describe('Configuration tests', () => { const incrementalQuerying = await page .locator(`#${selectors.components.DataSource.Prometheus.configPage.incrementalQuerying}`) - expect(await incrementalQuerying).toBeVisible(); + expect(incrementalQuerying).toBeVisible(); await page.getByLabel('Toggle switch').nth(3).setChecked(true); expect( - await configPage + configPage .getByTestIdOrAriaLabel( selectors.components.DataSource.Prometheus.configPage.queryOverlapWindow ) From 6af301024c1da7d46ed4c2d56e4693e4daf05cba Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 16:53:45 -0500 Subject: [PATCH 68/74] set default timeout to 10s for tests --- e2e/query-editor.spec.ts | 74 +++++++++++++++---------------- e2e/variable-query-editor.spec.ts | 20 ++++----- playwright.config.ts | 2 + 3 files changed, 47 insertions(+), 49 deletions(-) diff --git a/e2e/query-editor.spec.ts b/e2e/query-editor.spec.ts index 35857ed5..3ebb13e8 100644 --- a/e2e/query-editor.spec.ts +++ b/e2e/query-editor.spec.ts @@ -8,8 +8,6 @@ const codeEditorProvFile = 'code-editor.yml'; const metric = 'process_cpu_seconds_total'; -const TIMEOUT = {timeout: 5000} - test.describe('Prometheus query editor', () => { test(`should have the following components: kickstart component @@ -109,35 +107,35 @@ test.describe('Prometheus query editor', () => { .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).focus(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).isEnabled(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).isEnabled(); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton) - .click(TIMEOUT) + .click() await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric).isVisible(); await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric)).toBeVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric)).toBeVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelNamesFilter).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelNamesFilter).isVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelValuesFilter).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.labelValuesFilter).isVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useQuery).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useQuery).isVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useAsRateQuery).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.useAsRateQuery).isVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.validateSelector).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.validateSelector).isVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.clear).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.clear).isVisible(); }); test('selects a metric in the metrics browser and uses the query', async ({ @@ -164,11 +162,11 @@ test.describe('Prometheus query editor', () => { .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).focus(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).isEnabled(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton).isEnabled(); await explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.openButton) - .click(TIMEOUT) + .click() await expect(explorePage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.code.metricsBrowser.selectMetric)).toBeVisible(); @@ -204,16 +202,16 @@ test.describe('Prometheus query editor', () => { await page.getByRole('button', { name: 'Prometheus-amazon Prometheus' }).click(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(); await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); }); test('the query builder contains metric select, label filters and operations', async ({ @@ -234,19 +232,19 @@ test.describe('Prometheus query editor', () => { await page.getByRole('button', { name: 'Prometheus-amazon Prometheus' }).click(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(); await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); await expect(explorePage - .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect)).toBeVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect)).toBeVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).focus(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).focus(); await explorePage .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.matchOperatorSelect).focus(); @@ -279,17 +277,17 @@ test.describe('Prometheus query editor', () => { await page.getByRole('button', { name: 'Prometheus-amazon Prometheus' }).click(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); - await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click(TIMEOUT) + await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click() - await page.getByText(metric, { exact: true }).click(TIMEOUT); + await page.getByText(metric, { exact: true }).click(); const hintText = await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.hints).textContent(); @@ -314,17 +312,17 @@ test.describe('Prometheus query editor', () => { await page.getByRole('button', { name: 'Prometheus-amazon Prometheus' }).click(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).isVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).isEnabled(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).isEnabled(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).focus(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).focus(); - await explorePage.getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).click(TIMEOUT) + await explorePage.getByTestIdOrAriaLabel(selectors.components.QueryBuilder.labelSelect).click() - await page.getByText('__name__', { exact: true }).click(TIMEOUT); + await page.getByText('__name__', { exact: true }).click(); await explorePage.getByTestIdOrAriaLabel(selectors.components.QueryBuilder.valueSelect).click(); @@ -351,17 +349,17 @@ test.describe('Prometheus query editor', () => { await page.getByRole('button', { name: 'Prometheus-amazon Prometheus' }).click(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isVisible(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).isEnabled(); await explorePage - .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(TIMEOUT); + .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).focus(); - await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click(TIMEOUT); + await explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect).click(); - await page.getByText('Metrics explorer', { exact: true }).click(TIMEOUT); + await page.getByText('Metrics explorer', { exact: true }).click(); await expect(explorePage.getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricsExplorer)).toBeVisible(); }); diff --git a/e2e/variable-query-editor.spec.ts b/e2e/variable-query-editor.spec.ts index 581766f4..53c0b112 100644 --- a/e2e/variable-query-editor.spec.ts +++ b/e2e/variable-query-editor.spec.ts @@ -3,8 +3,6 @@ import { selectors } from '@grafana/e2e-selectors'; import { test, expect } from '@grafana/plugin-e2e'; import { PromOptions } from '@grafana/prometheus'; -const TIMEOUT = { timeout: 5000 }; - test.describe('Prometheus variable query editor', () => { test.beforeEach('set query type', async ({ readProvisionedDataSource, @@ -38,11 +36,11 @@ test.describe('Prometheus variable query editor', () => { await page.getByText('Label names', { exact: true }).click(); - await page.getByText('__name__').isVisible(TIMEOUT); + await page.getByText('__name__').isVisible(); - await page.getByText('__name__').focus(TIMEOUT); + await page.getByText('__name__').focus(); - await expect(page.getByText('__name__')).toBeVisible(TIMEOUT); + await expect(page.getByText('__name__')).toBeVisible(); }); test('label values query variable', async ({ @@ -56,11 +54,11 @@ test.describe('Prometheus variable query editor', () => { await page.getByTestId(selector).click(); - await page.getByText('__name__').isVisible(TIMEOUT); + await page.getByText('__name__').isVisible(); - await page.getByText('__name__').focus(TIMEOUT); + await page.getByText('__name__').focus(); - await page.getByText('__name__').click(TIMEOUT); + await page.getByText('__name__').click(); await expect(variableEditPage .getByTestIdOrAriaLabel(selectors.components.DataSource.Prometheus.queryEditor.builder.metricSelect)).toBeVisible(); @@ -150,10 +148,10 @@ test.describe('Prometheus variable query editor', () => { await variableEditPage.getByTestIdOrAriaLabel(selector).blur(); - await page.getByText('__name__').isVisible(TIMEOUT); + await page.getByText('__name__').isVisible(); - await page.getByText('__name__').focus(TIMEOUT); + await page.getByText('__name__').focus(); - await expect(page.getByText('__name__')).toBeVisible(TIMEOUT); + await expect(page.getByText('__name__')).toBeVisible(); }); }); diff --git a/playwright.config.ts b/playwright.config.ts index dfed64d3..22f73271 100644 --- a/playwright.config.ts +++ b/playwright.config.ts @@ -24,6 +24,8 @@ export default defineConfig({ workers: process.env.CI ? 1 : undefined, /* Reporter to use. See https://playwright.dev/docs/test-reporters */ reporter: 'html', + /* Timeout for each test in milliseconds. Defaults to 30 seconds. */ + timeout: 10000, /* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */ use: { /* Base URL to use in actions like `await page.goto('/')`. */ From 673e9b87b7196fdd9a57d4cf92d66b4028e1fbf3 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 17:01:03 -0500 Subject: [PATCH 69/74] remove unused code --- e2e/configuration.spec.ts | 1 - e2e/variable-query-editor.spec.ts | 7 ------- 2 files changed, 8 deletions(-) diff --git a/e2e/configuration.spec.ts b/e2e/configuration.spec.ts index 4a42bc05..34f4b54c 100644 --- a/e2e/configuration.spec.ts +++ b/e2e/configuration.spec.ts @@ -136,7 +136,6 @@ test.describe('Configuration tests', () => { test('it should allow a user to select a query overlap window when incremental querying is selected', async ({ createDataSourceConfigPage, - readProvisionedDataSource, page, }) => { // const ds = await readProvisionedDataSource>({ fileName: 'datasources.yml' }); diff --git a/e2e/variable-query-editor.spec.ts b/e2e/variable-query-editor.spec.ts index 53c0b112..c26ca32f 100644 --- a/e2e/variable-query-editor.spec.ts +++ b/e2e/variable-query-editor.spec.ts @@ -28,8 +28,6 @@ test.describe('Prometheus variable query editor', () => { }); test('label names query variable', async ({ - readProvisionedDataSource, - variableEditPage, page, }) => { await expect(page.getByText('Label names', { exact: true })).toBeVisible(); @@ -44,7 +42,6 @@ test.describe('Prometheus variable query editor', () => { }); test('label values query variable', async ({ - readProvisionedDataSource, variableEditPage, page, }) => { @@ -76,7 +73,6 @@ test.describe('Prometheus variable query editor', () => { }); test('Metrics query variable', async ({ - readProvisionedDataSource, variableEditPage, page, }) => { @@ -94,7 +90,6 @@ test.describe('Prometheus variable query editor', () => { }); test('Query result query variable', async ({ - readProvisionedDataSource, variableEditPage, page, }) => { @@ -114,7 +109,6 @@ test.describe('Prometheus variable query editor', () => { }); test('Series query variable', async ({ - readProvisionedDataSource, variableEditPage, page, }) => { @@ -134,7 +128,6 @@ test.describe('Prometheus variable query editor', () => { }); test('Classic query variable', async ({ - readProvisionedDataSource, variableEditPage, page, }) => { From b86b09a5683b5748d1b997444c0a2fdfca3355a1 Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 17:15:43 -0500 Subject: [PATCH 70/74] try fixing caching --- .github/workflows/e2e.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index fe277d92..e6a663ff 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -21,9 +21,7 @@ jobs: with: go-version: '1.21.6' check-latest: true - cache-dependency-path: | - subdir/go.sum - tools/go.sum + cache-dependency-path: "**/*.sum" # NOT TESTING THE BACKEND YET # - name: Test backend # uses: magefile/mage-action@v2 @@ -39,6 +37,8 @@ jobs: uses: actions/setup-node@v3 with: node-version: 20 + cache: 'yarn' + cache-dependency-path: '**/package-lock.json' - name: Install dependencies run: npm install -g yarn && yarn install --frozen-lockfile; - name: Build Frontend From 9b7df1ab9dd00240f2a91af0f439a1cb4b7274eb Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 17:18:38 -0500 Subject: [PATCH 71/74] fix caching --- .github/workflows/e2e.yml | 2 -- 1 file changed, 2 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index e6a663ff..f8151ba3 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -37,8 +37,6 @@ jobs: uses: actions/setup-node@v3 with: node-version: 20 - cache: 'yarn' - cache-dependency-path: '**/package-lock.json' - name: Install dependencies run: npm install -g yarn && yarn install --frozen-lockfile; - name: Build Frontend From ef48b54b809fd6079a7fac90de49c866c359a08b Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Tue, 12 Mar 2024 17:25:10 -0500 Subject: [PATCH 72/74] remove healthcheck because anonymous auth was removed --- .github/workflows/e2e.yml | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index f8151ba3..ae97d48d 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -60,13 +60,13 @@ jobs: responseCode: 200 timeout: 20000 interval: 500 - - name: Wait for prometheus to be configured in grafana - uses: nev7n/wait_for_response@v1 - with: - url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' - responseCode: 200 - timeout: 20000 - interval: 500 + # - name: Wait for prometheus to be configured in grafana + # uses: nev7n/wait_for_response@v1 + # with: + # url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' + # responseCode: 200 + # timeout: 20000 + # interval: 500 - name: Install Playwright Browsers run: yarn playwright install --with-deps - name: Run E2E tests From f53f78593205485a201e47b9384b4cef9d9d3fcd Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 13 Mar 2024 13:57:15 -0500 Subject: [PATCH 73/74] yarn cache workflow --- .github/workflows/e2e.yml | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index ae97d48d..b3caaca7 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -37,6 +37,9 @@ jobs: uses: actions/setup-node@v3 with: node-version: 20 + check-latest: true + cache: 'yarn' + cache-dependency-path: '**/package-lock.json' - name: Install dependencies run: npm install -g yarn && yarn install --frozen-lockfile; - name: Build Frontend @@ -60,13 +63,6 @@ jobs: responseCode: 200 timeout: 20000 interval: 500 - # - name: Wait for prometheus to be configured in grafana - # uses: nev7n/wait_for_response@v1 - # with: - # url: 'http://localhost:3099/api/datasources/uid/prometheus-amazon/health' - # responseCode: 200 - # timeout: 20000 - # interval: 500 - name: Install Playwright Browsers run: yarn playwright install --with-deps - name: Run E2E tests From 6440d59318e6f7da3da99fd86a119e526f922b3e Mon Sep 17 00:00:00 2001 From: Brendan O'Handley Date: Wed, 13 Mar 2024 14:16:41 -0500 Subject: [PATCH 74/74] yarn cache workflow fix --- .github/workflows/e2e.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/e2e.yml b/.github/workflows/e2e.yml index b3caaca7..d5c93d7c 100644 --- a/.github/workflows/e2e.yml +++ b/.github/workflows/e2e.yml @@ -39,7 +39,6 @@ jobs: node-version: 20 check-latest: true cache: 'yarn' - cache-dependency-path: '**/package-lock.json' - name: Install dependencies run: npm install -g yarn && yarn install --frozen-lockfile; - name: Build Frontend