forked from MapComplete/MapComplete
		
	Port tests to vitest
This commit is contained in:
		
							parent
							
								
									64a4d7e929
								
							
						
					
					
						commit
						228ceb120d
					
				
					 33 changed files with 673 additions and 326 deletions
				
			
		
							
								
								
									
										436
									
								
								package-lock.json
									
										
									
										generated
									
									
									
								
							
							
						
						
									
										436
									
								
								package-lock.json
									
										
									
										generated
									
									
									
								
							|  | @ -27,6 +27,7 @@ | ||||||
|         "geojson2svg": "^1.3.1", |         "geojson2svg": "^1.3.1", | ||||||
|         "i18next-client": "^1.11.4", |         "i18next-client": "^1.11.4", | ||||||
|         "idb-keyval": "^6.0.3", |         "idb-keyval": "^6.0.3", | ||||||
|  |         "jest-mock": "^29.4.1", | ||||||
|         "jspdf": "^2.5.1", |         "jspdf": "^2.5.1", | ||||||
|         "latlon2country": "^1.2.6", |         "latlon2country": "^1.2.6", | ||||||
|         "leaflet": "^1.9.2", |         "leaflet": "^1.9.2", | ||||||
|  | @ -64,7 +65,6 @@ | ||||||
|         "@types/leaflet-markercluster": "^1.0.3", |         "@types/leaflet-markercluster": "^1.0.3", | ||||||
|         "@types/leaflet-providers": "^1.2.0", |         "@types/leaflet-providers": "^1.2.0", | ||||||
|         "@types/lz-string": "^1.3.34", |         "@types/lz-string": "^1.3.34", | ||||||
|         "@types/mocha": "^9.1.0", |  | ||||||
|         "@types/node": "^18.11.18", |         "@types/node": "^18.11.18", | ||||||
|         "@types/papaparse": "^5.3.1", |         "@types/papaparse": "^5.3.1", | ||||||
|         "@types/prompt-sync": "^4.1.0", |         "@types/prompt-sync": "^4.1.0", | ||||||
|  | @ -74,7 +74,6 @@ | ||||||
|         "chai": "^4.3.6", |         "chai": "^4.3.6", | ||||||
|         "dependency-cruiser": "^10.4.0", |         "dependency-cruiser": "^10.4.0", | ||||||
|         "fs": "0.0.1-security", |         "fs": "0.0.1-security", | ||||||
|         "mocha": "^9.2.2", |  | ||||||
|         "prettier": "^2.7.1", |         "prettier": "^2.7.1", | ||||||
|         "prettier-plugin-svelte": "^2.9.0", |         "prettier-plugin-svelte": "^2.9.0", | ||||||
|         "read-file": "^0.2.0", |         "read-file": "^0.2.0", | ||||||
|  | @ -1622,6 +1621,97 @@ | ||||||
|         "node": ">=12" |         "node": ">=12" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "node_modules/@jest/schemas": { | ||||||
|  |       "version": "29.4.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.4.0.tgz", | ||||||
|  |       "integrity": "sha512-0E01f/gOZeNTG76i5eWWSupvSHaIINrTie7vCyjiYFKgzNdyEGd12BUv4oNBFHOqlHDbtoJi3HrQ38KCC90NsQ==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "@sinclair/typebox": "^0.25.16" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": "^14.15.0 || ^16.10.0 || >=18.0.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/@jest/types": { | ||||||
|  |       "version": "29.4.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.4.1.tgz", | ||||||
|  |       "integrity": "sha512-zbrAXDUOnpJ+FMST2rV7QZOgec8rskg2zv8g2ajeqitp4tvZiyqTCYXANrKsM+ryj5o+LI+ZN2EgU9drrkiwSA==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "@jest/schemas": "^29.4.0", | ||||||
|  |         "@types/istanbul-lib-coverage": "^2.0.0", | ||||||
|  |         "@types/istanbul-reports": "^3.0.0", | ||||||
|  |         "@types/node": "*", | ||||||
|  |         "@types/yargs": "^17.0.8", | ||||||
|  |         "chalk": "^4.0.0" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": "^14.15.0 || ^16.10.0 || >=18.0.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/@jest/types/node_modules/ansi-styles": { | ||||||
|  |       "version": "4.3.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", | ||||||
|  |       "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "color-convert": "^2.0.1" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=8" | ||||||
|  |       }, | ||||||
|  |       "funding": { | ||||||
|  |         "url": "https://github.com/chalk/ansi-styles?sponsor=1" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/@jest/types/node_modules/chalk": { | ||||||
|  |       "version": "4.1.2", | ||||||
|  |       "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", | ||||||
|  |       "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "ansi-styles": "^4.1.0", | ||||||
|  |         "supports-color": "^7.1.0" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=10" | ||||||
|  |       }, | ||||||
|  |       "funding": { | ||||||
|  |         "url": "https://github.com/chalk/chalk?sponsor=1" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/@jest/types/node_modules/color-convert": { | ||||||
|  |       "version": "2.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", | ||||||
|  |       "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "color-name": "~1.1.4" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=7.0.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/@jest/types/node_modules/color-name": { | ||||||
|  |       "version": "1.1.4", | ||||||
|  |       "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", | ||||||
|  |       "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" | ||||||
|  |     }, | ||||||
|  |     "node_modules/@jest/types/node_modules/has-flag": { | ||||||
|  |       "version": "4.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", | ||||||
|  |       "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=8" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/@jest/types/node_modules/supports-color": { | ||||||
|  |       "version": "7.2.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", | ||||||
|  |       "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "has-flag": "^4.0.0" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=8" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "node_modules/@jridgewell/gen-mapping": { |     "node_modules/@jridgewell/gen-mapping": { | ||||||
|       "version": "0.1.1", |       "version": "0.1.1", | ||||||
|       "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", |       "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", | ||||||
|  | @ -1831,6 +1921,11 @@ | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "node_modules/@sinclair/typebox": { | ||||||
|  |       "version": "0.25.21", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.25.21.tgz", | ||||||
|  |       "integrity": "sha512-gFukHN4t8K4+wVC+ECqeqwzBDeFeTzBXroBTqE6vcWrQGbEUpHO7LYdG0f4xnvYq4VOEwITSlHlp0JBAIFMS/g==" | ||||||
|  |     }, | ||||||
|     "node_modules/@sveltejs/vite-plugin-svelte": { |     "node_modules/@sveltejs/vite-plugin-svelte": { | ||||||
|       "version": "2.0.2", |       "version": "2.0.2", | ||||||
|       "resolved": "https://registry.npmjs.org/@sveltejs/vite-plugin-svelte/-/vite-plugin-svelte-2.0.2.tgz", |       "resolved": "https://registry.npmjs.org/@sveltejs/vite-plugin-svelte/-/vite-plugin-svelte-2.0.2.tgz", | ||||||
|  | @ -3470,6 +3565,27 @@ | ||||||
|       "integrity": "sha512-Nmh0K3iWQJzniTuPRcJn5hxXkfB1T1pgB89SBig5PlJQU5yocazeu4jATJlaA0GYFKWMqDdvYemoSnF2pXgLVA==", |       "integrity": "sha512-Nmh0K3iWQJzniTuPRcJn5hxXkfB1T1pgB89SBig5PlJQU5yocazeu4jATJlaA0GYFKWMqDdvYemoSnF2pXgLVA==", | ||||||
|       "devOptional": true |       "devOptional": true | ||||||
|     }, |     }, | ||||||
|  |     "node_modules/@types/istanbul-lib-coverage": { | ||||||
|  |       "version": "2.0.4", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", | ||||||
|  |       "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==" | ||||||
|  |     }, | ||||||
|  |     "node_modules/@types/istanbul-lib-report": { | ||||||
|  |       "version": "3.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", | ||||||
|  |       "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "@types/istanbul-lib-coverage": "*" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/@types/istanbul-reports": { | ||||||
|  |       "version": "3.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", | ||||||
|  |       "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "@types/istanbul-lib-report": "*" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "node_modules/@types/json-schema": { |     "node_modules/@types/json-schema": { | ||||||
|       "version": "7.0.11", |       "version": "7.0.11", | ||||||
|       "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", |       "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", | ||||||
|  | @ -3516,12 +3632,6 @@ | ||||||
|       "integrity": "sha512-j6G1e8DULJx3ONf6NdR5JiR2ZY3K3PaaqiEuKYkLQO0Czfi1AzrtjfnfCROyWGeDd5IVMKCwsgSmMip9OWijow==", |       "integrity": "sha512-j6G1e8DULJx3ONf6NdR5JiR2ZY3K3PaaqiEuKYkLQO0Czfi1AzrtjfnfCROyWGeDd5IVMKCwsgSmMip9OWijow==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "node_modules/@types/mocha": { |  | ||||||
|       "version": "9.1.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.1.1.tgz", |  | ||||||
|       "integrity": "sha512-Z61JK7DKDtdKTWwLeElSEBcWGRLY8g95ic5FoQqI9CMx0ns/Ghep3B4DfcEimiKMvtamNVULVNKEsiwV3aQmXw==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "node_modules/@types/node": { |     "node_modules/@types/node": { | ||||||
|       "version": "18.11.18", |       "version": "18.11.18", | ||||||
|       "resolved": "https://registry.npmjs.org/@types/node/-/node-18.11.18.tgz", |       "resolved": "https://registry.npmjs.org/@types/node/-/node-18.11.18.tgz", | ||||||
|  | @ -3587,6 +3697,19 @@ | ||||||
|         "@types/node": "*" |         "@types/node": "*" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "node_modules/@types/yargs": { | ||||||
|  |       "version": "17.0.22", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.22.tgz", | ||||||
|  |       "integrity": "sha512-pet5WJ9U8yPVRhkwuEIp5ktAeAqRZOq4UdAyWLWzxbtpyXnzbtLdKiXAjJzi/KLmPGS9wk86lUFWZFN6sISo4g==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "@types/yargs-parser": "*" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/@types/yargs-parser": { | ||||||
|  |       "version": "21.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", | ||||||
|  |       "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==" | ||||||
|  |     }, | ||||||
|     "node_modules/@ungap/promise-all-settled": { |     "node_modules/@ungap/promise-all-settled": { | ||||||
|       "version": "1.1.2", |       "version": "1.1.2", | ||||||
|       "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", |       "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", | ||||||
|  | @ -4411,6 +4534,20 @@ | ||||||
|       "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", |       "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|  |     "node_modules/ci-info": { | ||||||
|  |       "version": "3.7.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.7.1.tgz", | ||||||
|  |       "integrity": "sha512-4jYS4MOAaCIStSRwiuxc4B8MYhIe676yO1sYGzARnjXkWpmzZMMYxY6zu8WYWDhSuth5zhrQ1rhNSibyyvv4/w==", | ||||||
|  |       "funding": [ | ||||||
|  |         { | ||||||
|  |           "type": "github", | ||||||
|  |           "url": "https://github.com/sponsors/sibiraj-s" | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=8" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "node_modules/cli-cursor": { |     "node_modules/cli-cursor": { | ||||||
|       "version": "3.1.0", |       "version": "3.1.0", | ||||||
|       "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", |       "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", | ||||||
|  | @ -5774,8 +5911,7 @@ | ||||||
|     "node_modules/graceful-fs": { |     "node_modules/graceful-fs": { | ||||||
|       "version": "4.2.10", |       "version": "4.2.10", | ||||||
|       "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", |       "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", | ||||||
|       "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", |       "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==" | ||||||
|       "dev": true |  | ||||||
|     }, |     }, | ||||||
|     "node_modules/growl": { |     "node_modules/growl": { | ||||||
|       "version": "1.10.5", |       "version": "1.10.5", | ||||||
|  | @ -6419,6 +6555,99 @@ | ||||||
|       "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", |       "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", | ||||||
|       "integrity": "sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==" |       "integrity": "sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==" | ||||||
|     }, |     }, | ||||||
|  |     "node_modules/jest-mock": { | ||||||
|  |       "version": "29.4.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.4.1.tgz", | ||||||
|  |       "integrity": "sha512-MwA4hQ7zBOcgVCVnsM8TzaFLVUD/pFWTfbkY953Y81L5ret3GFRZtmPmRFAjKQSdCKoJvvqOu6Bvfpqlwwb0dQ==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "@jest/types": "^29.4.1", | ||||||
|  |         "@types/node": "*", | ||||||
|  |         "jest-util": "^29.4.1" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": "^14.15.0 || ^16.10.0 || >=18.0.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/jest-util": { | ||||||
|  |       "version": "29.4.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.4.1.tgz", | ||||||
|  |       "integrity": "sha512-bQy9FPGxVutgpN4VRc0hk6w7Hx/m6L53QxpDreTZgJd9gfx/AV2MjyPde9tGyZRINAUrSv57p2inGBu2dRLmkQ==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "@jest/types": "^29.4.1", | ||||||
|  |         "@types/node": "*", | ||||||
|  |         "chalk": "^4.0.0", | ||||||
|  |         "ci-info": "^3.2.0", | ||||||
|  |         "graceful-fs": "^4.2.9", | ||||||
|  |         "picomatch": "^2.2.3" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": "^14.15.0 || ^16.10.0 || >=18.0.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/jest-util/node_modules/ansi-styles": { | ||||||
|  |       "version": "4.3.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", | ||||||
|  |       "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "color-convert": "^2.0.1" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=8" | ||||||
|  |       }, | ||||||
|  |       "funding": { | ||||||
|  |         "url": "https://github.com/chalk/ansi-styles?sponsor=1" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/jest-util/node_modules/chalk": { | ||||||
|  |       "version": "4.1.2", | ||||||
|  |       "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", | ||||||
|  |       "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "ansi-styles": "^4.1.0", | ||||||
|  |         "supports-color": "^7.1.0" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=10" | ||||||
|  |       }, | ||||||
|  |       "funding": { | ||||||
|  |         "url": "https://github.com/chalk/chalk?sponsor=1" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/jest-util/node_modules/color-convert": { | ||||||
|  |       "version": "2.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", | ||||||
|  |       "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "color-name": "~1.1.4" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=7.0.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/jest-util/node_modules/color-name": { | ||||||
|  |       "version": "1.1.4", | ||||||
|  |       "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", | ||||||
|  |       "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" | ||||||
|  |     }, | ||||||
|  |     "node_modules/jest-util/node_modules/has-flag": { | ||||||
|  |       "version": "4.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", | ||||||
|  |       "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=8" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "node_modules/jest-util/node_modules/supports-color": { | ||||||
|  |       "version": "7.2.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", | ||||||
|  |       "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", | ||||||
|  |       "dependencies": { | ||||||
|  |         "has-flag": "^4.0.0" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=8" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "node_modules/jose": { |     "node_modules/jose": { | ||||||
|       "version": "4.11.2", |       "version": "4.11.2", | ||||||
|       "resolved": "https://registry.npmjs.org/jose/-/jose-4.11.2.tgz", |       "resolved": "https://registry.npmjs.org/jose/-/jose-4.11.2.tgz", | ||||||
|  | @ -12245,6 +12474,72 @@ | ||||||
|       "integrity": "sha512-mdPjPxfnmoqhgpiEArqi4egmBAMYvaObgn4poorpUaqmvzzbvqbowRllQ+ZgzGVMGKaPkqUmPDOOFQRUFDmeUw==", |       "integrity": "sha512-mdPjPxfnmoqhgpiEArqi4egmBAMYvaObgn4poorpUaqmvzzbvqbowRllQ+ZgzGVMGKaPkqUmPDOOFQRUFDmeUw==", | ||||||
|       "optional": true |       "optional": true | ||||||
|     }, |     }, | ||||||
|  |     "@jest/schemas": { | ||||||
|  |       "version": "29.4.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.4.0.tgz", | ||||||
|  |       "integrity": "sha512-0E01f/gOZeNTG76i5eWWSupvSHaIINrTie7vCyjiYFKgzNdyEGd12BUv4oNBFHOqlHDbtoJi3HrQ38KCC90NsQ==", | ||||||
|  |       "requires": { | ||||||
|  |         "@sinclair/typebox": "^0.25.16" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "@jest/types": { | ||||||
|  |       "version": "29.4.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.4.1.tgz", | ||||||
|  |       "integrity": "sha512-zbrAXDUOnpJ+FMST2rV7QZOgec8rskg2zv8g2ajeqitp4tvZiyqTCYXANrKsM+ryj5o+LI+ZN2EgU9drrkiwSA==", | ||||||
|  |       "requires": { | ||||||
|  |         "@jest/schemas": "^29.4.0", | ||||||
|  |         "@types/istanbul-lib-coverage": "^2.0.0", | ||||||
|  |         "@types/istanbul-reports": "^3.0.0", | ||||||
|  |         "@types/node": "*", | ||||||
|  |         "@types/yargs": "^17.0.8", | ||||||
|  |         "chalk": "^4.0.0" | ||||||
|  |       }, | ||||||
|  |       "dependencies": { | ||||||
|  |         "ansi-styles": { | ||||||
|  |           "version": "4.3.0", | ||||||
|  |           "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", | ||||||
|  |           "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", | ||||||
|  |           "requires": { | ||||||
|  |             "color-convert": "^2.0.1" | ||||||
|  |           } | ||||||
|  |         }, | ||||||
|  |         "chalk": { | ||||||
|  |           "version": "4.1.2", | ||||||
|  |           "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", | ||||||
|  |           "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", | ||||||
|  |           "requires": { | ||||||
|  |             "ansi-styles": "^4.1.0", | ||||||
|  |             "supports-color": "^7.1.0" | ||||||
|  |           } | ||||||
|  |         }, | ||||||
|  |         "color-convert": { | ||||||
|  |           "version": "2.0.1", | ||||||
|  |           "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", | ||||||
|  |           "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", | ||||||
|  |           "requires": { | ||||||
|  |             "color-name": "~1.1.4" | ||||||
|  |           } | ||||||
|  |         }, | ||||||
|  |         "color-name": { | ||||||
|  |           "version": "1.1.4", | ||||||
|  |           "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", | ||||||
|  |           "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" | ||||||
|  |         }, | ||||||
|  |         "has-flag": { | ||||||
|  |           "version": "4.0.0", | ||||||
|  |           "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", | ||||||
|  |           "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" | ||||||
|  |         }, | ||||||
|  |         "supports-color": { | ||||||
|  |           "version": "7.2.0", | ||||||
|  |           "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", | ||||||
|  |           "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", | ||||||
|  |           "requires": { | ||||||
|  |             "has-flag": "^4.0.0" | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "@jridgewell/gen-mapping": { |     "@jridgewell/gen-mapping": { | ||||||
|       "version": "0.1.1", |       "version": "0.1.1", | ||||||
|       "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", |       "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", | ||||||
|  | @ -12380,6 +12675,11 @@ | ||||||
|         "picomatch": "^2.3.1" |         "picomatch": "^2.3.1" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "@sinclair/typebox": { | ||||||
|  |       "version": "0.25.21", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.25.21.tgz", | ||||||
|  |       "integrity": "sha512-gFukHN4t8K4+wVC+ECqeqwzBDeFeTzBXroBTqE6vcWrQGbEUpHO7LYdG0f4xnvYq4VOEwITSlHlp0JBAIFMS/g==" | ||||||
|  |     }, | ||||||
|     "@sveltejs/vite-plugin-svelte": { |     "@sveltejs/vite-plugin-svelte": { | ||||||
|       "version": "2.0.2", |       "version": "2.0.2", | ||||||
|       "resolved": "https://registry.npmjs.org/@sveltejs/vite-plugin-svelte/-/vite-plugin-svelte-2.0.2.tgz", |       "resolved": "https://registry.npmjs.org/@sveltejs/vite-plugin-svelte/-/vite-plugin-svelte-2.0.2.tgz", | ||||||
|  | @ -13691,6 +13991,27 @@ | ||||||
|       "integrity": "sha512-Nmh0K3iWQJzniTuPRcJn5hxXkfB1T1pgB89SBig5PlJQU5yocazeu4jATJlaA0GYFKWMqDdvYemoSnF2pXgLVA==", |       "integrity": "sha512-Nmh0K3iWQJzniTuPRcJn5hxXkfB1T1pgB89SBig5PlJQU5yocazeu4jATJlaA0GYFKWMqDdvYemoSnF2pXgLVA==", | ||||||
|       "devOptional": true |       "devOptional": true | ||||||
|     }, |     }, | ||||||
|  |     "@types/istanbul-lib-coverage": { | ||||||
|  |       "version": "2.0.4", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", | ||||||
|  |       "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==" | ||||||
|  |     }, | ||||||
|  |     "@types/istanbul-lib-report": { | ||||||
|  |       "version": "3.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", | ||||||
|  |       "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", | ||||||
|  |       "requires": { | ||||||
|  |         "@types/istanbul-lib-coverage": "*" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "@types/istanbul-reports": { | ||||||
|  |       "version": "3.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", | ||||||
|  |       "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", | ||||||
|  |       "requires": { | ||||||
|  |         "@types/istanbul-lib-report": "*" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "@types/json-schema": { |     "@types/json-schema": { | ||||||
|       "version": "7.0.11", |       "version": "7.0.11", | ||||||
|       "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", |       "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", | ||||||
|  | @ -13736,12 +14057,6 @@ | ||||||
|       "integrity": "sha512-j6G1e8DULJx3ONf6NdR5JiR2ZY3K3PaaqiEuKYkLQO0Czfi1AzrtjfnfCROyWGeDd5IVMKCwsgSmMip9OWijow==", |       "integrity": "sha512-j6G1e8DULJx3ONf6NdR5JiR2ZY3K3PaaqiEuKYkLQO0Czfi1AzrtjfnfCROyWGeDd5IVMKCwsgSmMip9OWijow==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "@types/mocha": { |  | ||||||
|       "version": "9.1.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.1.1.tgz", |  | ||||||
|       "integrity": "sha512-Z61JK7DKDtdKTWwLeElSEBcWGRLY8g95ic5FoQqI9CMx0ns/Ghep3B4DfcEimiKMvtamNVULVNKEsiwV3aQmXw==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "@types/node": { |     "@types/node": { | ||||||
|       "version": "18.11.18", |       "version": "18.11.18", | ||||||
|       "resolved": "https://registry.npmjs.org/@types/node/-/node-18.11.18.tgz", |       "resolved": "https://registry.npmjs.org/@types/node/-/node-18.11.18.tgz", | ||||||
|  | @ -13806,6 +14121,19 @@ | ||||||
|         "@types/node": "*" |         "@types/node": "*" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "@types/yargs": { | ||||||
|  |       "version": "17.0.22", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.22.tgz", | ||||||
|  |       "integrity": "sha512-pet5WJ9U8yPVRhkwuEIp5ktAeAqRZOq4UdAyWLWzxbtpyXnzbtLdKiXAjJzi/KLmPGS9wk86lUFWZFN6sISo4g==", | ||||||
|  |       "requires": { | ||||||
|  |         "@types/yargs-parser": "*" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "@types/yargs-parser": { | ||||||
|  |       "version": "21.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", | ||||||
|  |       "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==" | ||||||
|  |     }, | ||||||
|     "@ungap/promise-all-settled": { |     "@ungap/promise-all-settled": { | ||||||
|       "version": "1.1.2", |       "version": "1.1.2", | ||||||
|       "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", |       "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", | ||||||
|  | @ -14415,6 +14743,11 @@ | ||||||
|       "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", |       "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|  |     "ci-info": { | ||||||
|  |       "version": "3.7.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.7.1.tgz", | ||||||
|  |       "integrity": "sha512-4jYS4MOAaCIStSRwiuxc4B8MYhIe676yO1sYGzARnjXkWpmzZMMYxY6zu8WYWDhSuth5zhrQ1rhNSibyyvv4/w==" | ||||||
|  |     }, | ||||||
|     "cli-cursor": { |     "cli-cursor": { | ||||||
|       "version": "3.1.0", |       "version": "3.1.0", | ||||||
|       "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", |       "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", | ||||||
|  | @ -15472,8 +15805,7 @@ | ||||||
|     "graceful-fs": { |     "graceful-fs": { | ||||||
|       "version": "4.2.10", |       "version": "4.2.10", | ||||||
|       "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", |       "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", | ||||||
|       "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", |       "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==" | ||||||
|       "dev": true |  | ||||||
|     }, |     }, | ||||||
|     "growl": { |     "growl": { | ||||||
|       "version": "1.10.5", |       "version": "1.10.5", | ||||||
|  | @ -15933,6 +16265,74 @@ | ||||||
|       "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", |       "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", | ||||||
|       "integrity": "sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==" |       "integrity": "sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==" | ||||||
|     }, |     }, | ||||||
|  |     "jest-mock": { | ||||||
|  |       "version": "29.4.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.4.1.tgz", | ||||||
|  |       "integrity": "sha512-MwA4hQ7zBOcgVCVnsM8TzaFLVUD/pFWTfbkY953Y81L5ret3GFRZtmPmRFAjKQSdCKoJvvqOu6Bvfpqlwwb0dQ==", | ||||||
|  |       "requires": { | ||||||
|  |         "@jest/types": "^29.4.1", | ||||||
|  |         "@types/node": "*", | ||||||
|  |         "jest-util": "^29.4.1" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "jest-util": { | ||||||
|  |       "version": "29.4.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.4.1.tgz", | ||||||
|  |       "integrity": "sha512-bQy9FPGxVutgpN4VRc0hk6w7Hx/m6L53QxpDreTZgJd9gfx/AV2MjyPde9tGyZRINAUrSv57p2inGBu2dRLmkQ==", | ||||||
|  |       "requires": { | ||||||
|  |         "@jest/types": "^29.4.1", | ||||||
|  |         "@types/node": "*", | ||||||
|  |         "chalk": "^4.0.0", | ||||||
|  |         "ci-info": "^3.2.0", | ||||||
|  |         "graceful-fs": "^4.2.9", | ||||||
|  |         "picomatch": "^2.2.3" | ||||||
|  |       }, | ||||||
|  |       "dependencies": { | ||||||
|  |         "ansi-styles": { | ||||||
|  |           "version": "4.3.0", | ||||||
|  |           "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", | ||||||
|  |           "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", | ||||||
|  |           "requires": { | ||||||
|  |             "color-convert": "^2.0.1" | ||||||
|  |           } | ||||||
|  |         }, | ||||||
|  |         "chalk": { | ||||||
|  |           "version": "4.1.2", | ||||||
|  |           "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", | ||||||
|  |           "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", | ||||||
|  |           "requires": { | ||||||
|  |             "ansi-styles": "^4.1.0", | ||||||
|  |             "supports-color": "^7.1.0" | ||||||
|  |           } | ||||||
|  |         }, | ||||||
|  |         "color-convert": { | ||||||
|  |           "version": "2.0.1", | ||||||
|  |           "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", | ||||||
|  |           "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", | ||||||
|  |           "requires": { | ||||||
|  |             "color-name": "~1.1.4" | ||||||
|  |           } | ||||||
|  |         }, | ||||||
|  |         "color-name": { | ||||||
|  |           "version": "1.1.4", | ||||||
|  |           "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", | ||||||
|  |           "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" | ||||||
|  |         }, | ||||||
|  |         "has-flag": { | ||||||
|  |           "version": "4.0.0", | ||||||
|  |           "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", | ||||||
|  |           "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" | ||||||
|  |         }, | ||||||
|  |         "supports-color": { | ||||||
|  |           "version": "7.2.0", | ||||||
|  |           "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", | ||||||
|  |           "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", | ||||||
|  |           "requires": { | ||||||
|  |             "has-flag": "^4.0.0" | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "jose": { |     "jose": { | ||||||
|       "version": "4.11.2", |       "version": "4.11.2", | ||||||
|       "resolved": "https://registry.npmjs.org/jose/-/jose-4.11.2.tgz", |       "resolved": "https://registry.npmjs.org/jose/-/jose-4.11.2.tgz", | ||||||
|  |  | ||||||
|  | @ -14,7 +14,7 @@ | ||||||
|     "watch:css": "tailwindcss -i index.css -o css/index-tailwind-output.css --watch", |     "watch:css": "tailwindcss -i index.css -o css/index-tailwind-output.css --watch", | ||||||
|     "generate:css": "tailwindcss -i index.css -o css/index-tailwind-output.css", |     "generate:css": "tailwindcss -i index.css -o css/index-tailwind-output.css", | ||||||
|     "generate:doctests": "doctest-ts-improved . --ignore .*.spec.ts --ignore .*ConfigJson.ts", |     "generate:doctests": "doctest-ts-improved . --ignore .*.spec.ts --ignore .*ConfigJson.ts", | ||||||
|     "test:run-only": "mocha  --require test/testhooks.ts \"./**/*.doctest.ts\" \"test/*\" \"test/**/*.ts\"", |     "test:run-only": "vitest  --require test/testhooks.ts \"./**/*.doctest.ts\" \"test/*\" \"test/**/*.ts\"", | ||||||
|     "test": "(npm run generate:doctests 2>&1 | grep -v \"No doctests found in\") && npm run test:run-only && npm run clean:tests", |     "test": "(npm run generate:doctests 2>&1 | grep -v \"No doctests found in\") && npm run test:run-only && npm run clean:tests", | ||||||
|     "init": "npm ci && npm run generate && npm run generate:editor-layer-index && npm run generate:layouts && npm run clean", |     "init": "npm ci && npm run generate && npm run generate:editor-layer-index && npm run generate:layouts && npm run clean", | ||||||
|     "generate:editor-layer-index": "vite-node scripts/downloadFile.ts -- https://osmlab.github.io/editor-layer-index/imagery.geojson assets/editor-layer-index.json", |     "generate:editor-layer-index": "vite-node scripts/downloadFile.ts -- https://osmlab.github.io/editor-layer-index/imagery.geojson assets/editor-layer-index.json", | ||||||
|  | @ -82,6 +82,7 @@ | ||||||
|     "geojson2svg": "^1.3.1", |     "geojson2svg": "^1.3.1", | ||||||
|     "i18next-client": "^1.11.4", |     "i18next-client": "^1.11.4", | ||||||
|     "idb-keyval": "^6.0.3", |     "idb-keyval": "^6.0.3", | ||||||
|  |     "jest-mock": "^29.4.1", | ||||||
|     "jspdf": "^2.5.1", |     "jspdf": "^2.5.1", | ||||||
|     "latlon2country": "^1.2.6", |     "latlon2country": "^1.2.6", | ||||||
|     "leaflet": "^1.9.2", |     "leaflet": "^1.9.2", | ||||||
|  | @ -119,7 +120,6 @@ | ||||||
|     "@types/leaflet-markercluster": "^1.0.3", |     "@types/leaflet-markercluster": "^1.0.3", | ||||||
|     "@types/leaflet-providers": "^1.2.0", |     "@types/leaflet-providers": "^1.2.0", | ||||||
|     "@types/lz-string": "^1.3.34", |     "@types/lz-string": "^1.3.34", | ||||||
|     "@types/mocha": "^9.1.0", |  | ||||||
|     "@types/node": "^18.11.18", |     "@types/node": "^18.11.18", | ||||||
|     "@types/papaparse": "^5.3.1", |     "@types/papaparse": "^5.3.1", | ||||||
|     "@types/prompt-sync": "^4.1.0", |     "@types/prompt-sync": "^4.1.0", | ||||||
|  | @ -129,7 +129,6 @@ | ||||||
|     "chai": "^4.3.6", |     "chai": "^4.3.6", | ||||||
|     "dependency-cruiser": "^10.4.0", |     "dependency-cruiser": "^10.4.0", | ||||||
|     "fs": "0.0.1-security", |     "fs": "0.0.1-security", | ||||||
|     "mocha": "^9.2.2", |  | ||||||
|     "prettier": "^2.7.1", |     "prettier": "^2.7.1", | ||||||
|     "prettier-plugin-svelte": "^2.9.0", |     "prettier-plugin-svelte": "^2.9.0", | ||||||
|     "read-file": "^0.2.0", |     "read-file": "^0.2.0", | ||||||
|  |  | ||||||
|  | @ -1,5 +1,5 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { exec } from "child_process" | import { exec } from "child_process" | ||||||
|  | import { describe, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * |  * | ||||||
|  |  | ||||||
|  | @ -1,4 +1,3 @@ | ||||||
| import { expect } from "chai" |  | ||||||
| import { Utils } from "../../../Utils" | import { Utils } from "../../../Utils" | ||||||
| import UserRelatedState from "../../../Logic/State/UserRelatedState" | import UserRelatedState from "../../../Logic/State/UserRelatedState" | ||||||
| import LayoutConfig from "../../../Models/ThemeConfig/LayoutConfig" | import LayoutConfig from "../../../Models/ThemeConfig/LayoutConfig" | ||||||
|  | @ -11,6 +10,7 @@ import SelectedFeatureHandler from "../../../Logic/Actors/SelectedFeatureHandler | ||||||
| import { ElementStorage } from "../../../Logic/ElementStorage" | import { ElementStorage } from "../../../Logic/ElementStorage" | ||||||
| import { OsmTags } from "../../../Models/OsmFeature" | import { OsmTags } from "../../../Models/OsmFeature" | ||||||
| import { Feature, Geometry } from "geojson" | import { Feature, Geometry } from "geojson" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| const latestTags = { | const latestTags = { | ||||||
|     amenity: "public_bookcase", |     amenity: "public_bookcase", | ||||||
|  | @ -83,9 +83,9 @@ it("should download the latest version", () => { | ||||||
|     SelectedElementTagsUpdater.applyUpdate(state, latestTags, feature.properties.id) |     SelectedElementTagsUpdater.applyUpdate(state, latestTags, feature.properties.id) | ||||||
| 
 | 
 | ||||||
|     // The name should be updated
 |     // The name should be updated
 | ||||||
|     expect(feature.properties.name).deep.equal("Stubbekwartier-buurtbibliotheek") |     expect(feature.properties.name).toEqual("Stubbekwartier-buurtbibliotheek") | ||||||
|     // The fixme should be removed
 |     // The fixme should be removed
 | ||||||
|     expect(feature.properties.fixme).deep.equal(undefined) |     expect(feature.properties.fixme).toBeUndefined() | ||||||
| }) | }) | ||||||
| it("Hash without selected element should download geojson from OSM-API", async () => { | it("Hash without selected element should download geojson from OSM-API", async () => { | ||||||
|     const hash = new UIEventSource("node/5568693115") |     const hash = new UIEventSource("node/5568693115") | ||||||
|  | @ -97,9 +97,9 @@ it("Hash without selected element should download geojson from OSM-API", async ( | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     loc.addCallback((_) => { |     loc.addCallback((_) => { | ||||||
|         expect(selected.data.properties.id).deep.equal("node/5568693115") |         expect(selected.data.properties.id).toEqual("node/5568693115") | ||||||
|         expect(loc.data.zoom).deep.equal(14) |         expect(loc.data.zoom).toEqual(14) | ||||||
|         expect(loc.data.lat).deep.equal(51.2179199) |         expect(loc.data.lat).toEqual(51.2179199) | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     new SelectedFeatureHandler(hash, { |     new SelectedFeatureHandler(hash, { | ||||||
|  |  | ||||||
|  | @ -1,8 +1,7 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import CreateMultiPolygonWithPointReuseAction from "../../../Logic/Osm/Actions/CreateMultiPolygonWithPointReuseAction" | import CreateMultiPolygonWithPointReuseAction from "../../../Logic/Osm/Actions/CreateMultiPolygonWithPointReuseAction" | ||||||
| import { Tag } from "../../../Logic/Tags/Tag" | import { Tag } from "../../../Logic/Tags/Tag" | ||||||
| import { Changes } from "../../../Logic/Osm/Changes" | import { Changes } from "../../../Logic/Osm/Changes" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("CreateMultiPolygonWithPointReuseAction", () => { | describe("CreateMultiPolygonWithPointReuseAction", () => { | ||||||
|     it("should produce a correct changeset", () => { |     it("should produce a correct changeset", () => { | ||||||
|  | @ -106,21 +105,29 @@ describe("CreateMultiPolygonWithPointReuseAction", () => { | ||||||
|             const descriptions = await action.Perform(new Changes()) |             const descriptions = await action.Perform(new Changes()) | ||||||
| 
 | 
 | ||||||
|             const ways = descriptions.filter((d) => d.type === "way") |             const ways = descriptions.filter((d) => d.type === "way") | ||||||
|             expect(ways[0].id == -18, "unexpected id").true |             // "unexpected id"
 | ||||||
|             expect(ways[1].id == -27, "unexpected id").true |             expect(ways[0].id == -18).toBe(true) | ||||||
|  |             // "unexpected id"
 | ||||||
|  |             expect(ways[1].id == -27).toBe(true) | ||||||
|             const outer = ways[0].changes["coordinates"] |             const outer = ways[0].changes["coordinates"] | ||||||
|             expect(outer).deep.equal(feature.geometry.coordinates[0]) |             expect(outer).toEqual(feature.geometry.coordinates[0]) | ||||||
|             const inner = ways[1].changes["coordinates"] |             const inner = ways[1].changes["coordinates"] | ||||||
|             expect(inner).deep.equal(feature.geometry.coordinates[1]) |             expect(inner).toEqual(feature.geometry.coordinates[1]) | ||||||
|             const members = <{ type: string; role: string; ref: number }[]>( |             const members = <{ type: string; role: string; ref: number }[]>( | ||||||
|                 descriptions.find((d) => d.type === "relation").changes["members"] |                 descriptions.find((d) => d.type === "relation").changes["members"] | ||||||
|             ) |             ) | ||||||
|             expect(members[0].role, "incorrect role").eq("outer") |             // "incorrect role"
 | ||||||
|             expect(members[1].role, "incorrect role").eq("inner") |             expect(members[0].role).toBe("outer") | ||||||
|             expect(members[0].type, "incorrect type").eq("way") |             // "incorrect role"
 | ||||||
|             expect(members[1].type, "incorrect type").eq("way") |             expect(members[1].role).toBe("inner") | ||||||
|             expect(members[0].ref, "incorrect id").eq(-18) |             // "incorrect type"
 | ||||||
|             expect(members[1].ref, "incorrect id").eq(-27) |             expect(members[0].type).toBe("way") | ||||||
|  |             // "incorrect type"
 | ||||||
|  |             expect(members[1].type).toBe("way") | ||||||
|  |             // "incorrect id"
 | ||||||
|  |             expect(members[0].ref).toBe(-18) | ||||||
|  |             // "incorrect id"
 | ||||||
|  |             expect(members[1].ref).toBe(-27) | ||||||
|         } |         } | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { ExtraFuncParams, ExtraFunctions } from "../../Logic/ExtraFunctions" | import { ExtraFuncParams, ExtraFunctions } from "../../Logic/ExtraFunctions" | ||||||
| import { OsmFeature } from "../../Models/OsmFeature" | import { OsmFeature } from "../../Models/OsmFeature" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("OverlapFunc", () => { | describe("OverlapFunc", () => { | ||||||
|     it("should give doors on the edge", () => { |     it("should give doors on the edge", () => { | ||||||
|  | @ -122,6 +121,6 @@ describe("OverlapFunc", () => { | ||||||
|         ExtraFunctions.FullPatchFeature(params, hermanTeirlinck) |         ExtraFunctions.FullPatchFeature(params, hermanTeirlinck) | ||||||
|         const overlap = (<any>hermanTeirlinck).overlapWith("*") |         const overlap = (<any>hermanTeirlinck).overlapWith("*") | ||||||
|         console.log(JSON.stringify(overlap)) |         console.log(JSON.stringify(overlap)) | ||||||
|         expect(overlap[0].feat == door).true |         expect(overlap[0].feat == door).toBe(true) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,4 +1,3 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import OsmFeatureSource from "../../../Logic/FeatureSource/TiledFeatureSource/OsmFeatureSource" | import OsmFeatureSource from "../../../Logic/FeatureSource/TiledFeatureSource/OsmFeatureSource" | ||||||
| import { UIEventSource } from "../../../Logic/UIEventSource" | import { UIEventSource } from "../../../Logic/UIEventSource" | ||||||
| import ScriptUtils from "../../../scripts/ScriptUtils" | import ScriptUtils from "../../../scripts/ScriptUtils" | ||||||
|  | @ -8,7 +7,7 @@ import { readFileSync } from "fs" | ||||||
| import { Utils } from "../../../Utils" | import { Utils } from "../../../Utils" | ||||||
| import { Tag } from "../../../Logic/Tags/Tag" | import { Tag } from "../../../Logic/Tags/Tag" | ||||||
| import LayerConfig from "../../../Models/ThemeConfig/LayerConfig" | import LayerConfig from "../../../Models/ThemeConfig/LayerConfig" | ||||||
| import { expect } from "chai" | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| const expected = { | const expected = { | ||||||
|     type: "Feature", |     type: "Feature", | ||||||
|  | @ -92,7 +91,7 @@ function test(done: () => void) { | ||||||
|         handleTile: (tile) => { |         handleTile: (tile) => { | ||||||
|             fetchedTile = tile |             fetchedTile = tile | ||||||
|             const data = tile.features.data[0].feature |             const data = tile.features.data[0].feature | ||||||
|             expect(data.properties).deep.eq({ |             expect(data.properties).toEqual({ | ||||||
|                 id: "relation/5759328", |                 id: "relation/5759328", | ||||||
|                 timestamp: "2022-06-10T00:46:55Z", |                 timestamp: "2022-06-10T00:46:55Z", | ||||||
|                 version: 6, |                 version: 6, | ||||||
|  | @ -107,8 +106,8 @@ function test(done: () => void) { | ||||||
|                 website: "http://ktahalle.be/", |                 website: "http://ktahalle.be/", | ||||||
|                 _backend: "https://osm.org", |                 _backend: "https://osm.org", | ||||||
|             }) |             }) | ||||||
|             expect(data.geometry.type).eq("MultiPolygon") |             expect(data.geometry.type).toBe("MultiPolygon") | ||||||
|             expect(data).deep.eq(expected) |             expect(data).toEqual(expected) | ||||||
|             done() |             done() | ||||||
|         }, |         }, | ||||||
|         isActive: new UIEventSource<boolean>(true), |         isActive: new UIEventSource<boolean>(true), | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import TileFreshnessCalculator from "../../../Logic/FeatureSource/TileFreshnessCalculator" | import TileFreshnessCalculator from "../../../Logic/FeatureSource/TileFreshnessCalculator" | ||||||
| import { Tiles } from "../../../Models/TileRange" | import { Tiles } from "../../../Models/TileRange" | ||||||
| import { expect } from "chai" | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("TileFreshnessCalculator", () => { | describe("TileFreshnessCalculator", () => { | ||||||
|     it("should get the freshness for loaded tiles", () => { |     it("should get the freshness for loaded tiles", () => { | ||||||
|  | @ -11,13 +10,13 @@ describe("TileFreshnessCalculator", () => { | ||||||
|         date.setTime(42) |         date.setTime(42) | ||||||
|         calc.addTileLoad(Tiles.tile_index(19, 266406, 175534), date) |         calc.addTileLoad(Tiles.tile_index(19, 266406, 175534), date) | ||||||
| 
 | 
 | ||||||
|         expect(calc.freshnessFor(19, 266406, 175534).getTime()).eq(42) |         expect(calc.freshnessFor(19, 266406, 175534).getTime()).toBe(42) | ||||||
|         expect(calc.freshnessFor(20, 266406 * 2, 175534 * 2 + 1).getTime()).eq(42) |         expect(calc.freshnessFor(20, 266406 * 2, 175534 * 2 + 1).getTime()).toBe(42) | ||||||
|         expect(calc.freshnessFor(19, 266406, 175535)).undefined |         expect(calc.freshnessFor(19, 266406, 175535)).toBeUndefined() | ||||||
|         expect(calc.freshnessFor(18, 266406 / 2, 175534 / 2)).undefined |         expect(calc.freshnessFor(18, 266406 / 2, 175534 / 2)).toBeUndefined() | ||||||
|         calc.addTileLoad(Tiles.tile_index(19, 266406, 175534 + 1), date) |         calc.addTileLoad(Tiles.tile_index(19, 266406, 175534 + 1), date) | ||||||
|         calc.addTileLoad(Tiles.tile_index(19, 266406 + 1, 175534), date) |         calc.addTileLoad(Tiles.tile_index(19, 266406 + 1, 175534), date) | ||||||
|         calc.addTileLoad(Tiles.tile_index(19, 266406 + 1, 175534 + 1), date) |         calc.addTileLoad(Tiles.tile_index(19, 266406 + 1, 175534 + 1), date) | ||||||
|         expect(calc.freshnessFor(18, 266406 / 2, 175534 / 2).getTime()).eq(42) |         expect(calc.freshnessFor(18, 266406 / 2, 175534 / 2).getTime()).toBe(42) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import * as turf from "@turf/turf" | import * as turf from "@turf/turf" | ||||||
| import { GeoOperations } from "../../Logic/GeoOperations" | import { GeoOperations } from "../../Logic/GeoOperations" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("GeoOperations", () => { | describe("GeoOperations", () => { | ||||||
|     describe("calculateOverlap", () => { |     describe("calculateOverlap", () => { | ||||||
|  | @ -123,9 +122,9 @@ describe("GeoOperations", () => { | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             const p0 = turf.polygon(polyGrb.geometry.coordinates) |             const p0 = turf.polygon(polyGrb.geometry.coordinates) | ||||||
|             expect(p0).not.null |             expect(p0).not.toBeNull() | ||||||
|             const p1 = turf.polygon(polyHouse.geometry.coordinates) |             const p1 = turf.polygon(polyHouse.geometry.coordinates) | ||||||
|             expect(p1).not.null |             expect(p1).not.toBeNull() | ||||||
| 
 | 
 | ||||||
|             const overlaps = GeoOperations.calculateOverlap(polyGrb, [polyHouse]) |             const overlaps = GeoOperations.calculateOverlap(polyGrb, [polyHouse]) | ||||||
|             expect(overlaps).empty |             expect(overlaps).empty | ||||||
|  |  | ||||||
|  | @ -1,8 +1,7 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import AllImageProviders from "../../../Logic/ImageProviders/AllImageProviders" | import AllImageProviders from "../../../Logic/ImageProviders/AllImageProviders" | ||||||
| import { UIEventSource } from "../../../Logic/UIEventSource" | import { UIEventSource } from "../../../Logic/UIEventSource" | ||||||
| import { Utils } from "../../../Utils" | import { Utils } from "../../../Utils" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("ImageProviders", () => { | describe("ImageProviders", () => { | ||||||
|     it("should work on a variaty of inputs", () => { |     it("should work on a variaty of inputs", () => { | ||||||
|  | @ -16,9 +15,9 @@ describe("ImageProviders", () => { | ||||||
|                 if (img === undefined) { |                 if (img === undefined) { | ||||||
|                     throw "No image found" |                     throw "No image found" | ||||||
|                 } |                 } | ||||||
|                 expect(img.url).deep.equal(url) |                 expect(img.url).toEqual(url) | ||||||
|                 if (providerName) { |                 if (providerName) { | ||||||
|                     expect(providerName).deep.equal(img.provider.constructor.name) |                     expect(providerName).toEqual(img.provider.constructor.name) | ||||||
|                 } |                 } | ||||||
|                 console.log("OK") |                 console.log("OK") | ||||||
|             }) |             }) | ||||||
|  |  | ||||||
|  | @ -1,5 +1,3 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { Utils } from "../../../../Utils" | import { Utils } from "../../../../Utils" | ||||||
| import { OsmObject, OsmRelation } from "../../../../Logic/Osm/OsmObject" | import { OsmObject, OsmRelation } from "../../../../Logic/Osm/OsmObject" | ||||||
| import { | import { | ||||||
|  | @ -7,6 +5,7 @@ import { | ||||||
|     TurnRestrictionRSH, |     TurnRestrictionRSH, | ||||||
| } from "../../../../Logic/Osm/Actions/RelationSplitHandler" | } from "../../../../Logic/Osm/Actions/RelationSplitHandler" | ||||||
| import { Changes } from "../../../../Logic/Osm/Changes" | import { Changes } from "../../../../Logic/Osm/Changes" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("RelationSplitHandler", () => { | describe("RelationSplitHandler", () => { | ||||||
|     Utils.injectJsonDownloadForTests("https://www.openstreetmap.org/api/0.6/node/1124134958/ways", { |     Utils.injectJsonDownloadForTests("https://www.openstreetmap.org/api/0.6/node/1124134958/ways", { | ||||||
|  | @ -651,10 +650,8 @@ describe("RelationSplitHandler", () => { | ||||||
|         const changeDescription = await splitter.CreateChangeDescriptions(new Changes()) |         const changeDescription = await splitter.CreateChangeDescriptions(new Changes()) | ||||||
|         const allIds = changeDescription[0].changes["members"].map((m) => m.ref).join(",") |         const allIds = changeDescription[0].changes["members"].map((m) => m.ref).join(",") | ||||||
|         const expected = "687866206,295132739,-1,690497698" |         const expected = "687866206,295132739,-1,690497698" | ||||||
|         expect( |         // "didn't find the expected order of ids in the relation to test"
 | ||||||
|             allIds.indexOf(expected) >= 0, |         expect(allIds.indexOf(expected) >= 0).toBe(true) | ||||||
|             "didn't find the expected order of ids in the relation to test" |  | ||||||
|         ).true |  | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     it("should split turn restrictions (split of https://www.openstreetmap.org/way/143298912)", async () => { |     it("should split turn restrictions (split of https://www.openstreetmap.org/way/143298912)", async () => { | ||||||
|  | @ -705,7 +702,7 @@ describe("RelationSplitHandler", () => { | ||||||
|             .map((m) => m.type + "/" + m.ref + "-->" + m.role) |             .map((m) => m.type + "/" + m.ref + "-->" + m.role) | ||||||
|             .join(",") |             .join(",") | ||||||
|         const expected = "way/318616190-->from,node/1407529979-->via,way/-1-->to" |         const expected = "way/318616190-->from,node/1407529979-->via,way/-1-->to" | ||||||
|         expect(allIds).deep.equal(expected) |         expect(allIds).toEqual(expected) | ||||||
| 
 | 
 | ||||||
|         // Reversing the ids has no effect
 |         // Reversing the ids has no effect
 | ||||||
|         const splitterReverse = new TurnRestrictionRSH( |         const splitterReverse = new TurnRestrictionRSH( | ||||||
|  | @ -719,6 +716,6 @@ describe("RelationSplitHandler", () => { | ||||||
|             "no-theme" |             "no-theme" | ||||||
|         ) |         ) | ||||||
|         const changesReverse = await splitterReverse.CreateChangeDescriptions(new Changes()) |         const changesReverse = await splitterReverse.CreateChangeDescriptions(new Changes()) | ||||||
|         expect(changesReverse.length).deep.equal(0) |         expect(changesReverse.length).toEqual(0) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,13 +1,11 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import Minimap from "../../../../UI/Base/Minimap" | import Minimap from "../../../../UI/Base/Minimap" | ||||||
| import { Utils } from "../../../../Utils" | import { Utils } from "../../../../Utils" | ||||||
| import LayoutConfig from "../../../../Models/ThemeConfig/LayoutConfig" | import LayoutConfig from "../../../../Models/ThemeConfig/LayoutConfig" | ||||||
| import State from "../../../../State" | import State from "../../../../State" | ||||||
| import { BBox } from "../../../../Logic/BBox" | import { BBox } from "../../../../Logic/BBox" | ||||||
| import ReplaceGeometryAction from "../../../../Logic/Osm/Actions/ReplaceGeometryAction" | import ReplaceGeometryAction from "../../../../Logic/Osm/Actions/ReplaceGeometryAction" | ||||||
| import ShowDataLayerImplementation from "../../../../UI/ShowDataLayer/ShowDataLayerImplementation" |  | ||||||
| import ShowDataLayer from "../../../../UI/ShowDataLayer/ShowDataLayer" | import ShowDataLayer from "../../../../UI/ShowDataLayer/ShowDataLayer" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("ReplaceGeometryAction", () => { | describe("ReplaceGeometryAction", () => { | ||||||
|     const grbStripped = { |     const grbStripped = { | ||||||
|  | @ -896,7 +894,7 @@ describe("ReplaceGeometryAction", () => { | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         const closestIds = await action.GetClosestIds() |         const closestIds = await action.GetClosestIds() | ||||||
|         expect(closestIds.closestIds).deep.equal([ |         expect(closestIds.closestIds).toEqual([ | ||||||
|             9219979643, |             9219979643, | ||||||
|             1728823481, |             1728823481, | ||||||
|             4978289383, |             4978289383, | ||||||
|  | @ -910,14 +908,14 @@ describe("ReplaceGeometryAction", () => { | ||||||
|             undefined, |             undefined, | ||||||
|         ]) |         ]) | ||||||
| 
 | 
 | ||||||
|         expect(closestIds.reprojectedNodes.size).deep.equal(1) |         expect(closestIds.reprojectedNodes.size).toEqual(1) | ||||||
|         const reproj = closestIds.reprojectedNodes.get(1728823549) |         const reproj = closestIds.reprojectedNodes.get(1728823549) | ||||||
|         expect(reproj.projectAfterIndex).deep.equal(1) |         expect(reproj.projectAfterIndex).toEqual(1) | ||||||
|         expect(reproj.newLon).deep.equal(3.2168880864669203) |         expect(reproj.newLon).toEqual(3.2168880864669203) | ||||||
|         expect(reproj.newLat).deep.equal(51.214739524104694) |         expect(reproj.newLat).toEqual(51.214739524104694) | ||||||
|         expect(closestIds.detachedNodes.size).deep.equal(0) |         expect(closestIds.detachedNodes.size).toEqual(0) | ||||||
|         const changes = await action.Perform(state.changes) |         const changes = await action.Perform(state.changes) | ||||||
|         expect(changes[11].changes["coordinates"]).deep.equal([ |         expect(changes[11].changes["coordinates"]).toEqual([ | ||||||
|             [3.216690793633461, 51.21474084112525], |             [3.216690793633461, 51.21474084112525], | ||||||
|             [3.2167256623506546, 51.214696737309964], |             [3.2167256623506546, 51.214696737309964], | ||||||
|             [3.2168880864669203, 51.214739524104694], |             [3.2168880864669203, 51.214739524104694], | ||||||
|  |  | ||||||
|  | @ -1,8 +1,7 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { Utils } from "../../../../Utils" | import { Utils } from "../../../../Utils" | ||||||
| import SplitAction from "../../../../Logic/Osm/Actions/SplitAction" | import SplitAction from "../../../../Logic/Osm/Actions/SplitAction" | ||||||
| import { Changes } from "../../../../Logic/Osm/Changes" | import { Changes } from "../../../../Logic/Osm/Changes" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("SplitAction", () => { | describe("SplitAction", () => { | ||||||
|     { |     { | ||||||
|  | @ -2690,20 +2689,20 @@ describe("SplitAction", () => { | ||||||
|         }) |         }) | ||||||
|         const changeDescription = await splitter.CreateChangeDescriptions(new Changes()) |         const changeDescription = await splitter.CreateChangeDescriptions(new Changes()) | ||||||
| 
 | 
 | ||||||
|         expect(changeDescription[0].type).eq("node") |         expect(changeDescription[0].type).toBe("node") | ||||||
|         expect(changeDescription[0].id).eq(-1) |         expect(changeDescription[0].id).toBe(-1) | ||||||
|         expect(changeDescription[0].changes["lat"]).eq(51.181710380278176) |         expect(changeDescription[0].changes["lat"]).toBe(51.181710380278176) | ||||||
|         expect(changeDescription[0].changes["lon"]).eq(3.246733546257019) |         expect(changeDescription[0].changes["lon"]).toBe(3.246733546257019) | ||||||
|         expect(changeDescription[1].type).eq("way") |         expect(changeDescription[1].type).toBe("way") | ||||||
|         expect(changeDescription[1].id).eq(-2) |         expect(changeDescription[1].id).toBe(-2) | ||||||
|         expect(changeDescription[1].changes["coordinates"].length).eq(6) |         expect(changeDescription[1].changes["coordinates"].length).toBe(6) | ||||||
|         expect(changeDescription[1].changes["coordinates"][5][0]).eq(splitPoint[0]) |         expect(changeDescription[1].changes["coordinates"][5][0]).toBe(splitPoint[0]) | ||||||
|         expect(changeDescription[1].changes["coordinates"][5][1]).eq(splitPoint[1]) |         expect(changeDescription[1].changes["coordinates"][5][1]).toBe(splitPoint[1]) | ||||||
|         expect(changeDescription[2].type).eq("way") |         expect(changeDescription[2].type).toBe("way") | ||||||
|         expect(changeDescription[2].id).eq(295132739) |         expect(changeDescription[2].id).toBe(295132739) | ||||||
|         expect(changeDescription[2].changes["coordinates"].length).eq(10) |         expect(changeDescription[2].changes["coordinates"].length).toBe(10) | ||||||
|         expect(changeDescription[2].changes["coordinates"][0][0]).eq(splitPoint[0]) |         expect(changeDescription[2].changes["coordinates"][0][0]).toBe(splitPoint[0]) | ||||||
|         expect(changeDescription[2].changes["coordinates"][0][1]).eq(splitPoint[1]) |         expect(changeDescription[2].changes["coordinates"][0][1]).toBe(splitPoint[1]) | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     it("split 295132739 on already existing node", async () => { |     it("split 295132739 on already existing node", async () => { | ||||||
|  | @ -2715,13 +2714,13 @@ describe("SplitAction", () => { | ||||||
|         }) |         }) | ||||||
|         const changeDescription = await splitter.CreateChangeDescriptions(new Changes()) |         const changeDescription = await splitter.CreateChangeDescriptions(new Changes()) | ||||||
| 
 | 
 | ||||||
|         expect(changeDescription.length).eq(2) |         expect(changeDescription.length).toBe(2) | ||||||
|         expect(changeDescription[0].type).eq("way") |         expect(changeDescription[0].type).toBe("way") | ||||||
|         expect(changeDescription[1].type).eq("way") |         expect(changeDescription[1].type).toBe("way") | ||||||
|         expect( |         expect( | ||||||
|             changeDescription[0].changes["nodes"][changeDescription[0].changes["nodes"].length - 1] |             changeDescription[0].changes["nodes"][changeDescription[0].changes["nodes"].length - 1] | ||||||
|         ).eq(changeDescription[1].changes["nodes"][0]) |         ).toBe(changeDescription[1].changes["nodes"][0]) | ||||||
|         expect(changeDescription[1].changes["nodes"][0]).eq(1507524610) |         expect(changeDescription[1].changes["nodes"][0]).toBe(1507524610) | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     it("split 61435323 on already existing node", async () => { |     it("split 61435323 on already existing node", async () => { | ||||||
|  | @ -2733,8 +2732,8 @@ describe("SplitAction", () => { | ||||||
|         const changeDescription = await splitter.CreateChangeDescriptions(new Changes()) |         const changeDescription = await splitter.CreateChangeDescriptions(new Changes()) | ||||||
| 
 | 
 | ||||||
|         // Should be a new node
 |         // Should be a new node
 | ||||||
|         expect(changeDescription[0].type).eq("node") |         expect(changeDescription[0].type).toBe("node") | ||||||
|         expect(changeDescription[3].type).eq("relation") |         expect(changeDescription[3].type).toBe("relation") | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     it("Split test line", async () => { |     it("Split test line", async () => { | ||||||
|  | @ -2764,11 +2763,11 @@ describe("SplitAction", () => { | ||||||
|                 8715440363 |                 8715440363 | ||||||
|              */ |              */ | ||||||
| 
 | 
 | ||||||
|         expect(changes[0].changes["nodes"]).deep.equal([ |         expect(changes[0].changes["nodes"]).toEqual([ | ||||||
|             6490126559, 8715440375, 8715440374, 8715440373, 8715440372, 8715440371, 8715440370, |             6490126559, 8715440375, 8715440374, 8715440373, 8715440372, 8715440371, 8715440370, | ||||||
|             8715440369, 8715440368, |             8715440369, 8715440368, | ||||||
|         ]) |         ]) | ||||||
|         expect(changes[1].changes["nodes"]).deep.equal([ |         expect(changes[1].changes["nodes"]).toEqual([ | ||||||
|             8715440368, 8715440367, 8715440366, 8715440365, 8715440364, 8715440363, |             8715440368, 8715440367, 8715440366, 8715440365, 8715440364, 8715440363, | ||||||
|         ]) |         ]) | ||||||
|     }) |     }) | ||||||
|  | @ -2784,14 +2783,14 @@ describe("SplitAction", () => { | ||||||
|         const changes = await splitAction.Perform(new Changes()) |         const changes = await splitAction.Perform(new Changes()) | ||||||
| 
 | 
 | ||||||
|         // THe first change is the creation of the new node
 |         // THe first change is the creation of the new node
 | ||||||
|         expect(changes[0].type).deep.equal("node") |         expect(changes[0].type).toEqual("node") | ||||||
|         expect(changes[0].id).deep.equal(-1) |         expect(changes[0].id).toEqual(-1) | ||||||
| 
 | 
 | ||||||
|         expect(changes[1].changes["nodes"]).deep.equal([ |         expect(changes[1].changes["nodes"]).toEqual([ | ||||||
|             6490126559, 8715440375, 8715440374, 8715440373, 8715440372, 8715440371, 8715440370, |             6490126559, 8715440375, 8715440374, 8715440373, 8715440372, 8715440371, 8715440370, | ||||||
|             8715440369, -1, |             8715440369, -1, | ||||||
|         ]) |         ]) | ||||||
|         expect(changes[2].changes["nodes"]).deep.equal([ |         expect(changes[2].changes["nodes"]).toEqual([ | ||||||
|             -1, 8715440368, 8715440367, 8715440366, 8715440365, 8715440364, 8715440363, |             -1, 8715440368, 8715440367, 8715440366, 8715440365, 8715440364, 8715440363, | ||||||
|         ]) |         ]) | ||||||
|     }) |     }) | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| import { expect } from "chai" |  | ||||||
| import { ChangeDescription } from "../../../Logic/Osm/Actions/ChangeDescription" | import { ChangeDescription } from "../../../Logic/Osm/Actions/ChangeDescription" | ||||||
| import { Changes } from "../../../Logic/Osm/Changes" | import { Changes } from "../../../Logic/Osm/Changes" | ||||||
|  | import { expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| it("Generate preXML from changeDescriptions", () => { | it("Generate preXML from changeDescriptions", () => { | ||||||
|     const changeDescrs: ChangeDescription[] = [ |     const changeDescrs: ChangeDescription[] = [ | ||||||
|  | @ -29,11 +29,11 @@ it("Generate preXML from changeDescriptions", () => { | ||||||
|     ] |     ] | ||||||
|     const c = new Changes() |     const c = new Changes() | ||||||
|     const descr = c.CreateChangesetObjects(changeDescrs, []) |     const descr = c.CreateChangesetObjects(changeDescrs, []) | ||||||
|     expect(descr.modifiedObjects).length(0) |     expect(descr.modifiedObjects).toHaveLength(0) | ||||||
|     expect(descr.deletedObjects).length(0) |     expect(descr.deletedObjects).toHaveLength(0) | ||||||
|     expect(descr.newObjects).length(1) |     expect(descr.newObjects).toHaveLength(1) | ||||||
| 
 | 
 | ||||||
|     const ch = descr.newObjects[0] |     const ch = descr.newObjects[0] | ||||||
|     expect(ch.tags["foo"]).eq("bar") |     expect(ch.tags["foo"]).toBe("bar") | ||||||
|     expect(ch.tags["someKey"]).eq("someValue") |     expect(ch.tags["someKey"]).toBe("someValue") | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,11 +1,10 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { Utils } from "../../../Utils" | import { Utils } from "../../../Utils" | ||||||
| import { ChangesetHandler, ChangesetTag } from "../../../Logic/Osm/ChangesetHandler" | import { ChangesetHandler, ChangesetTag } from "../../../Logic/Osm/ChangesetHandler" | ||||||
| import { UIEventSource } from "../../../Logic/UIEventSource" | import { UIEventSource } from "../../../Logic/UIEventSource" | ||||||
| import { OsmConnection } from "../../../Logic/Osm/OsmConnection" | import { OsmConnection } from "../../../Logic/Osm/OsmConnection" | ||||||
| import { ElementStorage } from "../../../Logic/ElementStorage" | import { ElementStorage } from "../../../Logic/ElementStorage" | ||||||
| import { Changes } from "../../../Logic/Osm/Changes" | import { Changes } from "../../../Logic/Osm/Changes" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("ChangesetHanlder", () => { | describe("ChangesetHanlder", () => { | ||||||
|     describe("RewriteTagsOf", () => { |     describe("RewriteTagsOf", () => { | ||||||
|  | @ -56,18 +55,16 @@ describe("ChangesetHanlder", () => { | ||||||
|                 oldChangesetMeta |                 oldChangesetMeta | ||||||
|             ) |             ) | ||||||
|             const d = Utils.asDict(rewritten) |             const d = Utils.asDict(rewritten) | ||||||
|             expect(d.size).deep.equal(10) |             expect(d.size).toEqual(10) | ||||||
|             expect(d.get("answer")).deep.equal("5") |             expect(d.get("answer")).toEqual("5") | ||||||
|             expect(d.get("comment")).deep.equal( |             expect(d.get("comment")).toEqual("Adding data with #MapComplete for theme #toerisme_vlaanderen") | ||||||
|                 "Adding data with #MapComplete for theme #toerisme_vlaanderen" |             expect(d.get("created_by")).toEqual("MapComplete 0.16.6") | ||||||
|             ) |             expect(d.get("host")).toEqual("https://mapcomplete.osm.be/toerisme_vlaanderen.html") | ||||||
|             expect(d.get("created_by")).deep.equal("MapComplete 0.16.6") |             expect(d.get("imagery")).toEqual("osm") | ||||||
|             expect(d.get("host")).deep.equal("https://mapcomplete.osm.be/toerisme_vlaanderen.html") |             expect(d.get("source")).toEqual("survey") | ||||||
|             expect(d.get("imagery")).deep.equal("osm") |             expect(d.get("source:node/-1")).toEqual("note/1234") | ||||||
|             expect(d.get("source")).deep.equal("survey") |             expect(d.get("theme")).toEqual("toerisme_vlaanderen") | ||||||
|             expect(d.get("source:node/-1")).deep.equal("note/1234") |             expect(d.get("newTag")).toEqual("newValue") | ||||||
|             expect(d.get("theme")).deep.equal("toerisme_vlaanderen") |  | ||||||
|             expect(d.get("newTag")).deep.equal("newValue") |  | ||||||
|         }) |         }) | ||||||
|         it("should aggregate numeric tags", () => { |         it("should aggregate numeric tags", () => { | ||||||
|             const changesetHandler = new ChangesetHandler( |             const changesetHandler = new ChangesetHandler( | ||||||
|  | @ -116,17 +113,15 @@ describe("ChangesetHanlder", () => { | ||||||
|             ) |             ) | ||||||
|             const d = Utils.asDict(rewritten) |             const d = Utils.asDict(rewritten) | ||||||
| 
 | 
 | ||||||
|             expect(d.size).deep.equal(9) |             expect(d.size).toEqual(9) | ||||||
|             expect(d.get("answer")).deep.equal("42") |             expect(d.get("answer")).toEqual("42") | ||||||
|             expect(d.get("comment")).deep.equal( |             expect(d.get("comment")).toEqual("Adding data with #MapComplete for theme #toerisme_vlaanderen") | ||||||
|                 "Adding data with #MapComplete for theme #toerisme_vlaanderen" |             expect(d.get("created_by")).toEqual("MapComplete 0.16.6") | ||||||
|             ) |             expect(d.get("host")).toEqual("https://mapcomplete.osm.be/toerisme_vlaanderen.html") | ||||||
|             expect(d.get("created_by")).deep.equal("MapComplete 0.16.6") |             expect(d.get("imagery")).toEqual("osm") | ||||||
|             expect(d.get("host")).deep.equal("https://mapcomplete.osm.be/toerisme_vlaanderen.html") |             expect(d.get("source")).toEqual("survey") | ||||||
|             expect(d.get("imagery")).deep.equal("osm") |             expect(d.get("source:node/-1")).toEqual("note/1234") | ||||||
|             expect(d.get("source")).deep.equal("survey") |             expect(d.get("theme")).toEqual("toerisme_vlaanderen") | ||||||
|             expect(d.get("source:node/-1")).deep.equal("note/1234") |  | ||||||
|             expect(d.get("theme")).deep.equal("toerisme_vlaanderen") |  | ||||||
|         }) |         }) | ||||||
|         it("should rewrite special reasons with the correct ID", () => { |         it("should rewrite special reasons with the correct ID", () => { | ||||||
|             const changesetHandler = new ChangesetHandler( |             const changesetHandler = new ChangesetHandler( | ||||||
|  | @ -169,17 +164,15 @@ describe("ChangesetHanlder", () => { | ||||||
|             ) |             ) | ||||||
|             const d = Utils.asDict(rewritten) |             const d = Utils.asDict(rewritten) | ||||||
| 
 | 
 | ||||||
|             expect(d.size).deep.equal(9) |             expect(d.size).toEqual(9) | ||||||
|             expect(d.get("answer")).deep.equal("5") |             expect(d.get("answer")).toEqual("5") | ||||||
|             expect(d.get("comment")).deep.equal( |             expect(d.get("comment")).toEqual("Adding data with #MapComplete for theme #toerisme_vlaanderen") | ||||||
|                 "Adding data with #MapComplete for theme #toerisme_vlaanderen" |             expect(d.get("created_by")).toEqual("MapComplete 0.16.6") | ||||||
|             ) |             expect(d.get("host")).toEqual("https://mapcomplete.osm.be/toerisme_vlaanderen.html") | ||||||
|             expect(d.get("created_by")).deep.equal("MapComplete 0.16.6") |             expect(d.get("imagery")).toEqual("osm") | ||||||
|             expect(d.get("host")).deep.equal("https://mapcomplete.osm.be/toerisme_vlaanderen.html") |             expect(d.get("source")).toEqual("survey") | ||||||
|             expect(d.get("imagery")).deep.equal("osm") |             expect(d.get("source:node/42")).toEqual("note/1234") | ||||||
|             expect(d.get("source")).deep.equal("survey") |             expect(d.get("theme")).toEqual("toerisme_vlaanderen") | ||||||
|             expect(d.get("source:node/42")).deep.equal("note/1234") |  | ||||||
|             expect(d.get("theme")).deep.equal("toerisme_vlaanderen") |  | ||||||
|         }) |         }) | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|  | @ -200,12 +193,13 @@ describe("ChangesetHanlder", () => { | ||||||
|                 extraMetaTags, |                 extraMetaTags, | ||||||
|                 changes |                 changes | ||||||
|             ) |             ) | ||||||
|             expect(hasSpecialMotivationChanges, "Special rewrite did not trigger").true |             // "Special rewrite did not trigger"
 | ||||||
|  |             expect(hasSpecialMotivationChanges).toBe(true) | ||||||
|             // Rewritten inline by rewriteMetaTags
 |             // Rewritten inline by rewriteMetaTags
 | ||||||
|             expect(extraMetaTags[1].key).deep.equal("source:node/42") |             expect(extraMetaTags[1].key).toEqual("source:node/42") | ||||||
|             expect(extraMetaTags[1].value).deep.equal("note/1234") |             expect(extraMetaTags[1].value).toEqual("note/1234") | ||||||
|             expect(extraMetaTags[0].key).deep.equal("created_by") |             expect(extraMetaTags[0].key).toEqual("created_by") | ||||||
|             expect(extraMetaTags[0].value).deep.equal("mapcomplete") |             expect(extraMetaTags[0].value).toEqual("mapcomplete") | ||||||
|         }) |         }) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,9 +1,8 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { OsmObject } from "../../../Logic/Osm/OsmObject" | import { OsmObject } from "../../../Logic/Osm/OsmObject" | ||||||
| import { Utils } from "../../../Utils" | import { Utils } from "../../../Utils" | ||||||
| import ScriptUtils from "../../../scripts/ScriptUtils" | import ScriptUtils from "../../../scripts/ScriptUtils" | ||||||
| import { readFileSync } from "fs" | import { readFileSync } from "fs" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("OsmObject", () => { | describe("OsmObject", () => { | ||||||
|     describe("download referencing ways", () => { |     describe("download referencing ways", () => { | ||||||
|  | @ -81,8 +80,8 @@ describe("OsmObject", () => { | ||||||
| 
 | 
 | ||||||
|         it("should download referencing ways", async () => { |         it("should download referencing ways", async () => { | ||||||
|             const ways = await OsmObject.DownloadReferencingWays("node/1124134958") |             const ways = await OsmObject.DownloadReferencingWays("node/1124134958") | ||||||
|             expect(ways).not.undefined |             expect(ways).toBeDefined() | ||||||
|             expect(ways).length(4) |             expect(ways).toHaveLength(4) | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should download full OSM-relations", async () => { |         it("should download full OSM-relations", async () => { | ||||||
|  | @ -93,7 +92,7 @@ describe("OsmObject", () => { | ||||||
|             ) |             ) | ||||||
|             const r = await OsmObject.DownloadObjectAsync("relation/5759328").then((x) => x) |             const r = await OsmObject.DownloadObjectAsync("relation/5759328").then((x) => x) | ||||||
|             const geojson = r.asGeoJson() |             const geojson = r.asGeoJson() | ||||||
|             expect(geojson.geometry.type).eq("MultiPolygon") |             expect(geojson.geometry.type).toBe("MultiPolygon") | ||||||
|         }) |         }) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { TagUtils } from "../../../Logic/Tags/TagUtils" | import { TagUtils } from "../../../Logic/Tags/TagUtils" | ||||||
| import { Tag } from "../../../Logic/Tags/Tag" | import { Tag } from "../../../Logic/Tags/Tag" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("Lazy object properties", () => { | describe("Lazy object properties", () => { | ||||||
|     it("should be matche by a normal tag", () => { |     it("should be matche by a normal tag", () => { | ||||||
|  | @ -16,7 +15,7 @@ describe("Lazy object properties", () => { | ||||||
|             }, |             }, | ||||||
|         }) |         }) | ||||||
|         const filter = new Tag("_key", "yes") |         const filter = new Tag("_key", "yes") | ||||||
|         expect(filter.matchesProperties(properties)).true |         expect(filter.matchesProperties(properties)).toBe(true) | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     it("should be matched by a RegexTag", () => { |     it("should be matched by a RegexTag", () => { | ||||||
|  | @ -31,6 +30,6 @@ describe("Lazy object properties", () => { | ||||||
|             }, |             }, | ||||||
|         }) |         }) | ||||||
|         const filter = TagUtils.Tag("_key~*") |         const filter = TagUtils.Tag("_key~*") | ||||||
|         expect(filter.matchesProperties(properties)).true |         expect(filter.matchesProperties(properties)).toBe(true) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,30 +1,29 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { TagsFilter } from "../../../Logic/Tags/TagsFilter" | import { TagsFilter } from "../../../Logic/Tags/TagsFilter" | ||||||
| import { And } from "../../../Logic/Tags/And" | import { And } from "../../../Logic/Tags/And" | ||||||
| import { Tag } from "../../../Logic/Tags/Tag" | import { Tag } from "../../../Logic/Tags/Tag" | ||||||
| import { TagUtils } from "../../../Logic/Tags/TagUtils" | import { TagUtils } from "../../../Logic/Tags/TagUtils" | ||||||
| import { Or } from "../../../Logic/Tags/Or" | import { Or } from "../../../Logic/Tags/Or" | ||||||
| import { RegexTag } from "../../../Logic/Tags/RegexTag" | import { RegexTag } from "../../../Logic/Tags/RegexTag" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("Tag optimalization", () => { | describe("Tag optimalization", () => { | ||||||
|     describe("And", () => { |     describe("And", () => { | ||||||
|         it("with condition and nested and should be flattened", () => { |         it("with condition and nested and should be flattened", () => { | ||||||
|             const t = new And([new And([new Tag("x", "y")]), new Tag("a", "b")]) |             const t = new And([new And([new Tag("x", "y")]), new Tag("a", "b")]) | ||||||
|             const opt = <TagsFilter>t.optimize() |             const opt = <TagsFilter>t.optimize() | ||||||
|             expect(TagUtils.toString(opt)).eq(`a=b&x=y`) |             expect(TagUtils.toString(opt)).toBe(`a=b&x=y`) | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should be 'true' if no conditions are given", () => { |         it("should be 'true' if no conditions are given", () => { | ||||||
|             const t = new And([]) |             const t = new And([]) | ||||||
|             const opt = t.optimize() |             const opt = t.optimize() | ||||||
|             expect(opt).eq(true) |             expect(opt).toBe(true) | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should return false on conflicting tags", () => { |         it("should return false on conflicting tags", () => { | ||||||
|             const t = new And([new Tag("key", "a"), new Tag("key", "b")]) |             const t = new And([new Tag("key", "a"), new Tag("key", "b")]) | ||||||
|             const opt = t.optimize() |             const opt = t.optimize() | ||||||
|             expect(opt).eq(false) |             expect(opt).toBe(false) | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("with nested ors and common property should be extracted", () => { |         it("with nested ors and common property should be extracted", () => { | ||||||
|  | @ -35,7 +34,7 @@ describe("Tag optimalization", () => { | ||||||
|                 new Or([new Tag("x", "y"), new Tag("c", "d")]), |                 new Or([new Tag("x", "y"), new Tag("c", "d")]), | ||||||
|             ]) |             ]) | ||||||
|             const opt = <TagsFilter>t.optimize() |             const opt = <TagsFilter>t.optimize() | ||||||
|             expect(TagUtils.toString(opt)).eq("foo=bar& (x=y| (a=b&c=d) )") |             expect(TagUtils.toString(opt)).toBe("foo=bar& (x=y| (a=b&c=d) )") | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("with nested ors and common regextag should be extracted", () => { |         it("with nested ors and common regextag should be extracted", () => { | ||||||
|  | @ -46,7 +45,7 @@ describe("Tag optimalization", () => { | ||||||
|                 new Or([new RegexTag("x", "y"), new RegexTag("c", "d")]), |                 new Or([new RegexTag("x", "y"), new RegexTag("c", "d")]), | ||||||
|             ]) |             ]) | ||||||
|             const opt = <TagsFilter>t.optimize() |             const opt = <TagsFilter>t.optimize() | ||||||
|             expect(TagUtils.toString(opt)).eq("foo=bar& ( (a=b&c=d) |x=y)") |             expect(TagUtils.toString(opt)).toBe("foo=bar& ( (a=b&c=d) |x=y)") | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("with nested ors and inverted regextags should _not_ be extracted", () => { |         it("with nested ors and inverted regextags should _not_ be extracted", () => { | ||||||
|  | @ -57,19 +56,19 @@ describe("Tag optimalization", () => { | ||||||
|                 new Or([new RegexTag("x", "y", true), new RegexTag("c", "d")]), |                 new Or([new RegexTag("x", "y", true), new RegexTag("c", "d")]), | ||||||
|             ]) |             ]) | ||||||
|             const opt = <TagsFilter>t.optimize() |             const opt = <TagsFilter>t.optimize() | ||||||
|             expect(TagUtils.toString(opt)).eq("foo=bar& (a=b|x=y) & (c=d|x!=y)") |             expect(TagUtils.toString(opt)).toBe("foo=bar& (a=b|x=y) & (c=d|x!=y)") | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should move regextag to the end", () => { |         it("should move regextag to the end", () => { | ||||||
|             const t = new And([new RegexTag("x", "y"), new Tag("a", "b")]) |             const t = new And([new RegexTag("x", "y"), new Tag("a", "b")]) | ||||||
|             const opt = <TagsFilter>t.optimize() |             const opt = <TagsFilter>t.optimize() | ||||||
|             expect(TagUtils.toString(opt)).eq("a=b&x=y") |             expect(TagUtils.toString(opt)).toBe("a=b&x=y") | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should sort tags by their popularity (least popular first)", () => { |         it("should sort tags by their popularity (least popular first)", () => { | ||||||
|             const t = new And([new Tag("bicycle", "yes"), new Tag("amenity", "binoculars")]) |             const t = new And([new Tag("bicycle", "yes"), new Tag("amenity", "binoculars")]) | ||||||
|             const opt = <TagsFilter>t.optimize() |             const opt = <TagsFilter>t.optimize() | ||||||
|             expect(TagUtils.toString(opt)).eq("amenity=binoculars&bicycle=yes") |             expect(TagUtils.toString(opt)).toBe("amenity=binoculars&bicycle=yes") | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should optimize nested ORs", () => { |         it("should optimize nested ORs", () => { | ||||||
|  | @ -163,17 +162,17 @@ describe("Tag optimalization", () => { | ||||||
|                 "leisure=playground&playground!=forest", |                 "leisure=playground&playground!=forest", | ||||||
|             ] |             ] | ||||||
| 
 | 
 | ||||||
|             expect((<Or>opt).or.map((f) => TagUtils.toString(f))).deep.eq(expected) |             expect((<Or>opt).or.map((f) => TagUtils.toString(f))).toEqual(expected) | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should detect conflicting tags", () => { |         it("should detect conflicting tags", () => { | ||||||
|             const q = new And([new Tag("key", "value"), new RegexTag("key", "value", true)]) |             const q = new And([new Tag("key", "value"), new RegexTag("key", "value", true)]) | ||||||
|             expect(q.optimize()).eq(false) |             expect(q.optimize()).toBe(false) | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should detect conflicting tags with a regex", () => { |         it("should detect conflicting tags with a regex", () => { | ||||||
|             const q = new And([new Tag("key", "value"), new RegexTag("key", /value/, true)]) |             const q = new And([new Tag("key", "value"), new RegexTag("key", /value/, true)]) | ||||||
|             expect(q.optimize()).eq(false) |             expect(q.optimize()).toBe(false) | ||||||
|         }) |         }) | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|  | @ -184,17 +183,17 @@ describe("Tag optimalization", () => { | ||||||
|                 new And([new Tag("foo", "bar"), new Tag("x", "y")]), |                 new And([new Tag("foo", "bar"), new Tag("x", "y")]), | ||||||
|             ]) |             ]) | ||||||
|             const opt = <TagsFilter>t.optimize() |             const opt = <TagsFilter>t.optimize() | ||||||
|             expect(TagUtils.toString(opt)).eq("foo=bar") |             expect(TagUtils.toString(opt)).toBe("foo=bar") | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should flatten nested ors", () => { |         it("should flatten nested ors", () => { | ||||||
|             const t = new Or([new Or([new Tag("x", "y")])]).optimize() |             const t = new Or([new Or([new Tag("x", "y")])]).optimize() | ||||||
|             expect(t).deep.eq(new Tag("x", "y")) |             expect(t).toEqual(new Tag("x", "y")) | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should flatten nested ors", () => { |         it("should flatten nested ors", () => { | ||||||
|             const t = new Or([new Tag("a", "b"), new Or([new Tag("x", "y")])]).optimize() |             const t = new Or([new Tag("a", "b"), new Or([new Tag("x", "y")])]).optimize() | ||||||
|             expect(t).deep.eq(new Or([new Tag("a", "b"), new Tag("x", "y")])) |             expect(t).toEqual(new Or([new Tag("a", "b"), new Tag("x", "y")])) | ||||||
|         }) |         }) | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|  | @ -259,8 +258,7 @@ describe("Tag optimalization", () => { | ||||||
|          ) |          ) | ||||||
|          */ |          */ | ||||||
| 
 | 
 | ||||||
|         expect(opt).deep.eq( |         expect(opt).toEqual(TagUtils.Tag({ | ||||||
|             TagUtils.Tag({ |  | ||||||
|             or: [ |             or: [ | ||||||
|                 "club=climbing", |                 "club=climbing", | ||||||
|                 { |                 { | ||||||
|  | @ -285,7 +283,6 @@ describe("Tag optimalization", () => { | ||||||
|                     ], |                     ], | ||||||
|                 }, |                 }, | ||||||
|             ], |             ], | ||||||
|             }) |         })) | ||||||
|         ) |  | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,12 +1,12 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { TagUtils } from "../../../Logic/Tags/TagUtils" | import { TagUtils } from "../../../Logic/Tags/TagUtils" | ||||||
| import { equal } from "assert" | import { equal } from "assert" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| describe("TagUtils", () => { | describe("TagUtils", () => { | ||||||
|     describe("ParseTag", () => { |     describe("ParseTag", () => { | ||||||
|         it("should refuse a key!=* tag", () => { |         it("should refuse a key!=* tag", () => { | ||||||
|             expect(() => TagUtils.Tag("key!=*")).to.throw() |             expect(() => TagUtils.Tag("key!=*")).toThrowError() | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should handle compare tag <=5", () => { |         it("should handle compare tag <=5", () => { | ||||||
|  | @ -42,8 +42,8 @@ describe("TagUtils", () => { | ||||||
| 
 | 
 | ||||||
|         it("should handle date comparison tags", () => { |         it("should handle date comparison tags", () => { | ||||||
|             const filter = TagUtils.Tag("date_created<2022-01-07") |             const filter = TagUtils.Tag("date_created<2022-01-07") | ||||||
|             expect(filter.matchesProperties({ date_created: "2022-01-08" })).false |             expect(filter.matchesProperties({ date_created: "2022-01-08" })).toBe(false) | ||||||
|             expect(filter.matchesProperties({ date_created: "2022-01-01" })).true |             expect(filter.matchesProperties({ date_created: "2022-01-01" })).toBe(true) | ||||||
|         }) |         }) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { Utils } from "../../../Utils" | import { Utils } from "../../../Utils" | ||||||
| import Wikidata from "../../../Logic/Web/Wikidata" | import Wikidata from "../../../Logic/Web/Wikidata" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| const Q140 = { | const Q140 = { | ||||||
|     entities: { |     entities: { | ||||||
|  | @ -9464,21 +9463,20 @@ Utils.injectJsonDownloadForTests( | ||||||
| describe("Wikidata", () => { | describe("Wikidata", () => { | ||||||
|     it("should download Q140 (lion)", async () => { |     it("should download Q140 (lion)", async () => { | ||||||
|         const wikidata = await Wikidata.LoadWikidataEntryAsync("Q140") |         const wikidata = await Wikidata.LoadWikidataEntryAsync("Q140") | ||||||
|         expect(wikidata.claims.get("P18")).length(2) |         expect(wikidata.claims.get("P18")).toHaveLength(2) | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     it("should download wikidata", async () => { |     it("should download wikidata", async () => { | ||||||
|         const wdata = await Wikidata.LoadWikidataEntryAsync(14517013) |         const wdata = await Wikidata.LoadWikidataEntryAsync(14517013) | ||||||
|         expect(wdata.wikisites).to.have.key("nl") |         expect(wdata.wikisites.get("nl")).toBe("Vredesmolen") | ||||||
|         expect(wdata.wikisites.get("nl")).eq("Vredesmolen") |  | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     it("should download a lexeme", async () => { |     it("should download a lexeme", async () => { | ||||||
|         const response = await Wikidata.LoadWikidataEntryAsync( |         const response = await Wikidata.LoadWikidataEntryAsync( | ||||||
|             "https://www.wikidata.org/wiki/Lexeme:L614072" |             "https://www.wikidata.org/wiki/Lexeme:L614072" | ||||||
|         ) |         ) | ||||||
|         expect(response).not.undefined | 
 | ||||||
|         expect(response.labels).to.have.key("nl") |         expect(response).toBeDefined() | ||||||
|         expect(response.labels).to.contains("Groen") |         expect(response.labels).toEqual(new Map<string, string>([["nl", "Groen"]])) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,5 +1,3 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { Utils } from "../../../../Utils" | import { Utils } from "../../../../Utils" | ||||||
| import { DesugaringContext } from "../../../../Models/ThemeConfig/Conversion/Conversion" | import { DesugaringContext } from "../../../../Models/ThemeConfig/Conversion/Conversion" | ||||||
| import { LayerConfigJson } from "../../../../Models/ThemeConfig/Json/LayerConfigJson" | import { LayerConfigJson } from "../../../../Models/ThemeConfig/Json/LayerConfigJson" | ||||||
|  | @ -7,6 +5,7 @@ import { TagRenderingConfigJson } from "../../../../Models/ThemeConfig/Json/TagR | ||||||
| import { PrepareLayer } from "../../../../Models/ThemeConfig/Conversion/PrepareLayer" | import { PrepareLayer } from "../../../../Models/ThemeConfig/Conversion/PrepareLayer" | ||||||
| import * as bookcases from "../../../../assets/layers/public_bookcase/public_bookcase.json" | import * as bookcases from "../../../../assets/layers/public_bookcase/public_bookcase.json" | ||||||
| import CreateNoteImportLayer from "../../../../Models/ThemeConfig/Conversion/CreateNoteImportLayer" | import CreateNoteImportLayer from "../../../../Models/ThemeConfig/Conversion/CreateNoteImportLayer" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("CreateNoteImportLayer", () => { | describe("CreateNoteImportLayer", () => { | ||||||
|     it("should generate a layerconfig", () => { |     it("should generate a layerconfig", () => { | ||||||
|  | @ -24,18 +23,15 @@ describe("CreateNoteImportLayer", () => { | ||||||
|             layer, |             layer, | ||||||
|             "ImportLayerGeneratorTest: convert" |             "ImportLayerGeneratorTest: convert" | ||||||
|         ) |         ) | ||||||
|         expect(generatedLayer.isShown["and"][1].or[0].and[0]).deep.equal( |         expect(generatedLayer.isShown["and"][1].or[0].and[0]).toEqual("_tags~(^|.*;)amenity=public_bookcase($|;.*)") | ||||||
|             "_tags~(^|.*;)amenity=public_bookcase($|;.*)" |         // "Zoomlevel is to high"
 | ||||||
|         ) |         expect(generatedLayer.minzoom <= layer.minzoom).toBe(true) | ||||||
|         expect(generatedLayer.minzoom <= layer.minzoom, "Zoomlevel is to high").true |  | ||||||
|         let renderings = Utils.NoNull( |         let renderings = Utils.NoNull( | ||||||
|             Utils.NoNull( |             Utils.NoNull( | ||||||
|                 generatedLayer.tagRenderings.map((tr) => (<TagRenderingConfigJson>tr).render) |                 generatedLayer.tagRenderings.map((tr) => (<TagRenderingConfigJson>tr).render) | ||||||
|             ).map((render) => render["en"]) |             ).map((render) => render["en"]) | ||||||
|         ) |         ) | ||||||
|         expect( |         // "no import button found"
 | ||||||
|             renderings.some((r) => r.indexOf("import_button") > 0), |         expect(renderings.some((r) => r.indexOf("import_button") > 0)).toBe(true) | ||||||
|             "no import button found" |  | ||||||
|         ).true |  | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import LayoutConfig from "../../../../Models/ThemeConfig/LayoutConfig" | import LayoutConfig from "../../../../Models/ThemeConfig/LayoutConfig" | ||||||
| import { FixLegacyTheme } from "../../../../Models/ThemeConfig/Conversion/LegacyJsonConvert" | import { FixLegacyTheme } from "../../../../Models/ThemeConfig/Conversion/LegacyJsonConvert" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("FixLegacyTheme", () => { | describe("FixLegacyTheme", () => { | ||||||
|     it("should create a working theme config", () => { |     it("should create a working theme config", () => { | ||||||
|  | @ -135,8 +134,9 @@ describe("FixLegacyTheme", () => { | ||||||
|             ], |             ], | ||||||
|         } |         } | ||||||
|         const fixed = new FixLegacyTheme().convert(<any>walking_node_theme, "While testing") |         const fixed = new FixLegacyTheme().convert(<any>walking_node_theme, "While testing") | ||||||
|         expect(fixed.errors, "Could not fix the legacy theme").empty |         // "Could not fix the legacy theme"
 | ||||||
|  |         expect(fixed.errors).empty | ||||||
|         const theme = new LayoutConfig(fixed.result, false) |         const theme = new LayoutConfig(fixed.result, false) | ||||||
|         expect(theme).not.undefined |         expect(theme).toBeDefined() | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,5 +1,3 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { LayerConfigJson } from "../../../../Models/ThemeConfig/Json/LayerConfigJson" | import { LayerConfigJson } from "../../../../Models/ThemeConfig/Json/LayerConfigJson" | ||||||
| import { TagRenderingConfigJson } from "../../../../Models/ThemeConfig/Json/TagRenderingConfigJson" | import { TagRenderingConfigJson } from "../../../../Models/ThemeConfig/Json/TagRenderingConfigJson" | ||||||
| import LineRenderingConfigJson from "../../../../Models/ThemeConfig/Json/LineRenderingConfigJson" | import LineRenderingConfigJson from "../../../../Models/ThemeConfig/Json/LineRenderingConfigJson" | ||||||
|  | @ -10,6 +8,7 @@ import { | ||||||
| } from "../../../../Models/ThemeConfig/Conversion/PrepareLayer" | } from "../../../../Models/ThemeConfig/Conversion/PrepareLayer" | ||||||
| import { QuestionableTagRenderingConfigJson } from "../../../../Models/ThemeConfig/Json/QuestionableTagRenderingConfigJson" | import { QuestionableTagRenderingConfigJson } from "../../../../Models/ThemeConfig/Json/QuestionableTagRenderingConfigJson" | ||||||
| import RewritableConfigJson from "../../../../Models/ThemeConfig/Json/RewritableConfigJson" | import RewritableConfigJson from "../../../../Models/ThemeConfig/Json/RewritableConfigJson" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("ExpandRewrite", () => { | describe("ExpandRewrite", () => { | ||||||
|     it("should not allow overlapping keys", () => { |     it("should not allow overlapping keys", () => { | ||||||
|  | @ -106,7 +105,7 @@ describe("PrepareLayer", () => { | ||||||
|             titleIcons: [{ render: "defaults", id: "defaults" }], |             titleIcons: [{ render: "defaults", id: "defaults" }], | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         expect(result).deep.eq(expected) |         expect(result).toEqual(expected) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
|  | @ -126,7 +125,7 @@ describe("RewriteSpecial", function () { | ||||||
|             }, |             }, | ||||||
|         } |         } | ||||||
|         const r = new RewriteSpecial().convert(tr, "test").result |         const r = new RewriteSpecial().convert(tr, "test").result | ||||||
|         expect(r).to.deep.eq({ |         expect(r).toEqual({ | ||||||
|             id: "uk_addresses_import_button", |             id: "uk_addresses_import_button", | ||||||
|             render: { |             render: { | ||||||
|                 "*": "{import_button(address,urpn_count=$urpn_count;ref:GB:uprn=$ref:GB:uprn$,Add this address,./assets/themes/uk_addresses/housenumber_add.svg,,,,none,)}", |                 "*": "{import_button(address,urpn_count=$urpn_count;ref:GB:uprn=$ref:GB:uprn$,Add this address,./assets/themes/uk_addresses/housenumber_add.svg,,,,none,)}", | ||||||
|  |  | ||||||
|  | @ -1,5 +1,3 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { LayoutConfigJson } from "../../../../Models/ThemeConfig/Json/LayoutConfigJson" | import { LayoutConfigJson } from "../../../../Models/ThemeConfig/Json/LayoutConfigJson" | ||||||
| import { LayerConfigJson } from "../../../../Models/ThemeConfig/Json/LayerConfigJson" | import { LayerConfigJson } from "../../../../Models/ThemeConfig/Json/LayerConfigJson" | ||||||
| import { PrepareTheme } from "../../../../Models/ThemeConfig/Conversion/PrepareTheme" | import { PrepareTheme } from "../../../../Models/ThemeConfig/Conversion/PrepareTheme" | ||||||
|  | @ -12,6 +10,7 @@ import * as cyclofix from "../../../../assets/generated/themes/cyclofix.json" | ||||||
| import { Tag } from "../../../../Logic/Tags/Tag" | import { Tag } from "../../../../Logic/Tags/Tag" | ||||||
| import { DesugaringContext } from "../../../../Models/ThemeConfig/Conversion/Conversion" | import { DesugaringContext } from "../../../../Models/ThemeConfig/Conversion/Conversion" | ||||||
| import { And } from "../../../../Logic/Tags/And" | import { And } from "../../../../Logic/Tags/And" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| const themeConfigJson: LayoutConfigJson = { | const themeConfigJson: LayoutConfigJson = { | ||||||
|     description: "Descr", |     description: "Descr", | ||||||
|  | @ -49,7 +48,7 @@ describe("PrepareTheme", () => { | ||||||
|         const layerUnderTest = <LayerConfig>( |         const layerUnderTest = <LayerConfig>( | ||||||
|             themeConfig.layers.find((l) => l.id === "public_bookcase") |             themeConfig.layers.find((l) => l.id === "public_bookcase") | ||||||
|         ) |         ) | ||||||
|         expect(layerUnderTest.source.osmTags).deep.eq( |         expect(layerUnderTest.source.osmTags).toEqual( | ||||||
|             new And([new Tag("amenity", "public_bookcase")]) |             new And([new Tag("amenity", "public_bookcase")]) | ||||||
|         ) |         ) | ||||||
|     }) |     }) | ||||||
|  | @ -65,7 +64,7 @@ describe("PrepareTheme", () => { | ||||||
|         const layerUnderTest = <LayerConfig>( |         const layerUnderTest = <LayerConfig>( | ||||||
|             themeConfig.layers.find((l) => l.id === "public_bookcase") |             themeConfig.layers.find((l) => l.id === "public_bookcase") | ||||||
|         ) |         ) | ||||||
|         expect(layerUnderTest.source.geojsonSource).eq("xyz") |         expect(layerUnderTest.source.geojsonSource).toBe("xyz") | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     it("should apply override", () => { |     it("should apply override", () => { | ||||||
|  | @ -85,7 +84,7 @@ describe("PrepareTheme", () => { | ||||||
|         const layerUnderTest = <LayerConfig>( |         const layerUnderTest = <LayerConfig>( | ||||||
|             themeConfig.layers.find((l) => l.id === "public_bookcase") |             themeConfig.layers.find((l) => l.id === "public_bookcase") | ||||||
|         ) |         ) | ||||||
|         expect(layerUnderTest.source.geojsonSource).eq("https://example.com/data.geojson") |         expect(layerUnderTest.source.geojsonSource).toBe("https://example.com/data.geojson") | ||||||
|     }) |     }) | ||||||
| 
 | 
 | ||||||
|     it("should remove names which are overriden with null", () => { |     it("should remove names which are overriden with null", () => { | ||||||
|  | @ -126,8 +125,8 @@ describe("PrepareTheme", () => { | ||||||
|         const rewritten = new PrepareTheme(ctx, { |         const rewritten = new PrepareTheme(ctx, { | ||||||
|             skipDefaultLayers: true, |             skipDefaultLayers: true, | ||||||
|         }).convertStrict(layout, "test") |         }).convertStrict(layout, "test") | ||||||
|         expect(rewritten.layers[0]).deep.eq(testLayer) |         expect(rewritten.layers[0]).toEqual(testLayer) | ||||||
|         expect(rewritten.layers[1]).deep.eq({ |         expect(rewritten.layers[1]).toEqual({ | ||||||
|             source: { |             source: { | ||||||
|                 osmTags: "x=y", |                 osmTags: "x=y", | ||||||
|             }, |             }, | ||||||
|  | @ -158,7 +157,7 @@ describe("ExtractImages", () => { | ||||||
|             "close", |             "close", | ||||||
|         ] |         ] | ||||||
|         for (const expected of expectedValues) { |         for (const expected of expectedValues) { | ||||||
|             expect(images).contains(expected) |             expect(images).toEqual(expect.arrayContaining([expected])) | ||||||
|         } |         } | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import SourceConfig from "../../../Models/ThemeConfig/SourceConfig" | import SourceConfig from "../../../Models/ThemeConfig/SourceConfig" | ||||||
| import { TagUtils } from "../../../Logic/Tags/TagUtils" | import { TagUtils } from "../../../Logic/Tags/TagUtils" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("SourceConfig", () => { | describe("SourceConfig", () => { | ||||||
|     it("should throw an error on conflicting tags", () => { |     it("should throw an error on conflicting tags", () => { | ||||||
|  | @ -14,6 +13,6 @@ describe("SourceConfig", () => { | ||||||
|                 }, |                 }, | ||||||
|                 false |                 false | ||||||
|             ) |             ) | ||||||
|         }).to.throw(/tags are conflicting/) |         }).toThrowError(/tags are conflicting/) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import TagRenderingConfig from "../../../Models/ThemeConfig/TagRenderingConfig" | import TagRenderingConfig from "../../../Models/ThemeConfig/TagRenderingConfig" | ||||||
| import Locale from "../../../UI/i18n/Locale" | import Locale from "../../../UI/i18n/Locale" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("TagRenderingConfig", () => { | describe("TagRenderingConfig", () => { | ||||||
|     describe("isKnown", () => { |     describe("isKnown", () => { | ||||||
|  | @ -26,11 +25,11 @@ describe("TagRenderingConfig", () => { | ||||||
|                 "Tests" |                 "Tests" | ||||||
|             ) |             ) | ||||||
| 
 | 
 | ||||||
|             expect(tr.GetRenderValue({ foo: "bar" })).undefined |             expect(tr.GetRenderValue({ foo: "bar" })).toBeUndefined() | ||||||
| 
 | 
 | ||||||
|             expect(tr.GetRenderValue({ noname: "yes" })?.textFor("nl")).eq("Has no name") |             expect(tr.GetRenderValue({ noname: "yes" })?.textFor("nl")).toBe("Has no name") | ||||||
|             expect(tr.GetRenderValue({ name: "xyz" })?.textFor("nl")).eq("Ook een {name}") |             expect(tr.GetRenderValue({ name: "xyz" })?.textFor("nl")).toBe("Ook een {name}") | ||||||
|             expect(tr.GetRenderValue({ foo: "bar" })).undefined |             expect(tr.GetRenderValue({ foo: "bar" })).toBeUndefined() | ||||||
|         }) |         }) | ||||||
| 
 | 
 | ||||||
|         it("should give a correct indication", () => { |         it("should give a correct indication", () => { | ||||||
|  | @ -63,8 +62,8 @@ describe("TagRenderingConfig", () => { | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             const tagRendering = new TagRenderingConfig(config, "test") |             const tagRendering = new TagRenderingConfig(config, "test") | ||||||
|             expect(tagRendering.IsKnown({ bottle: "yes" })).true |             expect(tagRendering.IsKnown({ bottle: "yes" })).toBe(true) | ||||||
|             expect(tagRendering.IsKnown({})).false |             expect(tagRendering.IsKnown({})).toBe(false) | ||||||
|         }) |         }) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { Unit } from "../../Models/Unit" | import { Unit } from "../../Models/Unit" | ||||||
| import { Denomination } from "../../Models/Denomination" | import { Denomination } from "../../Models/Denomination" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("Unit", () => { | describe("Unit", () => { | ||||||
|     it("should convert a value back and forth", () => { |     it("should convert a value back and forth", () => { | ||||||
|  | @ -19,10 +18,10 @@ describe("Unit", () => { | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         const canonical = denomintion.canonicalValue("5", true) |         const canonical = denomintion.canonicalValue("5", true) | ||||||
|         expect(canonical).eq("5 MW") |         expect(canonical).toBe("5 MW") | ||||||
|         const units = new Unit(["key"], [denomintion], false) |         const units = new Unit(["key"], [denomintion], false) | ||||||
|         const [detected, detectedDenom] = units.findDenomination("5 MW", () => "be") |         const [detected, detectedDenom] = units.findDenomination("5 MW", () => "be") | ||||||
|         expect(detected).eq("5") |         expect(detected).toBe("5") | ||||||
|         expect(detectedDenom).eq(denomintion) |         expect(detectedDenom).toBe(denomintion) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,10 +1,9 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { TagRenderingConfigJson } from "../../../Models/ThemeConfig/Json/TagRenderingConfigJson" | import { TagRenderingConfigJson } from "../../../Models/ThemeConfig/Json/TagRenderingConfigJson" | ||||||
| import TagRenderingConfig from "../../../Models/ThemeConfig/TagRenderingConfig" | import TagRenderingConfig from "../../../Models/ThemeConfig/TagRenderingConfig" | ||||||
| import TagRenderingQuestion from "../../../UI/Popup/TagRenderingQuestion" | import TagRenderingQuestion from "../../../UI/Popup/TagRenderingQuestion" | ||||||
| import { UIEventSource } from "../../../Logic/UIEventSource" | import { UIEventSource } from "../../../Logic/UIEventSource" | ||||||
| import { expect } from "chai" |  | ||||||
| import Locale from "../../../UI/i18n/Locale" | import Locale from "../../../UI/i18n/Locale" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("TagRenderingQuestion", () => { | describe("TagRenderingQuestion", () => { | ||||||
|     it("should have a freeform text field with the user defined placeholder", () => { |     it("should have a freeform text field with the user defined placeholder", () => { | ||||||
|  | @ -21,7 +20,7 @@ describe("TagRenderingQuestion", () => { | ||||||
|         const config = new TagRenderingConfig(configJson, "test") |         const config = new TagRenderingConfig(configJson, "test") | ||||||
|         const ui = new TagRenderingQuestion(new UIEventSource<any>({}), config) |         const ui = new TagRenderingQuestion(new UIEventSource<any>({}), config) | ||||||
|         const html = ui.ConstructElement() |         const html = ui.ConstructElement() | ||||||
|         expect(html.getElementsByTagName("input")[0]["placeholder"]).eq( |         expect(html.getElementsByTagName("input")[0]["placeholder"]).toBe( | ||||||
|             "Some user defined placeholder" |             "Some user defined placeholder" | ||||||
|         ) |         ) | ||||||
|     }) |     }) | ||||||
|  | @ -40,7 +39,7 @@ describe("TagRenderingQuestion", () => { | ||||||
|         const config = new TagRenderingConfig(configJson, "test") |         const config = new TagRenderingConfig(configJson, "test") | ||||||
|         const ui = new TagRenderingQuestion(new UIEventSource<any>({}), config) |         const ui = new TagRenderingQuestion(new UIEventSource<any>({}), config) | ||||||
|         const html = ui.ConstructElement() |         const html = ui.ConstructElement() | ||||||
|         expect(html.getElementsByTagName("input")[0]["placeholder"]).eq( |         expect(html.getElementsByTagName("input")[0]["placeholder"]).toBe( | ||||||
|             "capacity (a positive, whole number)" |             "capacity (a positive, whole number)" | ||||||
|         ) |         ) | ||||||
|     }) |     }) | ||||||
|  |  | ||||||
|  | @ -1,16 +1,12 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import SpecialVisualizations from "../../UI/SpecialVisualizations" | import SpecialVisualizations from "../../UI/SpecialVisualizations" | ||||||
| import { expect } from "chai" | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| describe("SpecialVisualisations", () => { | describe("SpecialVisualisations", () => { | ||||||
|     describe("predifined special visualisations", () => { |     describe("predifined special visualisations", () => { | ||||||
|         it("should not have an argument called 'type'", () => { |         it("should not have an argument called 'type'", () => { | ||||||
|             const specials = SpecialVisualizations.specialVisualizations |             const specials = SpecialVisualizations.specialVisualizations | ||||||
|             for (const special of specials) { |             for (const special of specials) { | ||||||
|                 expect(special.funcName).not.eq( |                 expect(special.funcName).not.toBe("type") | ||||||
|                     "type", |  | ||||||
|                     "A special visualisation is not allowed to be named 'type', as this will conflict with the 'special'-blocks" |  | ||||||
|                 ) |  | ||||||
| 
 | 
 | ||||||
|                 if (special.args === undefined) { |                 if (special.args === undefined) { | ||||||
|                     throw ( |                     throw ( | ||||||
|  | @ -20,10 +16,7 @@ describe("SpecialVisualisations", () => { | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 for (const arg of special.args) { |                 for (const arg of special.args) { | ||||||
|                     expect(arg.name).not.eq( |                     expect(arg.name).not.toBe("type") | ||||||
|                         "type", |  | ||||||
|                         "An argument is not allowed to be called 'type', as this will conflict with the 'special'-blocks" |  | ||||||
|                     ) |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }) |         }) | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| import { Utils } from "../Utils" | import { Utils } from "../Utils" | ||||||
| import LZString from "lz-string" | import LZString from "lz-string" | ||||||
| import { describe } from "mocha" | import { describe, expect, it } from "vitest" | ||||||
| import { expect } from "chai" |  | ||||||
| 
 | 
 | ||||||
| const example = { | const example = { | ||||||
|     id: "bookcases", |     id: "bookcases", | ||||||
|  | @ -36,25 +35,25 @@ describe("Utils", () => { | ||||||
|             const str = JSON.stringify({ title: "abc", and: "xyz", render: "somevalue" }) |             const str = JSON.stringify({ title: "abc", and: "xyz", render: "somevalue" }) | ||||||
|             const minified = Utils.MinifyJSON(str) |             const minified = Utils.MinifyJSON(str) | ||||||
|             const restored = Utils.UnMinify(minified) |             const restored = Utils.UnMinify(minified) | ||||||
|             expect(str).eq(restored) |             expect(str).toBe(restored) | ||||||
|         }) |         }) | ||||||
|         it("should minify and restore the bookcase example", () => { |         it("should minify and restore the bookcase example", () => { | ||||||
|             const str = JSON.stringify(example, null, 0) |             const str = JSON.stringify(example, null, 0) | ||||||
|             const minified = Utils.MinifyJSON(str) |             const minified = Utils.MinifyJSON(str) | ||||||
|             const restored = Utils.UnMinify(minified) |             const restored = Utils.UnMinify(minified) | ||||||
|             expect(str).eq(restored) |             expect(str).toBe(restored) | ||||||
|         }) |         }) | ||||||
|         it("should LZ-compress a theme", () => { |         it("should LZ-compress a theme", () => { | ||||||
|             const str = JSON.stringify(example, null, 0) |             const str = JSON.stringify(example, null, 0) | ||||||
|             const minified = LZString.compressToBase64(Utils.MinifyJSON(str)) |             const minified = LZString.compressToBase64(Utils.MinifyJSON(str)) | ||||||
|             const restored = Utils.UnMinify(LZString.decompressFromBase64(minified)) |             const restored = Utils.UnMinify(LZString.decompressFromBase64(minified)) | ||||||
|             expect(str).eq(restored) |             expect(str).toBe(restored) | ||||||
|         }) |         }) | ||||||
|         it("shoud be able to decode the LZ-compression of a theme", () => { |         it("shoud be able to decode the LZ-compression of a theme", () => { | ||||||
|             const str = JSON.stringify(example, null, 0) |             const str = JSON.stringify(example, null, 0) | ||||||
|             const minified = LZString.compressToBase64(str) |             const minified = LZString.compressToBase64(str) | ||||||
|             const restored = LZString.decompressFromBase64(minified) |             const restored = LZString.decompressFromBase64(minified) | ||||||
|             expect(str).eq(restored) |             expect(str).toBe(restored) | ||||||
|         }) |         }) | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -1,9 +1,8 @@ | ||||||
| import { describe } from "mocha" |  | ||||||
| import { expect } from "chai" |  | ||||||
| import { Utils } from "../../Utils" | import { Utils } from "../../Utils" | ||||||
| import { existsSync, mkdirSync, readFileSync, rmdirSync, unlinkSync } from "fs" | import { existsSync, mkdirSync, readFileSync, rmdirSync, unlinkSync } from "fs" | ||||||
| import ScriptUtils from "../../scripts/ScriptUtils" | import ScriptUtils from "../../scripts/ScriptUtils" | ||||||
| import { main } from "../../scripts/generateCache" | import { main } from "../../scripts/generateCache" | ||||||
|  | import { describe, expect, it } from "vitest" | ||||||
| 
 | 
 | ||||||
| function initDownloads(query: string) { | function initDownloads(query: string) { | ||||||
|     const d = { |     const d = { | ||||||
|  | @ -7613,10 +7612,8 @@ describe("GenerateCache", () => { | ||||||
|                 encoding: "utf8", |                 encoding: "utf8", | ||||||
|             }) |             }) | ||||||
|         ) |         ) | ||||||
|         expect(birdhides.features.length).deep.equal(5) |         expect(birdhides.features.length).toEqual(5) | ||||||
|         expect( |         // "Didn't find birdhide node/5158056232 "
 | ||||||
|             birdhides.features.some((f) => f.properties.id === "node/5158056232"), |         expect(birdhides.features.some((f) => f.properties.id === "node/5158056232")).toBe(true) | ||||||
|             "Didn't find birdhide node/5158056232 " |  | ||||||
|         ).true |  | ||||||
|     }) |     }) | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -2,9 +2,9 @@ import ScriptUtils from "../scripts/ScriptUtils" | ||||||
| import { Utils } from "../Utils" | import { Utils } from "../Utils" | ||||||
| import * as fakedom from "fake-dom" | import * as fakedom from "fake-dom" | ||||||
| import Locale from "../UI/i18n/Locale" | import Locale from "../UI/i18n/Locale" | ||||||
|  | import { beforeEach } from "vitest" | ||||||
| 
 | 
 | ||||||
| export const mochaHooks = { | beforeEach(async () => { | ||||||
|     beforeEach(done) { |  | ||||||
|     ScriptUtils.fixUtils() |     ScriptUtils.fixUtils() | ||||||
|     Locale.language.setData("en") |     Locale.language.setData("en") | ||||||
| 
 | 
 | ||||||
|  | @ -13,29 +13,7 @@ export const mochaHooks = { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Block internet access
 |     // Block internet access
 | ||||||
|         const realDownloadFunc = Utils.externalDownloadFunction |  | ||||||
|     Utils.externalDownloadFunction = async (url) => { |     Utils.externalDownloadFunction = async (url) => { | ||||||
|             console.error( |         throw "Fetching " + url + "blocked in tests, use Utils.injectJsonDownloadForTests instead" | ||||||
|                 "Fetching ", |  | ||||||
|                 url, |  | ||||||
|                 "blocked in tests, use Utils.injectJsonDownloadForTests" |  | ||||||
|             ) |  | ||||||
|             const data = await realDownloadFunc(url) |  | ||||||
|             console.log( |  | ||||||
|                 "\n\n ----------- \nBLOCKED DATA\n Utils.injectJsonDownloadForTests(\n" + "       ", |  | ||||||
|                 JSON.stringify(url), |  | ||||||
|                 ", \n", |  | ||||||
|                 "       ", |  | ||||||
|                 //   JSON.stringify(data),
 |  | ||||||
|                 "\n    )\n------------------\n\n" |  | ||||||
|             ) |  | ||||||
|             throw new Error( |  | ||||||
|                 "Detected internet access for URL " + |  | ||||||
|                     url + |  | ||||||
|                     ", please inject it with Utils.injectJsonDownloadForTests" |  | ||||||
|             ) |  | ||||||
|     } |     } | ||||||
| 
 | }) | ||||||
|         done() |  | ||||||
|     }, |  | ||||||
| } |  | ||||||
|  |  | ||||||
							
								
								
									
										8
									
								
								vitest.config.ts
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								vitest.config.ts
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,8 @@ | ||||||
|  | import { defineConfig } from "vitest/config" | ||||||
|  | 
 | ||||||
|  | export default defineConfig({ | ||||||
|  |     test: { | ||||||
|  |         globals: true, | ||||||
|  |         setupFiles: ["./test/testhooks.ts"], | ||||||
|  |     }, | ||||||
|  | }) | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue