generated from nhcarrigan/template
Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| a4e7545275 |
+4
-4
@@ -20,11 +20,11 @@
|
|||||||
"@types/node": "25.2.0",
|
"@types/node": "25.2.0",
|
||||||
"@types/node-cron": "3.0.11",
|
"@types/node-cron": "3.0.11",
|
||||||
"@types/semver": "7.7.1",
|
"@types/semver": "7.7.1",
|
||||||
"@vitest/coverage-istanbul": "4.1.0",
|
"@vitest/coverage-istanbul": "^4.0.18",
|
||||||
"@vitest/coverage-v8": "4.0.18",
|
"@vitest/coverage-v8": "^4.0.18",
|
||||||
"eslint": "9.39.2",
|
"eslint": "10.0.0",
|
||||||
"typescript": "5.9.3",
|
"typescript": "5.9.3",
|
||||||
"vitest": "4.0.18"
|
"vitest": "^4.0.18"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@nhcarrigan/logger": "1.1.1",
|
"@nhcarrigan/logger": "1.1.1",
|
||||||
|
|||||||
Generated
+193
-190
@@ -23,7 +23,7 @@ importers:
|
|||||||
devDependencies:
|
devDependencies:
|
||||||
'@nhcarrigan/eslint-config':
|
'@nhcarrigan/eslint-config':
|
||||||
specifier: 5.2.0
|
specifier: 5.2.0
|
||||||
version: 5.2.0(@typescript-eslint/utils@8.54.0(eslint@9.39.2)(typescript@5.9.3))(eslint@9.39.2)(playwright@1.58.1)(react@19.2.4)(typescript@5.9.3)(vitest@4.0.18(@types/node@25.2.0))
|
version: 5.2.0(@typescript-eslint/utils@8.54.0(eslint@10.0.0)(typescript@5.9.3))(eslint@10.0.0)(playwright@1.58.1)(react@19.2.4)(typescript@5.9.3)(vitest@4.0.18(@types/node@25.2.0))
|
||||||
'@nhcarrigan/typescript-config':
|
'@nhcarrigan/typescript-config':
|
||||||
specifier: 4.0.0
|
specifier: 4.0.0
|
||||||
version: 4.0.0(typescript@5.9.3)
|
version: 4.0.0(typescript@5.9.3)
|
||||||
@@ -37,19 +37,19 @@ importers:
|
|||||||
specifier: 7.7.1
|
specifier: 7.7.1
|
||||||
version: 7.7.1
|
version: 7.7.1
|
||||||
'@vitest/coverage-istanbul':
|
'@vitest/coverage-istanbul':
|
||||||
specifier: 4.1.0
|
specifier: ^4.0.18
|
||||||
version: 4.1.0(vitest@4.0.18(@types/node@25.2.0))
|
version: 4.0.18(vitest@4.0.18(@types/node@25.2.0))
|
||||||
'@vitest/coverage-v8':
|
'@vitest/coverage-v8':
|
||||||
specifier: 4.0.18
|
specifier: ^4.0.18
|
||||||
version: 4.0.18(vitest@4.0.18(@types/node@25.2.0))
|
version: 4.0.18(vitest@4.0.18(@types/node@25.2.0))
|
||||||
eslint:
|
eslint:
|
||||||
specifier: 9.39.2
|
specifier: 10.0.0
|
||||||
version: 9.39.2
|
version: 10.0.0
|
||||||
typescript:
|
typescript:
|
||||||
specifier: 5.9.3
|
specifier: 5.9.3
|
||||||
version: 5.9.3
|
version: 5.9.3
|
||||||
vitest:
|
vitest:
|
||||||
specifier: 4.0.18
|
specifier: ^4.0.18
|
||||||
version: 4.0.18(@types/node@25.2.0)
|
version: 4.0.18(@types/node@25.2.0)
|
||||||
|
|
||||||
packages:
|
packages:
|
||||||
@@ -310,41 +310,33 @@ packages:
|
|||||||
eslint:
|
eslint:
|
||||||
optional: true
|
optional: true
|
||||||
|
|
||||||
'@eslint/config-array@0.21.1':
|
'@eslint/config-array@0.23.1':
|
||||||
resolution: {integrity: sha512-aw1gNayWpdI/jSYVgzN5pL0cfzU02GT3NBpeT/DXbx1/1x7ZKxFPd9bwrzygx/qiwIQiJ1sw/zD8qY/kRvlGHA==}
|
resolution: {integrity: sha512-uVSdg/V4dfQmTjJzR0szNczjOH/J+FyUMMjYtr07xFRXR7EDf9i1qdxrD0VusZH9knj1/ecxzCQQxyic5NzAiA==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
|
||||||
|
|
||||||
'@eslint/config-helpers@0.4.2':
|
'@eslint/config-helpers@0.5.2':
|
||||||
resolution: {integrity: sha512-gBrxN88gOIf3R7ja5K9slwNayVcZgK6SOUORm2uBzTeIEfeVaIhOpCtTox3P6R7o2jLFwLFTLnC7kU/RGcYEgw==}
|
resolution: {integrity: sha512-a5MxrdDXEvqnIq+LisyCX6tQMPF/dSJpCfBgBauY+pNZ28yCtSsTvyTYrMhaI+LK26bVyCJfJkT0u8KIj2i1dQ==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
|
||||||
|
|
||||||
'@eslint/core@0.17.0':
|
'@eslint/core@1.1.0':
|
||||||
resolution: {integrity: sha512-yL/sLrpmtDaFEiUj1osRP4TI2MDz1AddJL+jZ7KSqvBuliN4xqYY54IfdN8qD8Toa6g1iloph1fxQNkjOxrrpQ==}
|
resolution: {integrity: sha512-/nr9K9wkr3P1EzFTdFdMoLuo1PmIxjmwvPozwoSodjNBdefGujXQUF93u1DDZpEaTuDvMsIQddsd35BwtrW9Xw==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
|
||||||
|
|
||||||
'@eslint/eslintrc@3.2.0':
|
'@eslint/eslintrc@3.2.0':
|
||||||
resolution: {integrity: sha512-grOjVNN8P3hjJn/eIETF1wwd12DdnwFDoyceUJLYYdkpbwq3nLi+4fqrTAONx7XDALqlL220wC/RHSC/QTI/0w==}
|
resolution: {integrity: sha512-grOjVNN8P3hjJn/eIETF1wwd12DdnwFDoyceUJLYYdkpbwq3nLi+4fqrTAONx7XDALqlL220wC/RHSC/QTI/0w==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
||||||
|
|
||||||
'@eslint/eslintrc@3.3.3':
|
|
||||||
resolution: {integrity: sha512-Kr+LPIUVKz2qkx1HAMH8q1q6azbqBAsXJUxBl/ODDuVPX45Z9DfwB8tPjTi6nNZ8BuM3nbJxC5zCAg5elnBUTQ==}
|
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
|
||||||
|
|
||||||
'@eslint/js@9.17.0':
|
'@eslint/js@9.17.0':
|
||||||
resolution: {integrity: sha512-Sxc4hqcs1kTu0iID3kcZDW3JHq2a77HO9P8CP6YEA/FpH3Ll8UXE2r/86Rz9YJLKme39S9vU5OWNjC6Xl0Cr3w==}
|
resolution: {integrity: sha512-Sxc4hqcs1kTu0iID3kcZDW3JHq2a77HO9P8CP6YEA/FpH3Ll8UXE2r/86Rz9YJLKme39S9vU5OWNjC6Xl0Cr3w==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
||||||
|
|
||||||
'@eslint/js@9.39.2':
|
'@eslint/object-schema@3.0.1':
|
||||||
resolution: {integrity: sha512-q1mjIoW1VX4IvSocvM/vbTiveKC4k9eLrajNEuSsmjymSDEbpGddtpfOoN7YGAqBK3NG+uqo8ia4PDTt8buCYA==}
|
resolution: {integrity: sha512-P9cq2dpr+LU8j3qbLygLcSZrl2/ds/pUpfnHNNuk5HW7mnngHs+6WSq5C9mO3rqRX8A1poxqLTC9cu0KOyJlBg==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
|
||||||
|
|
||||||
'@eslint/object-schema@2.1.7':
|
'@eslint/plugin-kit@0.6.0':
|
||||||
resolution: {integrity: sha512-VtAOaymWVfZcmZbp6E2mympDIHvyjXs/12LqWYjVw6qjrfF+VK+fyG33kChz3nnK+SU5/NeHOqrTEHS8sXO3OA==}
|
resolution: {integrity: sha512-bIZEUzOI1jkhviX2cp5vNyXQc6olzb2ohewQubuYlMXZ2Q/XjBO0x0XhGPvc9fjSIiUN0vw+0hq53BJ4eQSJKQ==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
|
||||||
|
|
||||||
'@eslint/plugin-kit@0.4.1':
|
|
||||||
resolution: {integrity: sha512-43/qtrDUokr7LJqoF2c3+RInu/t4zfrpYdoSDfYyhg52rwLV6TnOvdG4fXm7IkSB3wErkcmJS9iEhjVtOSEjjA==}
|
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
|
||||||
|
|
||||||
'@humanfs/core@0.19.1':
|
'@humanfs/core@0.19.1':
|
||||||
resolution: {integrity: sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==}
|
resolution: {integrity: sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==}
|
||||||
@@ -362,6 +354,10 @@ packages:
|
|||||||
resolution: {integrity: sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==}
|
resolution: {integrity: sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==}
|
||||||
engines: {node: '>=18.18'}
|
engines: {node: '>=18.18'}
|
||||||
|
|
||||||
|
'@isaacs/cliui@9.0.0':
|
||||||
|
resolution: {integrity: sha512-AokJm4tuBHillT+FpMtxQ60n8ObyXBatq7jD2/JA9dxbDDokKQm8KMht5ibGzLVU9IJDIKK4TPKgMHEYMn3lMg==}
|
||||||
|
engines: {node: '>=18'}
|
||||||
|
|
||||||
'@istanbuljs/schema@0.1.3':
|
'@istanbuljs/schema@0.1.3':
|
||||||
resolution: {integrity: sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==}
|
resolution: {integrity: sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==}
|
||||||
engines: {node: '>=8'}
|
engines: {node: '>=8'}
|
||||||
@@ -560,6 +556,9 @@ packages:
|
|||||||
'@types/deep-eql@4.0.2':
|
'@types/deep-eql@4.0.2':
|
||||||
resolution: {integrity: sha512-c9h9dVVMigMPc4bwTvC5dxqtqJZwQPePsWjPlpSOnojbor6pGqdk541lfA7AqFQr5pB1BRdq0juY9db81BwyFw==}
|
resolution: {integrity: sha512-c9h9dVVMigMPc4bwTvC5dxqtqJZwQPePsWjPlpSOnojbor6pGqdk541lfA7AqFQr5pB1BRdq0juY9db81BwyFw==}
|
||||||
|
|
||||||
|
'@types/esrecurse@4.3.1':
|
||||||
|
resolution: {integrity: sha512-xJBAbDifo5hpffDBuHl0Y8ywswbiAp/Wi7Y/GtAgSlZyIABppyurxVueOPE8LUQOxdlgi6Zqce7uoEpqNTeiUw==}
|
||||||
|
|
||||||
'@types/estree@1.0.8':
|
'@types/estree@1.0.8':
|
||||||
resolution: {integrity: sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==}
|
resolution: {integrity: sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==}
|
||||||
|
|
||||||
@@ -692,10 +691,10 @@ packages:
|
|||||||
resolution: {integrity: sha512-VFlhGSl4opC0bprJiItPQ1RfUhGDIBokcPwaFH4yiBCaNPeld/9VeXbiPO1cLyorQi1G1vL+ecBk1x8o1axORA==}
|
resolution: {integrity: sha512-VFlhGSl4opC0bprJiItPQ1RfUhGDIBokcPwaFH4yiBCaNPeld/9VeXbiPO1cLyorQi1G1vL+ecBk1x8o1axORA==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
||||||
|
|
||||||
'@vitest/coverage-istanbul@4.1.0':
|
'@vitest/coverage-istanbul@4.0.18':
|
||||||
resolution: {integrity: sha512-0+67gA94YToxd+Pc3XgIA/2c8HN2hXNSg3T+1FI4HW7W/2gPitYCtktsY6Ke7vrt5caboMq3TUf0/vwbHRb0og==}
|
resolution: {integrity: sha512-0OhjP30owEDihYTZGWuq20rNtV1RjjJs1Mv4MaZIKcFBmiLUXX7HJLX4fU7wE+Mrc3lQxI2HKq6WrSXi5FGuCQ==}
|
||||||
peerDependencies:
|
peerDependencies:
|
||||||
vitest: 4.1.0
|
vitest: 4.0.18
|
||||||
|
|
||||||
'@vitest/coverage-v8@4.0.18':
|
'@vitest/coverage-v8@4.0.18':
|
||||||
resolution: {integrity: sha512-7i+N2i0+ME+2JFZhfuz7Tg/FqKtilHjGyGvoHYQ6iLV0zahbsJ9sljC9OcFcPDbhYKCet+sG8SsVqlyGvPflZg==}
|
resolution: {integrity: sha512-7i+N2i0+ME+2JFZhfuz7Tg/FqKtilHjGyGvoHYQ6iLV0zahbsJ9sljC9OcFcPDbhYKCet+sG8SsVqlyGvPflZg==}
|
||||||
@@ -766,10 +765,6 @@ packages:
|
|||||||
ajv@6.12.6:
|
ajv@6.12.6:
|
||||||
resolution: {integrity: sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==}
|
resolution: {integrity: sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==}
|
||||||
|
|
||||||
ansi-styles@4.3.0:
|
|
||||||
resolution: {integrity: sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==}
|
|
||||||
engines: {node: '>=8'}
|
|
||||||
|
|
||||||
are-docs-informative@0.0.2:
|
are-docs-informative@0.0.2:
|
||||||
resolution: {integrity: sha512-ixiS0nLNNG5jNQzgZJNoUpBKdo9yTYZMGJ+QgT2jmjR7G7+QHRCc4v6LQ3NgE7EBJq+o0ams3waJwkrlBom8Ig==}
|
resolution: {integrity: sha512-ixiS0nLNNG5jNQzgZJNoUpBKdo9yTYZMGJ+QgT2jmjR7G7+QHRCc4v6LQ3NgE7EBJq+o0ams3waJwkrlBom8Ig==}
|
||||||
engines: {node: '>=14'}
|
engines: {node: '>=14'}
|
||||||
@@ -837,6 +832,10 @@ packages:
|
|||||||
balanced-match@1.0.2:
|
balanced-match@1.0.2:
|
||||||
resolution: {integrity: sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==}
|
resolution: {integrity: sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==}
|
||||||
|
|
||||||
|
balanced-match@4.0.2:
|
||||||
|
resolution: {integrity: sha512-x0K50QvKQ97fdEz2kPehIerj+YTeptKF9hyYkKf6egnwmMWAkADiO0QCzSp0R5xN8FTZgYaBfSaue46Ej62nMg==}
|
||||||
|
engines: {node: 20 || >=22}
|
||||||
|
|
||||||
baseline-browser-mapping@2.9.19:
|
baseline-browser-mapping@2.9.19:
|
||||||
resolution: {integrity: sha512-ipDqC8FrAl/76p2SSWKSI+H9tFwm7vYqXQrItCuiVPt26Km0jS+NzSsBWAaBusvSbQcfJG+JitdMm+wZAgTYqg==}
|
resolution: {integrity: sha512-ipDqC8FrAl/76p2SSWKSI+H9tFwm7vYqXQrItCuiVPt26Km0jS+NzSsBWAaBusvSbQcfJG+JitdMm+wZAgTYqg==}
|
||||||
hasBin: true
|
hasBin: true
|
||||||
@@ -847,6 +846,10 @@ packages:
|
|||||||
brace-expansion@2.0.2:
|
brace-expansion@2.0.2:
|
||||||
resolution: {integrity: sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ==}
|
resolution: {integrity: sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ==}
|
||||||
|
|
||||||
|
brace-expansion@5.0.2:
|
||||||
|
resolution: {integrity: sha512-Pdk8c9poy+YhOgVWw1JNN22/HcivgKWwpxKq04M/jTmHyCZn12WPJebZxdjSa5TmBqISrUSgNYU3eRORljfCCw==}
|
||||||
|
engines: {node: 20 || >=22}
|
||||||
|
|
||||||
braces@3.0.3:
|
braces@3.0.3:
|
||||||
resolution: {integrity: sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==}
|
resolution: {integrity: sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==}
|
||||||
engines: {node: '>=8'}
|
engines: {node: '>=8'}
|
||||||
@@ -883,10 +886,6 @@ packages:
|
|||||||
resolution: {integrity: sha512-NUPRluOfOiTKBKvWPtSD4PhFvWCqOi0BGStNWs57X9js7XGTprSmFoz5F0tWhR4WPjNeR9jXqdC7/UpSJTnlRg==}
|
resolution: {integrity: sha512-NUPRluOfOiTKBKvWPtSD4PhFvWCqOi0BGStNWs57X9js7XGTprSmFoz5F0tWhR4WPjNeR9jXqdC7/UpSJTnlRg==}
|
||||||
engines: {node: '>=18'}
|
engines: {node: '>=18'}
|
||||||
|
|
||||||
chalk@4.1.2:
|
|
||||||
resolution: {integrity: sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==}
|
|
||||||
engines: {node: '>=10'}
|
|
||||||
|
|
||||||
ci-info@4.4.0:
|
ci-info@4.4.0:
|
||||||
resolution: {integrity: sha512-77PSwercCZU2Fc4sX94eF8k8Pxte6JAwL4/ICZLFjJLqegs7kCuAsqqj/70NQF6TvDpgFjkubQB2FW2ZZddvQg==}
|
resolution: {integrity: sha512-77PSwercCZU2Fc4sX94eF8k8Pxte6JAwL4/ICZLFjJLqegs7kCuAsqqj/70NQF6TvDpgFjkubQB2FW2ZZddvQg==}
|
||||||
engines: {node: '>=8'}
|
engines: {node: '>=8'}
|
||||||
@@ -895,13 +894,6 @@ packages:
|
|||||||
resolution: {integrity: sha512-GfisEZEJvzKrmGWkvfhgzcz/BllN1USeqD2V6tg14OAOgaCD2Z/PUEuxnAZ/nPvmaHRG7a8y77p1T/IRQ4D1Hw==}
|
resolution: {integrity: sha512-GfisEZEJvzKrmGWkvfhgzcz/BllN1USeqD2V6tg14OAOgaCD2Z/PUEuxnAZ/nPvmaHRG7a8y77p1T/IRQ4D1Hw==}
|
||||||
engines: {node: '>=4'}
|
engines: {node: '>=4'}
|
||||||
|
|
||||||
color-convert@2.0.1:
|
|
||||||
resolution: {integrity: sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==}
|
|
||||||
engines: {node: '>=7.0.0'}
|
|
||||||
|
|
||||||
color-name@1.1.4:
|
|
||||||
resolution: {integrity: sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==}
|
|
||||||
|
|
||||||
combined-stream@1.0.8:
|
combined-stream@1.0.8:
|
||||||
resolution: {integrity: sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==}
|
resolution: {integrity: sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==}
|
||||||
engines: {node: '>= 0.8'}
|
engines: {node: '>= 0.8'}
|
||||||
@@ -1105,9 +1097,9 @@ packages:
|
|||||||
peerDependencies:
|
peerDependencies:
|
||||||
eslint: '>=8.56.0'
|
eslint: '>=8.56.0'
|
||||||
|
|
||||||
eslint-scope@8.4.0:
|
eslint-scope@9.1.0:
|
||||||
resolution: {integrity: sha512-sNXOfKCn74rt8RICKMvJS7XKV/Xk9kA7DyJr8mJik3S7Cwgy3qlkkmyS2uQB3jiJg6VNdZd/pDBJu0nvG2NlTg==}
|
resolution: {integrity: sha512-CkWE42hOJsNj9FJRaoMX9waUFYhqY4jmyLFdAdzZr6VaCg3ynLYx4WnOdkaIifGfH4gsUcBTn4OZbHXkpLD0FQ==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
|
||||||
|
|
||||||
eslint-visitor-keys@1.3.0:
|
eslint-visitor-keys@1.3.0:
|
||||||
resolution: {integrity: sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==}
|
resolution: {integrity: sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==}
|
||||||
@@ -1121,9 +1113,13 @@ packages:
|
|||||||
resolution: {integrity: sha512-Uhdk5sfqcee/9H/rCOJikYz67o0a2Tw2hGRPOG2Y1R2dg7brRe1uG0yaNQDHu+TO/uQPF/5eCapvYSmHUjt7JQ==}
|
resolution: {integrity: sha512-Uhdk5sfqcee/9H/rCOJikYz67o0a2Tw2hGRPOG2Y1R2dg7brRe1uG0yaNQDHu+TO/uQPF/5eCapvYSmHUjt7JQ==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
||||||
|
|
||||||
eslint@9.39.2:
|
eslint-visitor-keys@5.0.0:
|
||||||
resolution: {integrity: sha512-LEyamqS7W5HB3ujJyvi0HQK/dtVINZvd5mAAp9eT5S/ujByGjiZLCzPcHVzuXbpJDJF/cxwHlfceVUDZ2lnSTw==}
|
resolution: {integrity: sha512-A0XeIi7CXU7nPlfHS9loMYEKxUaONu/hTEzHTGba9Huu94Cq1hPivf+DE5erJozZOky0LfvXAyrV/tcswpLI0Q==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
|
||||||
|
|
||||||
|
eslint@10.0.0:
|
||||||
|
resolution: {integrity: sha512-O0piBKY36YSJhlFSG8p9VUdPV/SxxS4FYDWVpr/9GJuMaepzwlf4J8I4ov1b+ySQfDTPhc3DtLaxcT1fN0yqCg==}
|
||||||
|
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
|
||||||
hasBin: true
|
hasBin: true
|
||||||
peerDependencies:
|
peerDependencies:
|
||||||
jiti: '*'
|
jiti: '*'
|
||||||
@@ -1135,6 +1131,10 @@ packages:
|
|||||||
resolution: {integrity: sha512-j6PAQ2uUr79PZhBjP5C5fhl8e39FmRnOjsD5lGnWrFU8i2G776tBK7+nP8KuQUTTyAZUwfQqXAgrVH5MbH9CYQ==}
|
resolution: {integrity: sha512-j6PAQ2uUr79PZhBjP5C5fhl8e39FmRnOjsD5lGnWrFU8i2G776tBK7+nP8KuQUTTyAZUwfQqXAgrVH5MbH9CYQ==}
|
||||||
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
|
||||||
|
|
||||||
|
espree@11.1.0:
|
||||||
|
resolution: {integrity: sha512-WFWYhO1fV4iYkqOOvq8FbqIhr2pYfoDY0kCotMkDeNtGpiGGkZ1iov2u8ydjtgM8yF8rzK7oaTbw2NAzbAbehw==}
|
||||||
|
engines: {node: ^20.19.0 || ^22.13.0 || >=24}
|
||||||
|
|
||||||
espree@6.2.1:
|
espree@6.2.1:
|
||||||
resolution: {integrity: sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==}
|
resolution: {integrity: sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==}
|
||||||
engines: {node: '>=6.0.0'}
|
engines: {node: '>=6.0.0'}
|
||||||
@@ -1472,6 +1472,10 @@ packages:
|
|||||||
resolution: {integrity: sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==}
|
resolution: {integrity: sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==}
|
||||||
engines: {node: '>=8'}
|
engines: {node: '>=8'}
|
||||||
|
|
||||||
|
istanbul-lib-instrument@6.0.3:
|
||||||
|
resolution: {integrity: sha512-Vtgk7L/R2JHyyGW07spoFlB8/lpjiOLTjMdms6AFMraYt3BaJauod/NGrfnVG/y4Ix1JEuMRPDPEj2ua+zz1/Q==}
|
||||||
|
engines: {node: '>=10'}
|
||||||
|
|
||||||
istanbul-lib-report@3.0.1:
|
istanbul-lib-report@3.0.1:
|
||||||
resolution: {integrity: sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==}
|
resolution: {integrity: sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==}
|
||||||
engines: {node: '>=10'}
|
engines: {node: '>=10'}
|
||||||
@@ -1484,6 +1488,10 @@ packages:
|
|||||||
resolution: {integrity: sha512-H0dkQoCa3b2VEeKQBOxFph+JAbcrQdE7KC0UkqwpLmv2EC4P41QXP+rqo9wYodACiG5/WM5s9oDApTU8utwj9g==}
|
resolution: {integrity: sha512-H0dkQoCa3b2VEeKQBOxFph+JAbcrQdE7KC0UkqwpLmv2EC4P41QXP+rqo9wYodACiG5/WM5s9oDApTU8utwj9g==}
|
||||||
engines: {node: '>= 0.4'}
|
engines: {node: '>= 0.4'}
|
||||||
|
|
||||||
|
jackspeak@4.2.3:
|
||||||
|
resolution: {integrity: sha512-ykkVRwrYvFm1nb2AJfKKYPr0emF6IiXDYUaFx4Zn9ZuIH7MrzEZ3sD5RlqGXNRpHtvUHJyOnCEFxOlNDtGo7wg==}
|
||||||
|
engines: {node: 20 || >=22}
|
||||||
|
|
||||||
js-tokens@10.0.0:
|
js-tokens@10.0.0:
|
||||||
resolution: {integrity: sha512-lM/UBzQmfJRo9ABXbPWemivdCW8V2G8FHaHdypQaIy523snUjog0W71ayWXTjiR+ixeMyVHN2XcpnTd/liPg/Q==}
|
resolution: {integrity: sha512-lM/UBzQmfJRo9ABXbPWemivdCW8V2G8FHaHdypQaIy523snUjog0W71ayWXTjiR+ixeMyVHN2XcpnTd/liPg/Q==}
|
||||||
|
|
||||||
@@ -1550,9 +1558,6 @@ packages:
|
|||||||
resolution: {integrity: sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==}
|
resolution: {integrity: sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==}
|
||||||
engines: {node: '>=10'}
|
engines: {node: '>=10'}
|
||||||
|
|
||||||
lodash.merge@4.6.2:
|
|
||||||
resolution: {integrity: sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==}
|
|
||||||
|
|
||||||
loose-envify@1.4.0:
|
loose-envify@1.4.0:
|
||||||
resolution: {integrity: sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==}
|
resolution: {integrity: sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==}
|
||||||
hasBin: true
|
hasBin: true
|
||||||
@@ -1566,9 +1571,6 @@ packages:
|
|||||||
magicast@0.5.1:
|
magicast@0.5.1:
|
||||||
resolution: {integrity: sha512-xrHS24IxaLrvuo613F719wvOIv9xPHFWQHuvGUBmPnCA/3MQxKI3b+r7n1jAoDHmsbC5bRhTZYR77invLAxVnw==}
|
resolution: {integrity: sha512-xrHS24IxaLrvuo613F719wvOIv9xPHFWQHuvGUBmPnCA/3MQxKI3b+r7n1jAoDHmsbC5bRhTZYR77invLAxVnw==}
|
||||||
|
|
||||||
magicast@0.5.2:
|
|
||||||
resolution: {integrity: sha512-E3ZJh4J3S9KfwdjZhe2afj6R9lGIN5Pher1pF39UGrXRqq/VDaGVIGN13BjHd2u8B61hArAGOnso7nBOouW3TQ==}
|
|
||||||
|
|
||||||
make-dir@4.0.0:
|
make-dir@4.0.0:
|
||||||
resolution: {integrity: sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==}
|
resolution: {integrity: sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==}
|
||||||
engines: {node: '>=10'}
|
engines: {node: '>=10'}
|
||||||
@@ -1597,6 +1599,10 @@ packages:
|
|||||||
resolution: {integrity: sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==}
|
resolution: {integrity: sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==}
|
||||||
engines: {node: '>=4'}
|
engines: {node: '>=4'}
|
||||||
|
|
||||||
|
minimatch@10.2.1:
|
||||||
|
resolution: {integrity: sha512-MClCe8IL5nRRmawL6ib/eT4oLyeKMGCghibcDWK+J0hh0Q8kqSdia6BvbRMVk6mPa6WqUa5uR2oxt6C5jd533A==}
|
||||||
|
engines: {node: 20 || >=22}
|
||||||
|
|
||||||
minimatch@3.1.2:
|
minimatch@3.1.2:
|
||||||
resolution: {integrity: sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==}
|
resolution: {integrity: sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==}
|
||||||
|
|
||||||
@@ -2366,36 +2372,36 @@ snapshots:
|
|||||||
'@esbuild/win32-x64@0.27.2':
|
'@esbuild/win32-x64@0.27.2':
|
||||||
optional: true
|
optional: true
|
||||||
|
|
||||||
'@eslint-community/eslint-plugin-eslint-comments@4.4.1(eslint@9.39.2)':
|
'@eslint-community/eslint-plugin-eslint-comments@4.4.1(eslint@10.0.0)':
|
||||||
dependencies:
|
dependencies:
|
||||||
escape-string-regexp: 4.0.0
|
escape-string-regexp: 4.0.0
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
ignore: 5.3.2
|
ignore: 5.3.2
|
||||||
|
|
||||||
'@eslint-community/eslint-utils@4.9.1(eslint@9.39.2)':
|
'@eslint-community/eslint-utils@4.9.1(eslint@10.0.0)':
|
||||||
dependencies:
|
dependencies:
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
eslint-visitor-keys: 3.4.3
|
eslint-visitor-keys: 3.4.3
|
||||||
|
|
||||||
'@eslint-community/regexpp@4.12.2': {}
|
'@eslint-community/regexpp@4.12.2': {}
|
||||||
|
|
||||||
'@eslint/compat@1.2.4(eslint@9.39.2)':
|
'@eslint/compat@1.2.4(eslint@10.0.0)':
|
||||||
optionalDependencies:
|
optionalDependencies:
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
|
|
||||||
'@eslint/config-array@0.21.1':
|
'@eslint/config-array@0.23.1':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@eslint/object-schema': 2.1.7
|
'@eslint/object-schema': 3.0.1
|
||||||
debug: 4.4.3
|
debug: 4.4.3
|
||||||
minimatch: 3.1.2
|
minimatch: 10.2.1
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
'@eslint/config-helpers@0.4.2':
|
'@eslint/config-helpers@0.5.2':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@eslint/core': 0.17.0
|
'@eslint/core': 1.1.0
|
||||||
|
|
||||||
'@eslint/core@0.17.0':
|
'@eslint/core@1.1.0':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@types/json-schema': 7.0.15
|
'@types/json-schema': 7.0.15
|
||||||
|
|
||||||
@@ -2413,29 +2419,13 @@ snapshots:
|
|||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
'@eslint/eslintrc@3.3.3':
|
|
||||||
dependencies:
|
|
||||||
ajv: 6.12.6
|
|
||||||
debug: 4.4.3
|
|
||||||
espree: 10.4.0
|
|
||||||
globals: 14.0.0
|
|
||||||
ignore: 5.3.2
|
|
||||||
import-fresh: 3.3.1
|
|
||||||
js-yaml: 4.1.1
|
|
||||||
minimatch: 3.1.2
|
|
||||||
strip-json-comments: 3.1.1
|
|
||||||
transitivePeerDependencies:
|
|
||||||
- supports-color
|
|
||||||
|
|
||||||
'@eslint/js@9.17.0': {}
|
'@eslint/js@9.17.0': {}
|
||||||
|
|
||||||
'@eslint/js@9.39.2': {}
|
'@eslint/object-schema@3.0.1': {}
|
||||||
|
|
||||||
'@eslint/object-schema@2.1.7': {}
|
'@eslint/plugin-kit@0.6.0':
|
||||||
|
|
||||||
'@eslint/plugin-kit@0.4.1':
|
|
||||||
dependencies:
|
dependencies:
|
||||||
'@eslint/core': 0.17.0
|
'@eslint/core': 1.1.0
|
||||||
levn: 0.4.1
|
levn: 0.4.1
|
||||||
|
|
||||||
'@humanfs/core@0.19.1': {}
|
'@humanfs/core@0.19.1': {}
|
||||||
@@ -2449,6 +2439,8 @@ snapshots:
|
|||||||
|
|
||||||
'@humanwhocodes/retry@0.4.3': {}
|
'@humanwhocodes/retry@0.4.3': {}
|
||||||
|
|
||||||
|
'@isaacs/cliui@9.0.0': {}
|
||||||
|
|
||||||
'@istanbuljs/schema@0.1.3': {}
|
'@istanbuljs/schema@0.1.3': {}
|
||||||
|
|
||||||
'@jridgewell/gen-mapping@0.3.13':
|
'@jridgewell/gen-mapping@0.3.13':
|
||||||
@@ -2470,24 +2462,24 @@ snapshots:
|
|||||||
'@jridgewell/resolve-uri': 3.1.2
|
'@jridgewell/resolve-uri': 3.1.2
|
||||||
'@jridgewell/sourcemap-codec': 1.5.5
|
'@jridgewell/sourcemap-codec': 1.5.5
|
||||||
|
|
||||||
'@nhcarrigan/eslint-config@5.2.0(@typescript-eslint/utils@8.54.0(eslint@9.39.2)(typescript@5.9.3))(eslint@9.39.2)(playwright@1.58.1)(react@19.2.4)(typescript@5.9.3)(vitest@4.0.18(@types/node@25.2.0))':
|
'@nhcarrigan/eslint-config@5.2.0(@typescript-eslint/utils@8.54.0(eslint@10.0.0)(typescript@5.9.3))(eslint@10.0.0)(playwright@1.58.1)(react@19.2.4)(typescript@5.9.3)(vitest@4.0.18(@types/node@25.2.0))':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@eslint-community/eslint-plugin-eslint-comments': 4.4.1(eslint@9.39.2)
|
'@eslint-community/eslint-plugin-eslint-comments': 4.4.1(eslint@10.0.0)
|
||||||
'@eslint/compat': 1.2.4(eslint@9.39.2)
|
'@eslint/compat': 1.2.4(eslint@10.0.0)
|
||||||
'@eslint/eslintrc': 3.2.0
|
'@eslint/eslintrc': 3.2.0
|
||||||
'@eslint/js': 9.17.0
|
'@eslint/js': 9.17.0
|
||||||
'@stylistic/eslint-plugin': 2.12.1(eslint@9.39.2)(typescript@5.9.3)
|
'@stylistic/eslint-plugin': 2.12.1(eslint@10.0.0)(typescript@5.9.3)
|
||||||
'@typescript-eslint/eslint-plugin': 8.19.0(@typescript-eslint/parser@8.19.0(eslint@9.39.2)(typescript@5.9.3))(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/eslint-plugin': 8.19.0(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.9.3))(eslint@10.0.0)(typescript@5.9.3)
|
||||||
'@typescript-eslint/parser': 8.19.0(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/parser': 8.19.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
'@vitest/eslint-plugin': 1.1.24(@typescript-eslint/utils@8.54.0(eslint@9.39.2)(typescript@5.9.3))(eslint@9.39.2)(typescript@5.9.3)(vitest@4.0.18(@types/node@25.2.0))
|
'@vitest/eslint-plugin': 1.1.24(@typescript-eslint/utils@8.54.0(eslint@10.0.0)(typescript@5.9.3))(eslint@10.0.0)(typescript@5.9.3)(vitest@4.0.18(@types/node@25.2.0))
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
eslint-plugin-deprecation: 3.0.0(eslint@9.39.2)(typescript@5.9.3)
|
eslint-plugin-deprecation: 3.0.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
eslint-plugin-import: 2.31.0(@typescript-eslint/parser@8.19.0(eslint@9.39.2)(typescript@5.9.3))(eslint@9.39.2)
|
eslint-plugin-import: 2.31.0(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.9.3))(eslint@10.0.0)
|
||||||
eslint-plugin-jsdoc: 50.6.1(eslint@9.39.2)
|
eslint-plugin-jsdoc: 50.6.1(eslint@10.0.0)
|
||||||
eslint-plugin-playwright: 2.1.0(eslint@9.39.2)
|
eslint-plugin-playwright: 2.1.0(eslint@10.0.0)
|
||||||
eslint-plugin-react: 7.37.3(eslint@9.39.2)
|
eslint-plugin-react: 7.37.3(eslint@10.0.0)
|
||||||
eslint-plugin-sort-keys-fix: 1.1.2
|
eslint-plugin-sort-keys-fix: 1.1.2
|
||||||
eslint-plugin-unicorn: 56.0.1(eslint@9.39.2)
|
eslint-plugin-unicorn: 56.0.1(eslint@10.0.0)
|
||||||
globals: 15.14.0
|
globals: 15.14.0
|
||||||
playwright: 1.58.1
|
playwright: 1.58.1
|
||||||
react: 19.2.4
|
react: 19.2.4
|
||||||
@@ -2598,10 +2590,10 @@ snapshots:
|
|||||||
|
|
||||||
'@standard-schema/spec@1.1.0': {}
|
'@standard-schema/spec@1.1.0': {}
|
||||||
|
|
||||||
'@stylistic/eslint-plugin@2.12.1(eslint@9.39.2)(typescript@5.9.3)':
|
'@stylistic/eslint-plugin@2.12.1(eslint@10.0.0)(typescript@5.9.3)':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@typescript-eslint/utils': 8.54.0(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/utils': 8.54.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
eslint-visitor-keys: 4.2.1
|
eslint-visitor-keys: 4.2.1
|
||||||
espree: 10.4.0
|
espree: 10.4.0
|
||||||
estraverse: 5.3.0
|
estraverse: 5.3.0
|
||||||
@@ -2617,6 +2609,8 @@ snapshots:
|
|||||||
|
|
||||||
'@types/deep-eql@4.0.2': {}
|
'@types/deep-eql@4.0.2': {}
|
||||||
|
|
||||||
|
'@types/esrecurse@4.3.1': {}
|
||||||
|
|
||||||
'@types/estree@1.0.8': {}
|
'@types/estree@1.0.8': {}
|
||||||
|
|
||||||
'@types/json-schema@7.0.15': {}
|
'@types/json-schema@7.0.15': {}
|
||||||
@@ -2633,15 +2627,15 @@ snapshots:
|
|||||||
|
|
||||||
'@types/semver@7.7.1': {}
|
'@types/semver@7.7.1': {}
|
||||||
|
|
||||||
'@typescript-eslint/eslint-plugin@8.19.0(@typescript-eslint/parser@8.19.0(eslint@9.39.2)(typescript@5.9.3))(eslint@9.39.2)(typescript@5.9.3)':
|
'@typescript-eslint/eslint-plugin@8.19.0(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.9.3))(eslint@10.0.0)(typescript@5.9.3)':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@eslint-community/regexpp': 4.12.2
|
'@eslint-community/regexpp': 4.12.2
|
||||||
'@typescript-eslint/parser': 8.19.0(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/parser': 8.19.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
'@typescript-eslint/scope-manager': 8.19.0
|
'@typescript-eslint/scope-manager': 8.19.0
|
||||||
'@typescript-eslint/type-utils': 8.19.0(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/type-utils': 8.19.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
'@typescript-eslint/utils': 8.19.0(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/utils': 8.19.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
'@typescript-eslint/visitor-keys': 8.19.0
|
'@typescript-eslint/visitor-keys': 8.19.0
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
graphemer: 1.4.0
|
graphemer: 1.4.0
|
||||||
ignore: 5.3.2
|
ignore: 5.3.2
|
||||||
natural-compare: 1.4.0
|
natural-compare: 1.4.0
|
||||||
@@ -2650,14 +2644,14 @@ snapshots:
|
|||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
'@typescript-eslint/parser@8.19.0(eslint@9.39.2)(typescript@5.9.3)':
|
'@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.9.3)':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@typescript-eslint/scope-manager': 8.19.0
|
'@typescript-eslint/scope-manager': 8.19.0
|
||||||
'@typescript-eslint/types': 8.19.0
|
'@typescript-eslint/types': 8.19.0
|
||||||
'@typescript-eslint/typescript-estree': 8.19.0(typescript@5.9.3)
|
'@typescript-eslint/typescript-estree': 8.19.0(typescript@5.9.3)
|
||||||
'@typescript-eslint/visitor-keys': 8.19.0
|
'@typescript-eslint/visitor-keys': 8.19.0
|
||||||
debug: 4.4.3
|
debug: 4.4.3
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
typescript: 5.9.3
|
typescript: 5.9.3
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
@@ -2690,12 +2684,12 @@ snapshots:
|
|||||||
dependencies:
|
dependencies:
|
||||||
typescript: 5.9.3
|
typescript: 5.9.3
|
||||||
|
|
||||||
'@typescript-eslint/type-utils@8.19.0(eslint@9.39.2)(typescript@5.9.3)':
|
'@typescript-eslint/type-utils@8.19.0(eslint@10.0.0)(typescript@5.9.3)':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@typescript-eslint/typescript-estree': 8.19.0(typescript@5.9.3)
|
'@typescript-eslint/typescript-estree': 8.19.0(typescript@5.9.3)
|
||||||
'@typescript-eslint/utils': 8.19.0(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/utils': 8.19.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
debug: 4.4.3
|
debug: 4.4.3
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
ts-api-utils: 1.4.3(typescript@5.9.3)
|
ts-api-utils: 1.4.3(typescript@5.9.3)
|
||||||
typescript: 5.9.3
|
typescript: 5.9.3
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
@@ -2751,35 +2745,35 @@ snapshots:
|
|||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
'@typescript-eslint/utils@7.18.0(eslint@9.39.2)(typescript@5.9.3)':
|
'@typescript-eslint/utils@7.18.0(eslint@10.0.0)(typescript@5.9.3)':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@eslint-community/eslint-utils': 4.9.1(eslint@9.39.2)
|
'@eslint-community/eslint-utils': 4.9.1(eslint@10.0.0)
|
||||||
'@typescript-eslint/scope-manager': 7.18.0
|
'@typescript-eslint/scope-manager': 7.18.0
|
||||||
'@typescript-eslint/types': 7.18.0
|
'@typescript-eslint/types': 7.18.0
|
||||||
'@typescript-eslint/typescript-estree': 7.18.0(typescript@5.9.3)
|
'@typescript-eslint/typescript-estree': 7.18.0(typescript@5.9.3)
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
- typescript
|
- typescript
|
||||||
|
|
||||||
'@typescript-eslint/utils@8.19.0(eslint@9.39.2)(typescript@5.9.3)':
|
'@typescript-eslint/utils@8.19.0(eslint@10.0.0)(typescript@5.9.3)':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@eslint-community/eslint-utils': 4.9.1(eslint@9.39.2)
|
'@eslint-community/eslint-utils': 4.9.1(eslint@10.0.0)
|
||||||
'@typescript-eslint/scope-manager': 8.19.0
|
'@typescript-eslint/scope-manager': 8.19.0
|
||||||
'@typescript-eslint/types': 8.19.0
|
'@typescript-eslint/types': 8.19.0
|
||||||
'@typescript-eslint/typescript-estree': 8.19.0(typescript@5.9.3)
|
'@typescript-eslint/typescript-estree': 8.19.0(typescript@5.9.3)
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
typescript: 5.9.3
|
typescript: 5.9.3
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
'@typescript-eslint/utils@8.54.0(eslint@9.39.2)(typescript@5.9.3)':
|
'@typescript-eslint/utils@8.54.0(eslint@10.0.0)(typescript@5.9.3)':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@eslint-community/eslint-utils': 4.9.1(eslint@9.39.2)
|
'@eslint-community/eslint-utils': 4.9.1(eslint@10.0.0)
|
||||||
'@typescript-eslint/scope-manager': 8.54.0
|
'@typescript-eslint/scope-manager': 8.54.0
|
||||||
'@typescript-eslint/types': 8.54.0
|
'@typescript-eslint/types': 8.54.0
|
||||||
'@typescript-eslint/typescript-estree': 8.54.0(typescript@5.9.3)
|
'@typescript-eslint/typescript-estree': 8.54.0(typescript@5.9.3)
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
typescript: 5.9.3
|
typescript: 5.9.3
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
@@ -2799,16 +2793,16 @@ snapshots:
|
|||||||
'@typescript-eslint/types': 8.54.0
|
'@typescript-eslint/types': 8.54.0
|
||||||
eslint-visitor-keys: 4.2.1
|
eslint-visitor-keys: 4.2.1
|
||||||
|
|
||||||
'@vitest/coverage-istanbul@4.1.0(vitest@4.0.18(@types/node@25.2.0))':
|
'@vitest/coverage-istanbul@4.0.18(vitest@4.0.18(@types/node@25.2.0))':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@babel/core': 7.29.0
|
|
||||||
'@istanbuljs/schema': 0.1.3
|
'@istanbuljs/schema': 0.1.3
|
||||||
'@jridgewell/gen-mapping': 0.3.13
|
'@jridgewell/gen-mapping': 0.3.13
|
||||||
'@jridgewell/trace-mapping': 0.3.31
|
'@jridgewell/trace-mapping': 0.3.31
|
||||||
istanbul-lib-coverage: 3.2.2
|
istanbul-lib-coverage: 3.2.2
|
||||||
|
istanbul-lib-instrument: 6.0.3
|
||||||
istanbul-lib-report: 3.0.1
|
istanbul-lib-report: 3.0.1
|
||||||
istanbul-reports: 3.2.0
|
istanbul-reports: 3.2.0
|
||||||
magicast: 0.5.2
|
magicast: 0.5.1
|
||||||
obug: 2.1.1
|
obug: 2.1.1
|
||||||
tinyrainbow: 3.0.3
|
tinyrainbow: 3.0.3
|
||||||
vitest: 4.0.18(@types/node@25.2.0)
|
vitest: 4.0.18(@types/node@25.2.0)
|
||||||
@@ -2829,10 +2823,10 @@ snapshots:
|
|||||||
tinyrainbow: 3.0.3
|
tinyrainbow: 3.0.3
|
||||||
vitest: 4.0.18(@types/node@25.2.0)
|
vitest: 4.0.18(@types/node@25.2.0)
|
||||||
|
|
||||||
'@vitest/eslint-plugin@1.1.24(@typescript-eslint/utils@8.54.0(eslint@9.39.2)(typescript@5.9.3))(eslint@9.39.2)(typescript@5.9.3)(vitest@4.0.18(@types/node@25.2.0))':
|
'@vitest/eslint-plugin@1.1.24(@typescript-eslint/utils@8.54.0(eslint@10.0.0)(typescript@5.9.3))(eslint@10.0.0)(typescript@5.9.3)(vitest@4.0.18(@types/node@25.2.0))':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@typescript-eslint/utils': 8.54.0(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/utils': 8.54.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
optionalDependencies:
|
optionalDependencies:
|
||||||
typescript: 5.9.3
|
typescript: 5.9.3
|
||||||
vitest: 4.0.18(@types/node@25.2.0)
|
vitest: 4.0.18(@types/node@25.2.0)
|
||||||
@@ -2895,10 +2889,6 @@ snapshots:
|
|||||||
json-schema-traverse: 0.4.1
|
json-schema-traverse: 0.4.1
|
||||||
uri-js: 4.4.1
|
uri-js: 4.4.1
|
||||||
|
|
||||||
ansi-styles@4.3.0:
|
|
||||||
dependencies:
|
|
||||||
color-convert: 2.0.1
|
|
||||||
|
|
||||||
are-docs-informative@0.0.2: {}
|
are-docs-informative@0.0.2: {}
|
||||||
|
|
||||||
argparse@2.0.1: {}
|
argparse@2.0.1: {}
|
||||||
@@ -2998,6 +2988,10 @@ snapshots:
|
|||||||
|
|
||||||
balanced-match@1.0.2: {}
|
balanced-match@1.0.2: {}
|
||||||
|
|
||||||
|
balanced-match@4.0.2:
|
||||||
|
dependencies:
|
||||||
|
jackspeak: 4.2.3
|
||||||
|
|
||||||
baseline-browser-mapping@2.9.19: {}
|
baseline-browser-mapping@2.9.19: {}
|
||||||
|
|
||||||
brace-expansion@1.1.12:
|
brace-expansion@1.1.12:
|
||||||
@@ -3009,6 +3003,10 @@ snapshots:
|
|||||||
dependencies:
|
dependencies:
|
||||||
balanced-match: 1.0.2
|
balanced-match: 1.0.2
|
||||||
|
|
||||||
|
brace-expansion@5.0.2:
|
||||||
|
dependencies:
|
||||||
|
balanced-match: 4.0.2
|
||||||
|
|
||||||
braces@3.0.3:
|
braces@3.0.3:
|
||||||
dependencies:
|
dependencies:
|
||||||
fill-range: 7.1.1
|
fill-range: 7.1.1
|
||||||
@@ -3046,23 +3044,12 @@ snapshots:
|
|||||||
|
|
||||||
chai@6.2.2: {}
|
chai@6.2.2: {}
|
||||||
|
|
||||||
chalk@4.1.2:
|
|
||||||
dependencies:
|
|
||||||
ansi-styles: 4.3.0
|
|
||||||
supports-color: 7.2.0
|
|
||||||
|
|
||||||
ci-info@4.4.0: {}
|
ci-info@4.4.0: {}
|
||||||
|
|
||||||
clean-regexp@1.0.0:
|
clean-regexp@1.0.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
escape-string-regexp: 1.0.5
|
escape-string-regexp: 1.0.5
|
||||||
|
|
||||||
color-convert@2.0.1:
|
|
||||||
dependencies:
|
|
||||||
color-name: 1.1.4
|
|
||||||
|
|
||||||
color-name@1.1.4: {}
|
|
||||||
|
|
||||||
combined-stream@1.0.8:
|
combined-stream@1.0.8:
|
||||||
dependencies:
|
dependencies:
|
||||||
delayed-stream: 1.0.0
|
delayed-stream: 1.0.0
|
||||||
@@ -3291,27 +3278,27 @@ snapshots:
|
|||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
eslint-module-utils@2.12.1(@typescript-eslint/parser@8.19.0(eslint@9.39.2)(typescript@5.9.3))(eslint-import-resolver-node@0.3.9)(eslint@9.39.2):
|
eslint-module-utils@2.12.1(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.9.3))(eslint-import-resolver-node@0.3.9)(eslint@10.0.0):
|
||||||
dependencies:
|
dependencies:
|
||||||
debug: 3.2.7
|
debug: 3.2.7
|
||||||
optionalDependencies:
|
optionalDependencies:
|
||||||
'@typescript-eslint/parser': 8.19.0(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/parser': 8.19.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
eslint-import-resolver-node: 0.3.9
|
eslint-import-resolver-node: 0.3.9
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
eslint-plugin-deprecation@3.0.0(eslint@9.39.2)(typescript@5.9.3):
|
eslint-plugin-deprecation@3.0.0(eslint@10.0.0)(typescript@5.9.3):
|
||||||
dependencies:
|
dependencies:
|
||||||
'@typescript-eslint/utils': 7.18.0(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/utils': 7.18.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
ts-api-utils: 1.4.3(typescript@5.9.3)
|
ts-api-utils: 1.4.3(typescript@5.9.3)
|
||||||
tslib: 2.8.1
|
tslib: 2.8.1
|
||||||
typescript: 5.9.3
|
typescript: 5.9.3
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.19.0(eslint@9.39.2)(typescript@5.9.3))(eslint@9.39.2):
|
eslint-plugin-import@2.31.0(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.9.3))(eslint@10.0.0):
|
||||||
dependencies:
|
dependencies:
|
||||||
'@rtsao/scc': 1.1.0
|
'@rtsao/scc': 1.1.0
|
||||||
array-includes: 3.1.9
|
array-includes: 3.1.9
|
||||||
@@ -3320,9 +3307,9 @@ snapshots:
|
|||||||
array.prototype.flatmap: 1.3.3
|
array.prototype.flatmap: 1.3.3
|
||||||
debug: 3.2.7
|
debug: 3.2.7
|
||||||
doctrine: 2.1.0
|
doctrine: 2.1.0
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
eslint-import-resolver-node: 0.3.9
|
eslint-import-resolver-node: 0.3.9
|
||||||
eslint-module-utils: 2.12.1(@typescript-eslint/parser@8.19.0(eslint@9.39.2)(typescript@5.9.3))(eslint-import-resolver-node@0.3.9)(eslint@9.39.2)
|
eslint-module-utils: 2.12.1(@typescript-eslint/parser@8.19.0(eslint@10.0.0)(typescript@5.9.3))(eslint-import-resolver-node@0.3.9)(eslint@10.0.0)
|
||||||
hasown: 2.0.2
|
hasown: 2.0.2
|
||||||
is-core-module: 2.16.1
|
is-core-module: 2.16.1
|
||||||
is-glob: 4.0.3
|
is-glob: 4.0.3
|
||||||
@@ -3334,20 +3321,20 @@ snapshots:
|
|||||||
string.prototype.trimend: 1.0.9
|
string.prototype.trimend: 1.0.9
|
||||||
tsconfig-paths: 3.15.0
|
tsconfig-paths: 3.15.0
|
||||||
optionalDependencies:
|
optionalDependencies:
|
||||||
'@typescript-eslint/parser': 8.19.0(eslint@9.39.2)(typescript@5.9.3)
|
'@typescript-eslint/parser': 8.19.0(eslint@10.0.0)(typescript@5.9.3)
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- eslint-import-resolver-typescript
|
- eslint-import-resolver-typescript
|
||||||
- eslint-import-resolver-webpack
|
- eslint-import-resolver-webpack
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
eslint-plugin-jsdoc@50.6.1(eslint@9.39.2):
|
eslint-plugin-jsdoc@50.6.1(eslint@10.0.0):
|
||||||
dependencies:
|
dependencies:
|
||||||
'@es-joy/jsdoccomment': 0.49.0
|
'@es-joy/jsdoccomment': 0.49.0
|
||||||
are-docs-informative: 0.0.2
|
are-docs-informative: 0.0.2
|
||||||
comment-parser: 1.4.1
|
comment-parser: 1.4.1
|
||||||
debug: 4.4.3
|
debug: 4.4.3
|
||||||
escape-string-regexp: 4.0.0
|
escape-string-regexp: 4.0.0
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
espree: 10.4.0
|
espree: 10.4.0
|
||||||
esquery: 1.7.0
|
esquery: 1.7.0
|
||||||
parse-imports: 2.2.1
|
parse-imports: 2.2.1
|
||||||
@@ -3357,12 +3344,12 @@ snapshots:
|
|||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
- supports-color
|
- supports-color
|
||||||
|
|
||||||
eslint-plugin-playwright@2.1.0(eslint@9.39.2):
|
eslint-plugin-playwright@2.1.0(eslint@10.0.0):
|
||||||
dependencies:
|
dependencies:
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
globals: 13.24.0
|
globals: 13.24.0
|
||||||
|
|
||||||
eslint-plugin-react@7.37.3(eslint@9.39.2):
|
eslint-plugin-react@7.37.3(eslint@10.0.0):
|
||||||
dependencies:
|
dependencies:
|
||||||
array-includes: 3.1.9
|
array-includes: 3.1.9
|
||||||
array.prototype.findlast: 1.2.5
|
array.prototype.findlast: 1.2.5
|
||||||
@@ -3370,7 +3357,7 @@ snapshots:
|
|||||||
array.prototype.tosorted: 1.1.4
|
array.prototype.tosorted: 1.1.4
|
||||||
doctrine: 2.1.0
|
doctrine: 2.1.0
|
||||||
es-iterator-helpers: 1.2.2
|
es-iterator-helpers: 1.2.2
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
estraverse: 5.3.0
|
estraverse: 5.3.0
|
||||||
hasown: 2.0.2
|
hasown: 2.0.2
|
||||||
jsx-ast-utils: 3.3.5
|
jsx-ast-utils: 3.3.5
|
||||||
@@ -3391,14 +3378,14 @@ snapshots:
|
|||||||
natural-compare: 1.4.0
|
natural-compare: 1.4.0
|
||||||
requireindex: 1.2.0
|
requireindex: 1.2.0
|
||||||
|
|
||||||
eslint-plugin-unicorn@56.0.1(eslint@9.39.2):
|
eslint-plugin-unicorn@56.0.1(eslint@10.0.0):
|
||||||
dependencies:
|
dependencies:
|
||||||
'@babel/helper-validator-identifier': 7.28.5
|
'@babel/helper-validator-identifier': 7.28.5
|
||||||
'@eslint-community/eslint-utils': 4.9.1(eslint@9.39.2)
|
'@eslint-community/eslint-utils': 4.9.1(eslint@10.0.0)
|
||||||
ci-info: 4.4.0
|
ci-info: 4.4.0
|
||||||
clean-regexp: 1.0.0
|
clean-regexp: 1.0.0
|
||||||
core-js-compat: 3.48.0
|
core-js-compat: 3.48.0
|
||||||
eslint: 9.39.2
|
eslint: 10.0.0
|
||||||
esquery: 1.7.0
|
esquery: 1.7.0
|
||||||
globals: 15.14.0
|
globals: 15.14.0
|
||||||
indent-string: 4.0.0
|
indent-string: 4.0.0
|
||||||
@@ -3411,8 +3398,10 @@ snapshots:
|
|||||||
semver: 7.7.3
|
semver: 7.7.3
|
||||||
strip-indent: 3.0.0
|
strip-indent: 3.0.0
|
||||||
|
|
||||||
eslint-scope@8.4.0:
|
eslint-scope@9.1.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
|
'@types/esrecurse': 4.3.1
|
||||||
|
'@types/estree': 1.0.8
|
||||||
esrecurse: 4.3.0
|
esrecurse: 4.3.0
|
||||||
estraverse: 5.3.0
|
estraverse: 5.3.0
|
||||||
|
|
||||||
@@ -3422,28 +3411,27 @@ snapshots:
|
|||||||
|
|
||||||
eslint-visitor-keys@4.2.1: {}
|
eslint-visitor-keys@4.2.1: {}
|
||||||
|
|
||||||
eslint@9.39.2:
|
eslint-visitor-keys@5.0.0: {}
|
||||||
|
|
||||||
|
eslint@10.0.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
'@eslint-community/eslint-utils': 4.9.1(eslint@9.39.2)
|
'@eslint-community/eslint-utils': 4.9.1(eslint@10.0.0)
|
||||||
'@eslint-community/regexpp': 4.12.2
|
'@eslint-community/regexpp': 4.12.2
|
||||||
'@eslint/config-array': 0.21.1
|
'@eslint/config-array': 0.23.1
|
||||||
'@eslint/config-helpers': 0.4.2
|
'@eslint/config-helpers': 0.5.2
|
||||||
'@eslint/core': 0.17.0
|
'@eslint/core': 1.1.0
|
||||||
'@eslint/eslintrc': 3.3.3
|
'@eslint/plugin-kit': 0.6.0
|
||||||
'@eslint/js': 9.39.2
|
|
||||||
'@eslint/plugin-kit': 0.4.1
|
|
||||||
'@humanfs/node': 0.16.7
|
'@humanfs/node': 0.16.7
|
||||||
'@humanwhocodes/module-importer': 1.0.1
|
'@humanwhocodes/module-importer': 1.0.1
|
||||||
'@humanwhocodes/retry': 0.4.3
|
'@humanwhocodes/retry': 0.4.3
|
||||||
'@types/estree': 1.0.8
|
'@types/estree': 1.0.8
|
||||||
ajv: 6.12.6
|
ajv: 6.12.6
|
||||||
chalk: 4.1.2
|
|
||||||
cross-spawn: 7.0.6
|
cross-spawn: 7.0.6
|
||||||
debug: 4.4.3
|
debug: 4.4.3
|
||||||
escape-string-regexp: 4.0.0
|
escape-string-regexp: 4.0.0
|
||||||
eslint-scope: 8.4.0
|
eslint-scope: 9.1.0
|
||||||
eslint-visitor-keys: 4.2.1
|
eslint-visitor-keys: 5.0.0
|
||||||
espree: 10.4.0
|
espree: 11.1.0
|
||||||
esquery: 1.7.0
|
esquery: 1.7.0
|
||||||
esutils: 2.0.3
|
esutils: 2.0.3
|
||||||
fast-deep-equal: 3.1.3
|
fast-deep-equal: 3.1.3
|
||||||
@@ -3454,8 +3442,7 @@ snapshots:
|
|||||||
imurmurhash: 0.1.4
|
imurmurhash: 0.1.4
|
||||||
is-glob: 4.0.3
|
is-glob: 4.0.3
|
||||||
json-stable-stringify-without-jsonify: 1.0.1
|
json-stable-stringify-without-jsonify: 1.0.1
|
||||||
lodash.merge: 4.6.2
|
minimatch: 10.2.1
|
||||||
minimatch: 3.1.2
|
|
||||||
natural-compare: 1.4.0
|
natural-compare: 1.4.0
|
||||||
optionator: 0.9.4
|
optionator: 0.9.4
|
||||||
transitivePeerDependencies:
|
transitivePeerDependencies:
|
||||||
@@ -3467,6 +3454,12 @@ snapshots:
|
|||||||
acorn-jsx: 5.3.2(acorn@8.15.0)
|
acorn-jsx: 5.3.2(acorn@8.15.0)
|
||||||
eslint-visitor-keys: 4.2.1
|
eslint-visitor-keys: 4.2.1
|
||||||
|
|
||||||
|
espree@11.1.0:
|
||||||
|
dependencies:
|
||||||
|
acorn: 8.15.0
|
||||||
|
acorn-jsx: 5.3.2(acorn@8.15.0)
|
||||||
|
eslint-visitor-keys: 5.0.0
|
||||||
|
|
||||||
espree@6.2.1:
|
espree@6.2.1:
|
||||||
dependencies:
|
dependencies:
|
||||||
acorn: 7.4.1
|
acorn: 7.4.1
|
||||||
@@ -3796,6 +3789,16 @@ snapshots:
|
|||||||
|
|
||||||
istanbul-lib-coverage@3.2.2: {}
|
istanbul-lib-coverage@3.2.2: {}
|
||||||
|
|
||||||
|
istanbul-lib-instrument@6.0.3:
|
||||||
|
dependencies:
|
||||||
|
'@babel/core': 7.29.0
|
||||||
|
'@babel/parser': 7.29.0
|
||||||
|
'@istanbuljs/schema': 0.1.3
|
||||||
|
istanbul-lib-coverage: 3.2.2
|
||||||
|
semver: 7.7.3
|
||||||
|
transitivePeerDependencies:
|
||||||
|
- supports-color
|
||||||
|
|
||||||
istanbul-lib-report@3.0.1:
|
istanbul-lib-report@3.0.1:
|
||||||
dependencies:
|
dependencies:
|
||||||
istanbul-lib-coverage: 3.2.2
|
istanbul-lib-coverage: 3.2.2
|
||||||
@@ -3816,6 +3819,10 @@ snapshots:
|
|||||||
has-symbols: 1.1.0
|
has-symbols: 1.1.0
|
||||||
set-function-name: 2.0.2
|
set-function-name: 2.0.2
|
||||||
|
|
||||||
|
jackspeak@4.2.3:
|
||||||
|
dependencies:
|
||||||
|
'@isaacs/cliui': 9.0.0
|
||||||
|
|
||||||
js-tokens@10.0.0: {}
|
js-tokens@10.0.0: {}
|
||||||
|
|
||||||
js-tokens@4.0.0: {}
|
js-tokens@4.0.0: {}
|
||||||
@@ -3870,8 +3877,6 @@ snapshots:
|
|||||||
dependencies:
|
dependencies:
|
||||||
p-locate: 5.0.0
|
p-locate: 5.0.0
|
||||||
|
|
||||||
lodash.merge@4.6.2: {}
|
|
||||||
|
|
||||||
loose-envify@1.4.0:
|
loose-envify@1.4.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
js-tokens: 4.0.0
|
js-tokens: 4.0.0
|
||||||
@@ -3890,12 +3895,6 @@ snapshots:
|
|||||||
'@babel/types': 7.29.0
|
'@babel/types': 7.29.0
|
||||||
source-map-js: 1.2.1
|
source-map-js: 1.2.1
|
||||||
|
|
||||||
magicast@0.5.2:
|
|
||||||
dependencies:
|
|
||||||
'@babel/parser': 7.29.0
|
|
||||||
'@babel/types': 7.29.0
|
|
||||||
source-map-js: 1.2.1
|
|
||||||
|
|
||||||
make-dir@4.0.0:
|
make-dir@4.0.0:
|
||||||
dependencies:
|
dependencies:
|
||||||
semver: 7.7.3
|
semver: 7.7.3
|
||||||
@@ -3917,6 +3916,10 @@ snapshots:
|
|||||||
|
|
||||||
min-indent@1.0.1: {}
|
min-indent@1.0.1: {}
|
||||||
|
|
||||||
|
minimatch@10.2.1:
|
||||||
|
dependencies:
|
||||||
|
brace-expansion: 5.0.2
|
||||||
|
|
||||||
minimatch@3.1.2:
|
minimatch@3.1.2:
|
||||||
dependencies:
|
dependencies:
|
||||||
brace-expansion: 1.1.12
|
brace-expansion: 1.1.12
|
||||||
|
|||||||
@@ -6,9 +6,7 @@
|
|||||||
|
|
||||||
import axios, { isAxiosError, type AxiosInstance } from "axios";
|
import axios, { isAxiosError, type AxiosInstance } from "axios";
|
||||||
import { config } from "../config.js";
|
import { config } from "../config.js";
|
||||||
import { logger } from "../utils/logger.js";
|
|
||||||
import type {
|
import type {
|
||||||
GiteaCombinedStatus,
|
|
||||||
GiteaFile,
|
GiteaFile,
|
||||||
GiteaPullRequest,
|
GiteaPullRequest,
|
||||||
GiteaRepository,
|
GiteaRepository,
|
||||||
@@ -144,87 +142,6 @@ class GiteaService {
|
|||||||
);
|
);
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the combined commit status for a specific commit by querying the Gitea API for all status checks.
|
|
||||||
* @param owner - The repository owner.
|
|
||||||
* @param repo - The repository name.
|
|
||||||
* @param sha - The commit SHA to check.
|
|
||||||
* @returns The combined status of all checks (pending, success, error, or failure).
|
|
||||||
*/
|
|
||||||
public async getCommitStatus(
|
|
||||||
owner: string,
|
|
||||||
repo: string,
|
|
||||||
sha: string,
|
|
||||||
): Promise<GiteaCombinedStatus> {
|
|
||||||
const { data } = await this.client.get<GiteaCombinedStatus>(
|
|
||||||
`/repos/${owner}/${repo}/commits/${sha}/status`,
|
|
||||||
);
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Merges a pull request.
|
|
||||||
* @param owner - The repository owner.
|
|
||||||
* @param repo - The repository name.
|
|
||||||
* @param index - The pull request index number.
|
|
||||||
* @returns True if the merge was successful, false otherwise.
|
|
||||||
*/
|
|
||||||
public async mergePullRequest(
|
|
||||||
owner: string,
|
|
||||||
repo: string,
|
|
||||||
index: number,
|
|
||||||
): Promise<boolean> {
|
|
||||||
try {
|
|
||||||
await this.client.post(
|
|
||||||
`/repos/${owner}/${repo}/pulls/${String(index)}/merge`,
|
|
||||||
{
|
|
||||||
/* eslint-disable @typescript-eslint/naming-convention -- Gitea API uses snake_case */
|
|
||||||
Do: "merge",
|
|
||||||
MergeMessageField: "",
|
|
||||||
MergeTitleField: "",
|
|
||||||
delete_branch_after_merge: true,
|
|
||||||
force_merge: true,
|
|
||||||
head_commit_id: "",
|
|
||||||
merge_when_checks_succeed: false,
|
|
||||||
/* eslint-enable @typescript-eslint/naming-convention -- End Gitea API */
|
|
||||||
},
|
|
||||||
);
|
|
||||||
return true;
|
|
||||||
} catch (error) {
|
|
||||||
if (isAxiosError(error)) {
|
|
||||||
await logger.log(
|
|
||||||
"warn",
|
|
||||||
`Merge failed with status ${String(error.response?.status)}: ${JSON.stringify(error.response?.data)}`,
|
|
||||||
);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
throw error;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Deletes a repository branch by name.
|
|
||||||
* @param owner - The repository owner.
|
|
||||||
* @param repo - The repository name.
|
|
||||||
* @param branch - The branch name to remove.
|
|
||||||
* @returns True if successful, false otherwise.
|
|
||||||
*/
|
|
||||||
public async deleteBranch(
|
|
||||||
owner: string,
|
|
||||||
repo: string,
|
|
||||||
branch: string,
|
|
||||||
): Promise<boolean> {
|
|
||||||
try {
|
|
||||||
await this.client.delete(`/repos/${owner}/${repo}/branches/${branch}`);
|
|
||||||
return true;
|
|
||||||
} catch (error) {
|
|
||||||
if (isAxiosError(error)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
throw error;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export { GiteaService };
|
export { GiteaService };
|
||||||
|
|||||||
@@ -6,10 +6,6 @@
|
|||||||
|
|
||||||
import { config } from "../config.js";
|
import { config } from "../config.js";
|
||||||
import { logger } from "../utils/logger.js";
|
import { logger } from "../utils/logger.js";
|
||||||
import {
|
|
||||||
isMajorVersionBump,
|
|
||||||
stripVersionPrefix,
|
|
||||||
} from "../utils/versionComparison.js";
|
|
||||||
import { DependencyAnalyzerService } from "./dependencyAnalyzerService.js";
|
import { DependencyAnalyzerService } from "./dependencyAnalyzerService.js";
|
||||||
import { GiteaService } from "./giteaService.js";
|
import { GiteaService } from "./giteaService.js";
|
||||||
import {
|
import {
|
||||||
@@ -21,6 +17,15 @@ import { NpmService } from "./npmService.js";
|
|||||||
import type { GiteaRepository } from "../types/gitea.types.js";
|
import type { GiteaRepository } from "../types/gitea.types.js";
|
||||||
import type { DependencyUpdate, PackageJson } from "../types/package.types.js";
|
import type { DependencyUpdate, PackageJson } from "../types/package.types.js";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Strips version prefix characters from a version string.
|
||||||
|
* @param version - The version string with potential prefixes.
|
||||||
|
* @returns The version without prefix characters.
|
||||||
|
*/
|
||||||
|
const stripVersionPrefix = (version: string): string => {
|
||||||
|
return version.replace(/^[<=>^~]*/, "");
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generates the body content for a PR.
|
* Generates the body content for a PR.
|
||||||
* @param update - The dependency update information.
|
* @param update - The dependency update information.
|
||||||
@@ -137,103 +142,6 @@ class UpdateOrchestratorService {
|
|||||||
await logger.log("info", "Dependency update check complete!");
|
await logger.log("info", "Dependency update check complete!");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Attempts to merge an existing PR after checking CI status.
|
|
||||||
* @param repo - The repository information.
|
|
||||||
* @param update - The dependency update details.
|
|
||||||
* @param matchingPR - The existing PR with head SHA and number.
|
|
||||||
* @param matchingPR.head - The PR head information.
|
|
||||||
* @param matchingPR.head.sha - The commit SHA to check.
|
|
||||||
* @param matchingPR.number - The PR number for merging.
|
|
||||||
* @returns True if merge was attempted, false otherwise.
|
|
||||||
*/
|
|
||||||
private async attemptPRMerge(
|
|
||||||
repo: GiteaRepository,
|
|
||||||
update: DependencyUpdate,
|
|
||||||
matchingPR: { head: { sha: string }; number: number },
|
|
||||||
): Promise<boolean> {
|
|
||||||
const commitStatus = await this.giteaService.getCommitStatus(
|
|
||||||
config.giteaOrg,
|
|
||||||
repo.name,
|
|
||||||
matchingPR.head.sha,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (commitStatus.state !== "success") {
|
|
||||||
await logger.log(
|
|
||||||
"info",
|
|
||||||
` PR exists for ${update.packageName} but CI status is ${commitStatus.state}, skipping auto-merge...`,
|
|
||||||
);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
await logger.log(
|
|
||||||
"info",
|
|
||||||
` Auto-merging PR for ${update.packageName} (CI passed, non-major bump)...`,
|
|
||||||
);
|
|
||||||
|
|
||||||
const merged = await this.giteaService.mergePullRequest(
|
|
||||||
config.giteaOrg,
|
|
||||||
repo.name,
|
|
||||||
matchingPR.number,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (merged) {
|
|
||||||
await logger.log(
|
|
||||||
"info",
|
|
||||||
` Successfully merged PR for ${update.packageName}`,
|
|
||||||
);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
await logger.log(
|
|
||||||
"warn",
|
|
||||||
` Failed to merge PR for ${update.packageName}`,
|
|
||||||
);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Checks if an existing PR can be auto-merged based on CI status and version bump type.
|
|
||||||
* @param repo - The repository information.
|
|
||||||
* @param update - The dependency update details.
|
|
||||||
* @param branchName - The branch name for the PR.
|
|
||||||
* @returns True if the PR exists and was handled, false otherwise.
|
|
||||||
*/
|
|
||||||
private async checkAndMergeExistingPR(
|
|
||||||
repo: GiteaRepository,
|
|
||||||
update: DependencyUpdate,
|
|
||||||
branchName: string,
|
|
||||||
): Promise<boolean> {
|
|
||||||
const existingPRs = await this.giteaService.listPullRequests(
|
|
||||||
config.giteaOrg,
|
|
||||||
repo.name,
|
|
||||||
"open",
|
|
||||||
);
|
|
||||||
|
|
||||||
const matchingPR = existingPRs.find((pr) => {
|
|
||||||
return pr.head.ref === branchName;
|
|
||||||
});
|
|
||||||
|
|
||||||
if (matchingPR === undefined) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const isMajorBump = isMajorVersionBump(
|
|
||||||
update.currentVersion,
|
|
||||||
update.latestVersion,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (isMajorBump) {
|
|
||||||
await logger.log(
|
|
||||||
"info",
|
|
||||||
` PR exists for ${update.packageName} but is a major version bump, skipping auto-merge...`,
|
|
||||||
);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return await this.attemptPRMerge(repo, update, matchingPR);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates or updates a PR for a dependency update.
|
* Creates or updates a PR for a dependency update.
|
||||||
* @param repo - The repository information.
|
* @param repo - The repository information.
|
||||||
@@ -249,16 +157,6 @@ class UpdateOrchestratorService {
|
|||||||
= `${config.prBranchPrefix}${update.packageName.replaceAll(/[/@]/g, "-")}`;
|
= `${config.prBranchPrefix}${update.packageName.replaceAll(/[/@]/g, "-")}`;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const existingPRMerged = await this.checkAndMergeExistingPR(
|
|
||||||
repo,
|
|
||||||
update,
|
|
||||||
branchName,
|
|
||||||
);
|
|
||||||
|
|
||||||
if (existingPRMerged) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const result = await createOrUpdateBranch({
|
const result = await createOrUpdateBranch({
|
||||||
branchName: branchName,
|
branchName: branchName,
|
||||||
clonedRepo: clonedRepo,
|
clonedRepo: clonedRepo,
|
||||||
|
|||||||
@@ -39,33 +39,6 @@ interface GiteaPullRequest {
|
|||||||
state: "closed" | "open";
|
state: "closed" | "open";
|
||||||
title: string;
|
title: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface GiteaCommitStatus {
|
|
||||||
context: string;
|
|
||||||
created_at: string;
|
|
||||||
description: string;
|
|
||||||
id: number;
|
|
||||||
state: "error" | "failure" | "pending" | "success" | "warning";
|
|
||||||
target_url: string;
|
|
||||||
updated_at: string;
|
|
||||||
url: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface GiteaCombinedStatus {
|
|
||||||
commit_url: string;
|
|
||||||
repository: GiteaRepository;
|
|
||||||
sha: string;
|
|
||||||
state: "error" | "failure" | "pending" | "success" | "warning";
|
|
||||||
statuses: Array<GiteaCommitStatus>;
|
|
||||||
total_count: number;
|
|
||||||
url: string;
|
|
||||||
}
|
|
||||||
/* eslint-enable @typescript-eslint/naming-convention -- End Gitea API types */
|
/* eslint-enable @typescript-eslint/naming-convention -- End Gitea API types */
|
||||||
|
|
||||||
export type {
|
export type { GiteaFile, GiteaPullRequest, GiteaRepository };
|
||||||
GiteaCombinedStatus,
|
|
||||||
GiteaCommitStatus,
|
|
||||||
GiteaFile,
|
|
||||||
GiteaPullRequest,
|
|
||||||
GiteaRepository,
|
|
||||||
};
|
|
||||||
|
|||||||
+4
-7
@@ -4,22 +4,19 @@
|
|||||||
* @author Naomi Carrigan
|
* @author Naomi Carrigan
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import type { Logger } from "@nhcarrigan/logger";
|
import { Logger } from "@nhcarrigan/logger";
|
||||||
|
|
||||||
// Import { Logger } from "@nhcarrigan/logger";
|
// import { Logger } from "@nhcarrigan/logger";
|
||||||
|
|
||||||
// Const logger = new Logger("Minori", process.env.LOG_TOKEN ?? "");
|
// const logger = new Logger("Minori", process.env.LOG_TOKEN ?? "");
|
||||||
|
|
||||||
/* eslint-disable no-console -- Temporary mock logger for development */
|
|
||||||
/* eslint-disable @typescript-eslint/consistent-type-assertions -- Mock logger requires type assertion */
|
|
||||||
const logger = {
|
const logger = {
|
||||||
error: (message: string, error: Error) => {
|
error: (message: string, error: Error) => {
|
||||||
console.error(message, error);
|
console.error(message, error);
|
||||||
},
|
},
|
||||||
log: (level: string, message: string) => {
|
log: (level: string, message: string) => {
|
||||||
console.log(level, message);
|
console.log(level, message);
|
||||||
},
|
},
|
||||||
} as unknown as Logger;
|
} as unknown as Logger;
|
||||||
/* eslint-enable no-console, @typescript-eslint/consistent-type-assertions -- Re-enable rules after mock logger */
|
|
||||||
|
|
||||||
export { logger };
|
export { logger };
|
||||||
|
|||||||
@@ -1,64 +0,0 @@
|
|||||||
/**
|
|
||||||
* @copyright NHCarrigan
|
|
||||||
* @license Naomi's Public License
|
|
||||||
* @author Naomi Carrigan
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Strips version prefix characters from a version string.
|
|
||||||
* @param version - The version string with potential prefixes.
|
|
||||||
* @returns The version without prefix characters.
|
|
||||||
*/
|
|
||||||
const stripVersionPrefix = (version: string): string => {
|
|
||||||
return version.replace(/^[<=>^~]*/, "");
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parses a semantic version string into its components.
|
|
||||||
* @param version - The version string to parse (e.g., "1.2.3").
|
|
||||||
* @returns An object with major, minor, and patch numbers, or null if invalid.
|
|
||||||
*/
|
|
||||||
const parseVersion = (
|
|
||||||
version: string,
|
|
||||||
): { major: number; minor: number; patch: number } | null => {
|
|
||||||
const cleaned = stripVersionPrefix(version);
|
|
||||||
const parts = cleaned.split(".");
|
|
||||||
|
|
||||||
if (parts.length < 3) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
const major = Number.parseInt(parts[0] ?? "0", 10);
|
|
||||||
const minor = Number.parseInt(parts[1] ?? "0", 10);
|
|
||||||
const patchPart = parts[2] ?? "0";
|
|
||||||
const patch = Number.parseInt(patchPart.split("-")[0] ?? "0", 10);
|
|
||||||
|
|
||||||
if (Number.isNaN(major) || Number.isNaN(minor) || Number.isNaN(patch)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return { major, minor, patch };
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Determines if a version update is a major version bump.
|
|
||||||
* A major bump occurs when the major version number increases.
|
|
||||||
* @param fromVersion - The current version.
|
|
||||||
* @param toVersion - The target version.
|
|
||||||
* @returns True if this is a major version bump, false otherwise.
|
|
||||||
*/
|
|
||||||
const isMajorVersionBump = (
|
|
||||||
fromVersion: string,
|
|
||||||
toVersion: string,
|
|
||||||
): boolean => {
|
|
||||||
const from = parseVersion(fromVersion);
|
|
||||||
const to = parseVersion(toVersion);
|
|
||||||
|
|
||||||
if (from === null || to === null) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return to.major > from.major;
|
|
||||||
};
|
|
||||||
|
|
||||||
export { isMajorVersionBump, stripVersionPrefix };
|
|
||||||
@@ -6,16 +6,11 @@
|
|||||||
|
|
||||||
/* eslint-disable vitest/valid-expect -- Test expectations don't need messages */
|
/* eslint-disable vitest/valid-expect -- Test expectations don't need messages */
|
||||||
/* eslint-disable max-lines-per-function -- Test suites require many test cases */
|
/* eslint-disable max-lines-per-function -- Test suites require many test cases */
|
||||||
/* eslint-disable max-lines -- Test suites naturally have many cases */
|
|
||||||
/* eslint-disable max-statements -- Test suites naturally have many statements */
|
|
||||||
/* eslint-disable @typescript-eslint/consistent-type-assertions -- Required for mocking */
|
/* eslint-disable @typescript-eslint/consistent-type-assertions -- Required for mocking */
|
||||||
/* eslint-disable @typescript-eslint/consistent-type-imports -- Dynamic imports */
|
/* eslint-disable @typescript-eslint/consistent-type-imports -- Dynamic imports */
|
||||||
/* eslint-disable @typescript-eslint/naming-convention -- Environment variables and Gitea API format */
|
/* eslint-disable @typescript-eslint/naming-convention -- Environment variables and Gitea API format */
|
||||||
/* eslint-disable max-nested-callbacks -- Vitest structure requires nested callbacks */
|
/* eslint-disable max-nested-callbacks -- Vitest structure requires nested callbacks */
|
||||||
/* eslint-disable vitest/require-to-throw-message -- Generic throw assertion */
|
/* eslint-disable vitest/require-to-throw-message -- Generic throw assertion */
|
||||||
/* eslint-disable vitest/prefer-to-be-truthy -- toBe(true) is clearer for boolean functions */
|
|
||||||
/* eslint-disable vitest/prefer-to-be-falsy -- toBe(false) is clearer for boolean functions */
|
|
||||||
/* eslint-disable stylistic/max-len -- Test files have long object literals */
|
|
||||||
|
|
||||||
import axios, { AxiosError, type AxiosResponse } from "axios";
|
import axios, { AxiosError, type AxiosResponse } from "axios";
|
||||||
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
||||||
@@ -29,9 +24,8 @@ vi.mock("axios", async() => {
|
|||||||
default: {
|
default: {
|
||||||
create: vi.fn(() => {
|
create: vi.fn(() => {
|
||||||
return {
|
return {
|
||||||
delete: vi.fn(),
|
get: vi.fn(),
|
||||||
get: vi.fn(),
|
post: vi.fn(),
|
||||||
post: vi.fn(),
|
|
||||||
};
|
};
|
||||||
}),
|
}),
|
||||||
},
|
},
|
||||||
@@ -75,8 +69,6 @@ describe("giteaService", () => {
|
|||||||
let mockGet: ReturnType<typeof vi.fn>;
|
let mockGet: ReturnType<typeof vi.fn>;
|
||||||
// eslint-disable-next-line @typescript-eslint/init-declarations -- Reassigned in beforeEach
|
// eslint-disable-next-line @typescript-eslint/init-declarations -- Reassigned in beforeEach
|
||||||
let mockPost: ReturnType<typeof vi.fn>;
|
let mockPost: ReturnType<typeof vi.fn>;
|
||||||
// eslint-disable-next-line @typescript-eslint/init-declarations -- Reassigned in beforeEach
|
|
||||||
let mockDelete: ReturnType<typeof vi.fn>;
|
|
||||||
const originalEnvironment = process.env;
|
const originalEnvironment = process.env;
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
@@ -85,11 +77,9 @@ describe("giteaService", () => {
|
|||||||
|
|
||||||
mockGet = vi.fn();
|
mockGet = vi.fn();
|
||||||
mockPost = vi.fn();
|
mockPost = vi.fn();
|
||||||
mockDelete = vi.fn();
|
|
||||||
vi.mocked(axios.create).mockReturnValue({
|
vi.mocked(axios.create).mockReturnValue({
|
||||||
delete: mockDelete,
|
get: mockGet,
|
||||||
get: mockGet,
|
post: mockPost,
|
||||||
post: mockPost,
|
|
||||||
} as unknown as ReturnType<typeof axios.create>);
|
} as unknown as ReturnType<typeof axios.create>);
|
||||||
|
|
||||||
giteaService = new GiteaService();
|
giteaService = new GiteaService();
|
||||||
@@ -316,69 +306,4 @@ describe("giteaService", () => {
|
|||||||
{ params: { state: "closed" } },
|
{ params: { state: "closed" } },
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should get commit status", async() => {
|
|
||||||
expect.assertions(2);
|
|
||||||
const mockStatus = {
|
|
||||||
commit_url: "https://git.nhcarrigan.com/api/v1/repos/owner/repo/commits/abc123",
|
|
||||||
repository: createMockRepository({ id: 1, name: "test-repo" }),
|
|
||||||
sha: "abc123",
|
|
||||||
state: "success",
|
|
||||||
statuses: [],
|
|
||||||
total_count: 0,
|
|
||||||
url: "https://git.nhcarrigan.com/api/v1/repos/owner/repo/commits/abc123/status",
|
|
||||||
};
|
|
||||||
mockGet.mockResolvedValueOnce({ data: mockStatus });
|
|
||||||
const result = await giteaService.getCommitStatus("owner", "repo", "abc123");
|
|
||||||
expect(result).toStrictEqual(mockStatus);
|
|
||||||
expect(mockGet).toHaveBeenCalledWith("/repos/owner/repo/commits/abc123/status");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should merge a pull request successfully", async() => {
|
|
||||||
expect.assertions(2);
|
|
||||||
mockPost.mockResolvedValueOnce({ data: {} });
|
|
||||||
const result = await giteaService.mergePullRequest("owner", "repo", 1);
|
|
||||||
expect(result).toBe(true);
|
|
||||||
expect(mockPost).toHaveBeenCalledWith("/repos/owner/repo/pulls/1/merge", {
|
|
||||||
Do: "merge",
|
|
||||||
MergeMessageField: "",
|
|
||||||
MergeTitleField: "",
|
|
||||||
delete_branch_after_merge: true,
|
|
||||||
force_merge: false,
|
|
||||||
head_commit_id: "",
|
|
||||||
merge_when_checks_succeed: false,
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should return false when merge fails", async() => {
|
|
||||||
expect.assertions(1);
|
|
||||||
const axiosError = new AxiosError("Merge conflict");
|
|
||||||
mockPost.mockRejectedValueOnce(axiosError);
|
|
||||||
const result = await giteaService.mergePullRequest("owner", "repo", 1);
|
|
||||||
expect(result).toBe(false);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should delete a branch successfully", async() => {
|
|
||||||
expect.assertions(2);
|
|
||||||
mockDelete.mockResolvedValueOnce({ data: {} });
|
|
||||||
const result = await giteaService.deleteBranch(
|
|
||||||
"owner",
|
|
||||||
"repo",
|
|
||||||
"feature-branch",
|
|
||||||
);
|
|
||||||
expect(result).toBe(true);
|
|
||||||
expect(mockDelete).toHaveBeenCalledWith("/repos/owner/repo/branches/feature-branch");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should return false when branch deletion fails", async() => {
|
|
||||||
expect.assertions(1);
|
|
||||||
const axiosError = new AxiosError("Branch not found");
|
|
||||||
mockDelete.mockRejectedValueOnce(axiosError);
|
|
||||||
const result = await giteaService.deleteBranch(
|
|
||||||
"owner",
|
|
||||||
"repo",
|
|
||||||
"nonexistent-branch",
|
|
||||||
);
|
|
||||||
expect(result).toBe(false);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -18,8 +18,6 @@ const mockGiteaGetFileContent = vi.fn();
|
|||||||
const mockGiteaListOrgRepositories = vi.fn();
|
const mockGiteaListOrgRepositories = vi.fn();
|
||||||
const mockGiteaCreatePullRequest = vi.fn();
|
const mockGiteaCreatePullRequest = vi.fn();
|
||||||
const mockGiteaListPullRequests = vi.fn();
|
const mockGiteaListPullRequests = vi.fn();
|
||||||
const mockGiteaGetCommitStatus = vi.fn();
|
|
||||||
const mockGiteaMergePullRequest = vi.fn();
|
|
||||||
const mockNpmGetPackageChangelog = vi.fn();
|
const mockNpmGetPackageChangelog = vi.fn();
|
||||||
const mockNpmGetPackageInfo = vi.fn();
|
const mockNpmGetPackageInfo = vi.fn();
|
||||||
const mockAnalyzePackageJson = vi.fn();
|
const mockAnalyzePackageJson = vi.fn();
|
||||||
@@ -41,11 +39,9 @@ vi.mock("../../src/services/giteaService.js", () => {
|
|||||||
|
|
||||||
GiteaService: class MockGiteaService {
|
GiteaService: class MockGiteaService {
|
||||||
public createPullRequest = mockGiteaCreatePullRequest;
|
public createPullRequest = mockGiteaCreatePullRequest;
|
||||||
public getCommitStatus = mockGiteaGetCommitStatus;
|
|
||||||
public getFileContent = mockGiteaGetFileContent;
|
public getFileContent = mockGiteaGetFileContent;
|
||||||
public listOrgRepositories = mockGiteaListOrgRepositories;
|
public listOrgRepositories = mockGiteaListOrgRepositories;
|
||||||
public listPullRequests = mockGiteaListPullRequests;
|
public listPullRequests = mockGiteaListPullRequests;
|
||||||
public mergePullRequest = mockGiteaMergePullRequest;
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
@@ -225,7 +221,6 @@ describe("updateOrchestratorService", () => {
|
|||||||
const mockUpdates = [ createMockUpdate() ];
|
const mockUpdates = [ createMockUpdate() ];
|
||||||
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
||||||
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
||||||
mockGiteaListPullRequests.mockResolvedValue([]);
|
|
||||||
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
||||||
mockNpmGetPackageChangelog.mockResolvedValue("## Changelog");
|
mockNpmGetPackageChangelog.mockResolvedValue("## Changelog");
|
||||||
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
||||||
@@ -272,7 +267,6 @@ describe("updateOrchestratorService", () => {
|
|||||||
const mockUpdates = [ createMockUpdate() ];
|
const mockUpdates = [ createMockUpdate() ];
|
||||||
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
||||||
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
||||||
mockGiteaListPullRequests.mockResolvedValue([]);
|
|
||||||
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
||||||
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
||||||
mockCreateOrUpdateBranch.mockResolvedValue({
|
mockCreateOrUpdateBranch.mockResolvedValue({
|
||||||
@@ -295,7 +289,6 @@ describe("updateOrchestratorService", () => {
|
|||||||
const mockUpdates = [ createMockUpdate() ];
|
const mockUpdates = [ createMockUpdate() ];
|
||||||
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
||||||
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
||||||
mockGiteaListPullRequests.mockResolvedValue([]);
|
|
||||||
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
||||||
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
||||||
mockCreateOrUpdateBranch.mockResolvedValue({
|
mockCreateOrUpdateBranch.mockResolvedValue({
|
||||||
@@ -319,7 +312,6 @@ describe("updateOrchestratorService", () => {
|
|||||||
const mockUpdates = [ createMockUpdate() ];
|
const mockUpdates = [ createMockUpdate() ];
|
||||||
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
||||||
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
||||||
mockGiteaListPullRequests.mockResolvedValue([]);
|
|
||||||
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
||||||
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
||||||
mockCreateOrUpdateBranch.mockResolvedValue({
|
mockCreateOrUpdateBranch.mockResolvedValue({
|
||||||
@@ -362,7 +354,6 @@ describe("updateOrchestratorService", () => {
|
|||||||
const mockUpdates = [ createMockUpdate() ];
|
const mockUpdates = [ createMockUpdate() ];
|
||||||
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
||||||
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
||||||
mockGiteaListPullRequests.mockResolvedValue([]);
|
|
||||||
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
||||||
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
||||||
mockCreateOrUpdateBranch.mockResolvedValue({
|
mockCreateOrUpdateBranch.mockResolvedValue({
|
||||||
@@ -386,7 +377,6 @@ describe("updateOrchestratorService", () => {
|
|||||||
const mockUpdates = [ createMockUpdate() ];
|
const mockUpdates = [ createMockUpdate() ];
|
||||||
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
||||||
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
||||||
mockGiteaListPullRequests.mockResolvedValue([]);
|
|
||||||
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
||||||
mockNpmGetPackageChangelog.mockResolvedValue("## Changelog");
|
mockNpmGetPackageChangelog.mockResolvedValue("## Changelog");
|
||||||
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
mockCloneRepository.mockResolvedValue(createMockClonedRepo());
|
||||||
@@ -436,7 +426,6 @@ describe("updateOrchestratorService", () => {
|
|||||||
const mockCleanup = vi.fn();
|
const mockCleanup = vi.fn();
|
||||||
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
mockGiteaListOrgRepositories.mockResolvedValue(mockRepos);
|
||||||
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
mockGiteaGetFileContent.mockResolvedValue(mockFileContent);
|
||||||
mockGiteaListPullRequests.mockResolvedValue([]);
|
|
||||||
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
mockAnalyzePackageJson.mockResolvedValue(mockUpdates);
|
||||||
mockCloneRepository.mockResolvedValue(createMockClonedRepo(mockCleanup));
|
mockCloneRepository.mockResolvedValue(createMockClonedRepo(mockCleanup));
|
||||||
mockCreateOrUpdateBranch.mockResolvedValue({
|
mockCreateOrUpdateBranch.mockResolvedValue({
|
||||||
|
|||||||
@@ -1,108 +0,0 @@
|
|||||||
/**
|
|
||||||
* @copyright NHCarrigan
|
|
||||||
* @license Naomi's Public License
|
|
||||||
* @author Naomi Carrigan
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* eslint-disable vitest/valid-expect -- Test expectations don't need messages */
|
|
||||||
/* eslint-disable max-lines-per-function -- Test suites naturally have many cases */
|
|
||||||
/* eslint-disable max-nested-callbacks -- Vitest structure requires nesting */
|
|
||||||
/* eslint-disable vitest/prefer-to-be-truthy -- toBe(true) is clearer for boolean functions */
|
|
||||||
/* eslint-disable vitest/prefer-to-be-falsy -- toBe(false) is clearer for boolean functions */
|
|
||||||
|
|
||||||
import { describe, expect, it } from "vitest";
|
|
||||||
import {
|
|
||||||
isMajorVersionBump,
|
|
||||||
stripVersionPrefix,
|
|
||||||
} from "../../src/utils/versionComparison.js";
|
|
||||||
|
|
||||||
describe("versionComparison", () => {
|
|
||||||
describe("stripVersionPrefix", () => {
|
|
||||||
it("should strip caret prefix", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(stripVersionPrefix("^1.2.3")).toBe("1.2.3");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should strip tilde prefix", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(stripVersionPrefix("~1.2.3")).toBe("1.2.3");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should strip greater than prefix", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(stripVersionPrefix(">1.2.3")).toBe("1.2.3");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should strip less than prefix", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(stripVersionPrefix("<1.2.3")).toBe("1.2.3");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should strip equals prefix", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(stripVersionPrefix("=1.2.3")).toBe("1.2.3");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should strip multiple prefix characters", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(stripVersionPrefix(">=1.2.3")).toBe("1.2.3");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should return version without prefix unchanged", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(stripVersionPrefix("1.2.3")).toBe("1.2.3");
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("isMajorVersionBump", () => {
|
|
||||||
it("should detect major version bump", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(isMajorVersionBump("1.2.3", "2.0.0")).toBe(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should detect major version bump with prefixes", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(isMajorVersionBump("^1.2.3", "^2.0.0")).toBe(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should not detect minor version bump as major", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(isMajorVersionBump("1.2.3", "1.3.0")).toBe(false);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should not detect patch version bump as major", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(isMajorVersionBump("1.2.3", "1.2.4")).toBe(false);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should handle version with pre-release tags", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(isMajorVersionBump("1.2.3", "2.0.0-beta.1")).toBe(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should return false for invalid from version", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(isMajorVersionBump("invalid", "2.0.0")).toBe(false);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should return false for invalid to version", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(isMajorVersionBump("1.2.3", "invalid")).toBe(false);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should return false for both invalid versions", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(isMajorVersionBump("invalid", "also-invalid")).toBe(false);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should handle 0.x.x to 1.x.x as major bump", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(isMajorVersionBump("0.9.5", "1.0.0")).toBe(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should not detect same version as major bump", () => {
|
|
||||||
expect.assertions(1);
|
|
||||||
expect(isMajorVersionBump("1.2.3", "1.2.3")).toBe(false);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
Reference in New Issue
Block a user