diff --git a/global.d.ts b/global.d.ts new file mode 100644 index 0000000..b3d6c47 --- /dev/null +++ b/global.d.ts @@ -0,0 +1 @@ +import 'jest-extended'; \ No newline at end of file diff --git a/jest.config.js b/jest.config.js new file mode 100644 index 0000000..1267469 --- /dev/null +++ b/jest.config.js @@ -0,0 +1,11 @@ +/** @type {import('ts-jest/dist/types').InitialOptionsTsJest} */ +module.exports = { + preset: 'ts-jest', + testEnvironment: 'node', + setupFilesAfterEnv: ["jest-extended/all"], + globals: { + 'ts-jest': { + isolatedModules: true + } + } +}; \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index 74c4ce9..a11feb0 100644 --- a/package-lock.json +++ b/package-lock.json @@ -13,13 +13,13 @@ "s-expression": "^3.1.1" }, "devDependencies": { - "@types/chai": "^4.3.0", - "@types/mocha": "^9.1.0", + "@types/jest": "^27.4.1", "@types/node": "^17.0.21", "@types/ramda": "^0.28.1", - "chai": "^4.3.6", - "mocha": "^9.2.2", + "jest": "^27.5.1", + "jest-extended": "^2.0.0", "nyc": "^15.1.0", + "ts-jest": "^27.1.3", "ts-node": "^10.7.0", "typescript": "^4.6.2" } @@ -200,6 +200,15 @@ "node": ">=6.9.0" } }, + "node_modules/@babel/helper-plugin-utils": { + "version": "7.16.7", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.16.7.tgz", + "integrity": "sha512-Qg3Nk7ZxpgMrsox6HreY1ZNKdBq7K72tDSliA6dCl5f007jR4ne8iD5UzuNnCJH2xBf2BEEVGr+/OL6Gdp7RxA==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, "node_modules/@babel/helper-simple-access": { "version": "7.16.7", "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.16.7.tgz", @@ -353,6 +362,168 @@ "node": ">=6.0.0" } }, + "node_modules/@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-bigint": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", + "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-class-properties": { + "version": "7.12.13", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", + "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.12.13" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-import-meta": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", + "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-logical-assignment-operators": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", + "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", + "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-numeric-separator": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", + "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", + "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", + "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-optional-chaining": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", + "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-top-level-await": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", + "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-typescript": { + "version": "7.16.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.16.7.tgz", + "integrity": "sha512-YhUIJHHGkqPgEcMYkPCKTyGUdoGKWtopIycQyjJH8OjvRgOYsXsaKehLVPScKJWAULPxMa4N1vCe6szREFlZ7A==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.16.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, "node_modules/@babel/template": { "version": "7.16.7", "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.16.7.tgz", @@ -401,6 +572,12 @@ "node": ">=6.9.0" } }, + "node_modules/@bcoe/v8-coverage": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", + "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", + "dev": true + }, "node_modules/@cspotcode/source-map-consumer": { "version": "0.8.0", "resolved": "https://registry.npmjs.org/@cspotcode/source-map-consumer/-/source-map-consumer-0.8.0.tgz", @@ -521,6 +698,289 @@ "node": ">=8" } }, + "node_modules/@jest/console": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/console/-/console-27.5.1.tgz", + "integrity": "sha512-kZ/tNpS3NXn0mlXXXPNuDZnb4c0oZ20r4K5eemM2k30ZC3G0T02nXUvyhf5YdbXWHPEJLc9qGLxEZ216MdL+Zg==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "jest-message-util": "^27.5.1", + "jest-util": "^27.5.1", + "slash": "^3.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/core": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/core/-/core-27.5.1.tgz", + "integrity": "sha512-AK6/UTrvQD0Cd24NSqmIA6rKsu0tKIxfiCducZvqxYdmMisOYAsdItspT+fQDQYARPf8XgjAFZi0ogW2agH5nQ==", + "dev": true, + "dependencies": { + "@jest/console": "^27.5.1", + "@jest/reporters": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "ansi-escapes": "^4.2.1", + "chalk": "^4.0.0", + "emittery": "^0.8.1", + "exit": "^0.1.2", + "graceful-fs": "^4.2.9", + "jest-changed-files": "^27.5.1", + "jest-config": "^27.5.1", + "jest-haste-map": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-resolve-dependencies": "^27.5.1", + "jest-runner": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "jest-watcher": "^27.5.1", + "micromatch": "^4.0.4", + "rimraf": "^3.0.0", + "slash": "^3.0.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" + }, + "peerDependenciesMeta": { + "node-notifier": { + "optional": true + } + } + }, + "node_modules/@jest/environment": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-27.5.1.tgz", + "integrity": "sha512-/WQjhPJe3/ghaol/4Bq480JKXV/Rfw8nQdN7f41fM8VDHLcxKXou6QyXAh3EFr9/bVG3x74z1NWDkP87EiY8gA==", + "dev": true, + "dependencies": { + "@jest/fake-timers": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "jest-mock": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/fake-timers": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-27.5.1.tgz", + "integrity": "sha512-/aPowoolwa07k7/oM3aASneNeBGCmGQsc3ugN4u6s4C/+s5M64MFo/+djTdiwcbQlRfFElGuDXWzaWj6QgKObQ==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "@sinonjs/fake-timers": "^8.0.1", + "@types/node": "*", + "jest-message-util": "^27.5.1", + "jest-mock": "^27.5.1", + "jest-util": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/globals": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-27.5.1.tgz", + "integrity": "sha512-ZEJNB41OBQQgGzgyInAv0UUfDDj3upmHydjieSxFvTRuZElrx7tXg/uVQ5hYVEwiXs3+aMsAeEc9X7xiSKCm4Q==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/types": "^27.5.1", + "expect": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/reporters": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-27.5.1.tgz", + "integrity": "sha512-cPXh9hWIlVJMQkVk84aIvXuBB4uQQmFqZiacloFuGiP3ah1sbCxCosidXFDfqG8+6fO1oR2dTJTlsOy4VFmUfw==", + "dev": true, + "dependencies": { + "@bcoe/v8-coverage": "^0.2.3", + "@jest/console": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "collect-v8-coverage": "^1.0.0", + "exit": "^0.1.2", + "glob": "^7.1.2", + "graceful-fs": "^4.2.9", + "istanbul-lib-coverage": "^3.0.0", + "istanbul-lib-instrument": "^5.1.0", + "istanbul-lib-report": "^3.0.0", + "istanbul-lib-source-maps": "^4.0.0", + "istanbul-reports": "^3.1.3", + "jest-haste-map": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-util": "^27.5.1", + "jest-worker": "^27.5.1", + "slash": "^3.0.0", + "source-map": "^0.6.0", + "string-length": "^4.0.1", + "terminal-link": "^2.0.0", + "v8-to-istanbul": "^8.1.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" + }, + "peerDependenciesMeta": { + "node-notifier": { + "optional": true + } + } + }, + "node_modules/@jest/reporters/node_modules/istanbul-lib-instrument": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.1.0.tgz", + "integrity": "sha512-czwUz525rkOFDJxfKK6mYfIs9zBKILyrZQxjz3ABhjQXhbhFsSbo1HW/BFcsDnfJYJWA6thRR5/TUY2qs5W99Q==", + "dev": true, + "dependencies": { + "@babel/core": "^7.12.3", + "@babel/parser": "^7.14.7", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-coverage": "^3.2.0", + "semver": "^6.3.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/@jest/reporters/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/@jest/source-map": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-27.5.1.tgz", + "integrity": "sha512-y9NIHUYF3PJRlHk98NdC/N1gl88BL08aQQgu4k4ZopQkCw9t9cV8mtl3TV8b/YCB8XaVTFrmUTAJvjsntDireg==", + "dev": true, + "dependencies": { + "callsites": "^3.0.0", + "graceful-fs": "^4.2.9", + "source-map": "^0.6.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/source-map/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/@jest/test-result": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-27.5.1.tgz", + "integrity": "sha512-EW35l2RYFUcUQxFJz5Cv5MTOxlJIQs4I7gxzi2zVU7PJhOwfYq1MdC5nhSmYjX1gmMmLPvB3sIaC+BkcHRBfag==", + "dev": true, + "dependencies": { + "@jest/console": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/istanbul-lib-coverage": "^2.0.0", + "collect-v8-coverage": "^1.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/test-sequencer": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-27.5.1.tgz", + "integrity": "sha512-LCheJF7WB2+9JuCS7VB/EmGIdQuhtqjRNI9A43idHv3E4KltCTsPsLxvdaubFHSYwY/fNjMWjl6vNRhDiN7vpQ==", + "dev": true, + "dependencies": { + "@jest/test-result": "^27.5.1", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-runtime": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/transform": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-27.5.1.tgz", + "integrity": "sha512-ipON6WtYgl/1329g5AIJVbUuEh0wZVbdpGwC99Jw4LwuoBNS95MVphU6zOeD9pDkon+LLbFL7lOQRapbB8SCHw==", + "dev": true, + "dependencies": { + "@babel/core": "^7.1.0", + "@jest/types": "^27.5.1", + "babel-plugin-istanbul": "^6.1.1", + "chalk": "^4.0.0", + "convert-source-map": "^1.4.0", + "fast-json-stable-stringify": "^2.0.0", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-util": "^27.5.1", + "micromatch": "^4.0.4", + "pirates": "^4.0.4", + "slash": "^3.0.0", + "source-map": "^0.6.1", + "write-file-atomic": "^3.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/@jest/transform/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/@jest/types": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-27.5.1.tgz", + "integrity": "sha512-Cx46iJ9QpwQTjIdq5VJu2QTMMs3QlEjI0x1QbBP5W1+nMzyc2XmimiRR/CbX9TO0cPTeUlxWMOu8mslYsJ8DEw==", + "dev": true, + "dependencies": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^3.0.0", + "@types/node": "*", + "@types/yargs": "^16.0.0", + "chalk": "^4.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, "node_modules/@jridgewell/resolve-uri": { "version": "3.0.5", "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.0.5.tgz", @@ -546,6 +1006,33 @@ "@jridgewell/sourcemap-codec": "^1.4.10" } }, + "node_modules/@sinonjs/commons": { + "version": "1.8.3", + "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.3.tgz", + "integrity": "sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ==", + "dev": true, + "dependencies": { + "type-detect": "4.0.8" + } + }, + "node_modules/@sinonjs/fake-timers": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-8.1.0.tgz", + "integrity": "sha512-OAPJUAtgeINhh/TAlUID4QTs53Njm7xzddaVlEs/SXwgtiD1tW22zAB/W1wdqfrpmikgaWQ9Fw6Ws+hsiRm5Vg==", + "dev": true, + "dependencies": { + "@sinonjs/commons": "^1.7.0" + } + }, + "node_modules/@tootallnate/once": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", + "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", + "dev": true, + "engines": { + "node": ">= 6" + } + }, "node_modules/@tsconfig/node10": { "version": "1.0.8", "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.8.tgz", @@ -570,40 +1057,139 @@ "integrity": "sha512-eZxlbI8GZscaGS7kkc/trHTT5xgrjH3/1n2JDwusC9iahPKWMRvRjJSAN5mCXviuTGQ/lHnhvv8Q1YTpnfz9gA==", "dev": true }, - "node_modules/@types/chai": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.0.tgz", - "integrity": "sha512-/ceqdqeRraGolFTcfoXNiqjyQhZzbINDngeoAq9GoHa8PPK1yNzTaxWjA6BFWp5Ua9JpXEMSS4s5i9tS0hOJtw==", - "dev": true - }, - "node_modules/@types/mocha": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.1.0.tgz", - "integrity": "sha512-QCWHkbMv4Y5U9oW10Uxbr45qMMSzl4OzijsozynUAgx3kEHUdXB00udx2dWDQ7f2TU2a2uuiFaRZjCe3unPpeg==", - "dev": true + "node_modules/@types/babel__core": { + "version": "7.1.18", + "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.18.tgz", + "integrity": "sha512-S7unDjm/C7z2A2R9NzfKCK1I+BAALDtxEmsJBwlB3EzNfb929ykjL++1CK9LO++EIp2fQrC8O+BwjKvz6UeDyQ==", + "dev": true, + "dependencies": { + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0", + "@types/babel__generator": "*", + "@types/babel__template": "*", + "@types/babel__traverse": "*" + } }, - "node_modules/@types/node": { - "version": "17.0.21", - "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.21.tgz", - "integrity": "sha512-DBZCJbhII3r90XbQxI8Y9IjjiiOGlZ0Hr32omXIZvwwZ7p4DMMXGrKXVyPfuoBOri9XNtL0UK69jYIBIsRX3QQ==", - "dev": true + "node_modules/@types/babel__generator": { + "version": "7.6.4", + "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz", + "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==", + "dev": true, + "dependencies": { + "@babel/types": "^7.0.0" + } }, - "node_modules/@types/ramda": { - "version": "0.28.1", - "resolved": "https://registry.npmjs.org/@types/ramda/-/ramda-0.28.1.tgz", - "integrity": "sha512-8wnJK5aPaGL7AYhQSe7olwxjhIB9GO4GOCxd6JjYlVNe128DHJDOu7Kyve4kx4uazeKJdnOS3N5TVRv0z1bb1g==", + "node_modules/@types/babel__template": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz", + "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==", "dev": true, "dependencies": { - "ts-toolbelt": "^6.15.1" + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0" } }, - "node_modules/@ungap/promise-all-settled": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", - "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", - "dev": true + "node_modules/@types/babel__traverse": { + "version": "7.14.2", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.14.2.tgz", + "integrity": "sha512-K2waXdXBi2302XUdcHcR1jCeU0LL4TD9HRs/gk0N2Xvrht+G/BfJa4QObBQZfhMdxiCpV3COl5Nfq4uKTeTnJA==", + "dev": true, + "dependencies": { + "@babel/types": "^7.3.0" + } }, - "node_modules/acorn": { + "node_modules/@types/graceful-fs": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.5.tgz", + "integrity": "sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "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==", + "dev": true + }, + "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==", + "dev": true, + "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==", + "dev": true, + "dependencies": { + "@types/istanbul-lib-report": "*" + } + }, + "node_modules/@types/jest": { + "version": "27.4.1", + "resolved": "https://registry.npmjs.org/@types/jest/-/jest-27.4.1.tgz", + "integrity": "sha512-23iPJADSmicDVrWk+HT58LMJtzLAnB2AgIzplQuq/bSrGaxCrlvRFjGbXmamnnk/mAmCdLStiGqggu28ocUyiw==", + "dev": true, + "dependencies": { + "jest-matcher-utils": "^27.0.0", + "pretty-format": "^27.0.0" + } + }, + "node_modules/@types/node": { + "version": "17.0.21", + "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.21.tgz", + "integrity": "sha512-DBZCJbhII3r90XbQxI8Y9IjjiiOGlZ0Hr32omXIZvwwZ7p4DMMXGrKXVyPfuoBOri9XNtL0UK69jYIBIsRX3QQ==", + "dev": true + }, + "node_modules/@types/prettier": { + "version": "2.4.4", + "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.4.4.tgz", + "integrity": "sha512-ReVR2rLTV1kvtlWFyuot+d1pkpG2Fw/XKE3PDAdj57rbM97ttSp9JZ2UsP+2EHTylra9cUf6JA7tGwW1INzUrA==", + "dev": true + }, + "node_modules/@types/ramda": { + "version": "0.28.1", + "resolved": "https://registry.npmjs.org/@types/ramda/-/ramda-0.28.1.tgz", + "integrity": "sha512-8wnJK5aPaGL7AYhQSe7olwxjhIB9GO4GOCxd6JjYlVNe128DHJDOu7Kyve4kx4uazeKJdnOS3N5TVRv0z1bb1g==", + "dev": true, + "dependencies": { + "ts-toolbelt": "^6.15.1" + } + }, + "node_modules/@types/stack-utils": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", + "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", + "dev": true + }, + "node_modules/@types/yargs": { + "version": "16.0.4", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz", + "integrity": "sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw==", + "dev": true, + "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==", + "dev": true + }, + "node_modules/abab": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.5.tgz", + "integrity": "sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q==", + "dev": true + }, + "node_modules/acorn": { "version": "8.7.0", "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.0.tgz", "integrity": "sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==", @@ -615,6 +1201,37 @@ "node": ">=0.4.0" } }, + "node_modules/acorn-globals": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-6.0.0.tgz", + "integrity": "sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg==", + "dev": true, + "dependencies": { + "acorn": "^7.1.1", + "acorn-walk": "^7.1.1" + } + }, + "node_modules/acorn-globals/node_modules/acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true, + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-globals/node_modules/acorn-walk": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", + "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==", + "dev": true, + "engines": { + "node": ">=0.4.0" + } + }, "node_modules/acorn-walk": { "version": "8.2.0", "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", @@ -624,6 +1241,18 @@ "node": ">=0.4.0" } }, + "node_modules/agent-base": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", + "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", + "dev": true, + "dependencies": { + "debug": "4" + }, + "engines": { + "node": ">= 6.0.0" + } + }, "node_modules/aggregate-error": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", @@ -637,13 +1266,31 @@ "node": ">=8" } }, - "node_modules/ansi-colors": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", - "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", + "node_modules/ansi-escapes": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", + "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", "dev": true, + "dependencies": { + "type-fest": "^0.21.3" + }, "engines": { - "node": ">=6" + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ansi-escapes/node_modules/type-fest": { + "version": "0.21.3", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", + "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/ansi-regex": { @@ -707,36 +1354,126 @@ "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", "dev": true }, - "node_modules/argparse": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", - "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", "dev": true }, - "node_modules/assertion-error": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", - "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", + "node_modules/babel-jest": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-27.5.1.tgz", + "integrity": "sha512-cdQ5dXjGRd0IBRATiQ4mZGlGlRE8kJpjPOixdNRdT+m3UcNqmYWN6rK6nvtXYfY3D76cb8s/O1Ss8ea24PIwcg==", "dev": true, + "dependencies": { + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/babel__core": "^7.1.14", + "babel-plugin-istanbul": "^6.1.1", + "babel-preset-jest": "^27.5.1", + "chalk": "^4.0.0", + "graceful-fs": "^4.2.9", + "slash": "^3.0.0" + }, "engines": { - "node": "*" + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "@babel/core": "^7.8.0" } }, - "node_modules/balanced-match": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", - "dev": true + "node_modules/babel-plugin-istanbul": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", + "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.0.0", + "@istanbuljs/load-nyc-config": "^1.0.0", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-instrument": "^5.0.4", + "test-exclude": "^6.0.0" + }, + "engines": { + "node": ">=8" + } }, - "node_modules/binary-extensions": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", - "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", + "node_modules/babel-plugin-istanbul/node_modules/istanbul-lib-instrument": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.1.0.tgz", + "integrity": "sha512-czwUz525rkOFDJxfKK6mYfIs9zBKILyrZQxjz3ABhjQXhbhFsSbo1HW/BFcsDnfJYJWA6thRR5/TUY2qs5W99Q==", "dev": true, + "dependencies": { + "@babel/core": "^7.12.3", + "@babel/parser": "^7.14.7", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-coverage": "^3.2.0", + "semver": "^6.3.0" + }, "engines": { "node": ">=8" } }, + "node_modules/babel-plugin-jest-hoist": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-27.5.1.tgz", + "integrity": "sha512-50wCwD5EMNW4aRpOwtqzyZHIewTYNxLA4nhB+09d8BIssfNfzBRhkBIHiaPv1Si226TQSvp8gxAJm2iY2qs2hQ==", + "dev": true, + "dependencies": { + "@babel/template": "^7.3.3", + "@babel/types": "^7.3.3", + "@types/babel__core": "^7.0.0", + "@types/babel__traverse": "^7.0.6" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/babel-preset-current-node-syntax": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", + "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", + "dev": true, + "dependencies": { + "@babel/plugin-syntax-async-generators": "^7.8.4", + "@babel/plugin-syntax-bigint": "^7.8.3", + "@babel/plugin-syntax-class-properties": "^7.8.3", + "@babel/plugin-syntax-import-meta": "^7.8.3", + "@babel/plugin-syntax-json-strings": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.8.3", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.3", + "@babel/plugin-syntax-top-level-await": "^7.8.3" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/babel-preset-jest": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-27.5.1.tgz", + "integrity": "sha512-Nptf2FzlPCWYuJg41HBqXVT8ym6bXOevuCTbhxlUpjwtysGaIWFvDEjp4y+G7fl13FgOdjs7P/DmErqH7da0Ag==", + "dev": true, + "dependencies": { + "babel-plugin-jest-hoist": "^27.5.1", + "babel-preset-current-node-syntax": "^1.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, "node_modules/brace-expansion": { "version": "1.1.11", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", @@ -759,10 +1496,10 @@ "node": ">=8" } }, - "node_modules/browser-stdout": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", - "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", + "node_modules/browser-process-hrtime": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", + "integrity": "sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==", "dev": true }, "node_modules/browserslist": { @@ -788,6 +1525,33 @@ "url": "https://opencollective.com/browserslist" } }, + "node_modules/bs-logger": { + "version": "0.2.6", + "resolved": "https://registry.npmjs.org/bs-logger/-/bs-logger-0.2.6.tgz", + "integrity": "sha512-pd8DCoxmbgc7hyPKOvxtqNcjYoOsABPQdcCUjGp3d42VR2CX1ORhk2A87oqqu5R1kk+76nsxZupkmyd+MVtCog==", + "dev": true, + "dependencies": { + "fast-json-stable-stringify": "2.x" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/bser": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", + "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", + "dev": true, + "dependencies": { + "node-int64": "^0.4.0" + } + }, + "node_modules/buffer-from": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", + "dev": true + }, "node_modules/caching-transform": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/caching-transform/-/caching-transform-4.0.0.tgz", @@ -803,6 +1567,15 @@ "node": ">=8" } }, + "node_modules/callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, "node_modules/camelcase": { "version": "5.3.1", "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", @@ -822,24 +1595,6 @@ "url": "https://opencollective.com/browserslist" } }, - "node_modules/chai": { - "version": "4.3.6", - "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.6.tgz", - "integrity": "sha512-bbcp3YfHCUzMOvKqsztczerVgBKSsEijCySNlHHbX3VG1nskvqjz5Rfso1gGwD6w6oOV3eI60pKuMOV5MV7p3Q==", - "dev": true, - "dependencies": { - "assertion-error": "^1.1.0", - "check-error": "^1.0.2", - "deep-eql": "^3.0.1", - "get-func-name": "^2.0.0", - "loupe": "^2.3.1", - "pathval": "^1.1.1", - "type-detect": "^4.0.5" - }, - "engines": { - "node": ">=4" - } - }, "node_modules/chalk": { "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", @@ -868,41 +1623,26 @@ "node": ">=8" } }, - "node_modules/check-error": { + "node_modules/char-regex": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", - "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", + "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", + "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", "dev": true, "engines": { - "node": "*" + "node": ">=10" } }, - "node_modules/chokidar": { - "version": "3.5.3", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", - "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ], - "dependencies": { - "anymatch": "~3.1.2", - "braces": "~3.0.2", - "glob-parent": "~5.1.2", - "is-binary-path": "~2.1.0", - "is-glob": "~4.0.1", - "normalize-path": "~3.0.0", - "readdirp": "~3.6.0" - }, - "engines": { - "node": ">= 8.10.0" - }, - "optionalDependencies": { - "fsevents": "~2.3.2" - } + "node_modules/ci-info": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.3.0.tgz", + "integrity": "sha512-riT/3vI5YpVH6/qomlDnJow6TBee2PBKSEpx3O32EGPYbWGIRsIlGRms3Sm74wYE1JMo8RnO04Hb12+v1J5ICw==", + "dev": true + }, + "node_modules/cjs-module-lexer": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz", + "integrity": "sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA==", + "dev": true }, "node_modules/clean-stack": { "version": "2.2.0", @@ -924,6 +1664,22 @@ "wrap-ansi": "^7.0.0" } }, + "node_modules/co": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", + "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", + "dev": true, + "engines": { + "iojs": ">= 1.0.0", + "node": ">= 0.12.0" + } + }, + "node_modules/collect-v8-coverage": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz", + "integrity": "sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg==", + "dev": true + }, "node_modules/color-convert": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", @@ -942,6 +1698,18 @@ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", "dev": true }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dev": true, + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, "node_modules/commondir": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", @@ -983,6 +1751,44 @@ "node": ">= 8" } }, + "node_modules/cssom": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.4.4.tgz", + "integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw==", + "dev": true + }, + "node_modules/cssstyle": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.3.0.tgz", + "integrity": "sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==", + "dev": true, + "dependencies": { + "cssom": "~0.3.6" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cssstyle/node_modules/cssom": { + "version": "0.3.8", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", + "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==", + "dev": true + }, + "node_modules/data-urls": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-2.0.0.tgz", + "integrity": "sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ==", + "dev": true, + "dependencies": { + "abab": "^2.0.3", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^8.0.0" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/debug": { "version": "4.3.3", "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", @@ -1015,16 +1821,31 @@ "node": ">=0.10.0" } }, - "node_modules/deep-eql": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", - "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", + "node_modules/decimal.js": { + "version": "10.3.1", + "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.3.1.tgz", + "integrity": "sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ==", + "dev": true + }, + "node_modules/dedent": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", + "integrity": "sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw=", + "dev": true + }, + "node_modules/deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true + }, + "node_modules/deepmerge": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz", + "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==", "dev": true, - "dependencies": { - "type-detect": "^4.0.0" - }, "engines": { - "node": ">=0.12" + "node": ">=0.10.0" } }, "node_modules/default-require-extensions": { @@ -1039,28 +1860,88 @@ "node": ">=8" } }, - "node_modules/diff": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", - "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", "dev": true, "engines": { - "node": ">=0.3.1" + "node": ">=0.4.0" } }, - "node_modules/electron-to-chromium": { - "version": "1.4.82", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.82.tgz", - "integrity": "sha512-Ks+ANzLoIrFDUOJdjxYMH6CMKB8UQo5modAwvSZTxgF+vEs/U7G5IbWFUp6dS4klPkTDVdxbORuk8xAXXhMsWw==", - "dev": true - }, - "node_modules/emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true + "node_modules/detect-newline": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", + "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", + "dev": true, + "engines": { + "node": ">=8" + } }, - "node_modules/es6-error": { + "node_modules/diff-sequences": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-27.5.1.tgz", + "integrity": "sha512-k1gCAXAsNgLwEL+Y8Wvl+M6oEFj5bgazfZULpS5CneoPPXRaCCW7dm+q21Ky2VEE5X+VeRDBVg1Pcvvsr4TtNQ==", + "dev": true, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/domexception": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/domexception/-/domexception-2.0.1.tgz", + "integrity": "sha512-yxJ2mFy/sibVQlu5qHjOkf9J3K6zgmCxgJ94u2EdvDOV09H+32LtRswEcUsmUWN72pVLOEnTSRaIVVzVQgS0dg==", + "dev": true, + "dependencies": { + "webidl-conversions": "^5.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/domexception/node_modules/webidl-conversions": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-5.0.0.tgz", + "integrity": "sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/electron-to-chromium": { + "version": "1.4.82", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.82.tgz", + "integrity": "sha512-Ks+ANzLoIrFDUOJdjxYMH6CMKB8UQo5modAwvSZTxgF+vEs/U7G5IbWFUp6dS4klPkTDVdxbORuk8xAXXhMsWw==", + "dev": true + }, + "node_modules/emittery": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.8.1.tgz", + "integrity": "sha512-uDfvUjVrfGJJhymx/kz6prltenw1u7WrCg1oa94zYY8xxVpLLUu045LAT0dhDZdXG58/EpPL/5kA180fQ/qudg==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sindresorhus/emittery?sponsor=1" + } + }, + "node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "dependencies": { + "is-arrayish": "^0.2.1" + } + }, + "node_modules/es6-error": { "version": "4.1.1", "resolved": "https://registry.npmjs.org/es6-error/-/es6-error-4.1.1.tgz", "integrity": "sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==", @@ -1075,16 +1956,36 @@ "node": ">=6" } }, - "node_modules/escape-string-regexp": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", - "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "node_modules/escodegen": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.0.0.tgz", + "integrity": "sha512-mmHKys/C8BFUGI+MAWNcSYoORYLMdPzjrknd2Vc+bUsjN5bXcr8EhrNB+UTqfL1y3I9c4fw2ihgtMPQLBRiQxw==", "dev": true, + "dependencies": { + "esprima": "^4.0.1", + "estraverse": "^5.2.0", + "esutils": "^2.0.2", + "optionator": "^0.8.1" + }, + "bin": { + "escodegen": "bin/escodegen.js", + "esgenerate": "bin/esgenerate.js" + }, "engines": { - "node": ">=10" + "node": ">=6.0" }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "optionalDependencies": { + "source-map": "~0.6.1" + } + }, + "node_modules/escodegen/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "optional": true, + "engines": { + "node": ">=0.10.0" } }, "node_modules/esprima": { @@ -1100,6 +2001,92 @@ "node": ">=4" } }, + "node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/execa": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", + "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", + "dev": true, + "dependencies": { + "cross-spawn": "^7.0.3", + "get-stream": "^6.0.0", + "human-signals": "^2.1.0", + "is-stream": "^2.0.0", + "merge-stream": "^2.0.0", + "npm-run-path": "^4.0.1", + "onetime": "^5.1.2", + "signal-exit": "^3.0.3", + "strip-final-newline": "^2.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sindresorhus/execa?sponsor=1" + } + }, + "node_modules/exit": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", + "integrity": "sha1-BjJjj42HfMghB9MKD/8aF8uhzQw=", + "dev": true, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/expect": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/expect/-/expect-27.5.1.tgz", + "integrity": "sha512-E1q5hSUG2AmYQwQJ041nvgpkODHQvB+RKlB4IYdru6uJsyFTRyZAP463M+1lINorwbqAmUggi6+WwkD8lCS/Dw==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "jest-get-type": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true + }, + "node_modules/fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", + "dev": true + }, + "node_modules/fb-watchman": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.1.tgz", + "integrity": "sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg==", + "dev": true, + "dependencies": { + "bser": "2.1.1" + } + }, "node_modules/fill-range": { "version": "7.0.1", "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", @@ -1129,31 +2116,6 @@ "url": "https://github.com/avajs/find-cache-dir?sponsor=1" } }, - "node_modules/find-up": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", - "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", - "dev": true, - "dependencies": { - "locate-path": "^6.0.0", - "path-exists": "^4.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/flat": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", - "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", - "dev": true, - "bin": { - "flat": "cli.js" - } - }, "node_modules/foreground-child": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", @@ -1167,6 +2129,20 @@ "node": ">=8.0.0" } }, + "node_modules/form-data": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", + "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", + "dev": true, + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, "node_modules/fromentries": { "version": "1.3.2", "resolved": "https://registry.npmjs.org/fromentries/-/fromentries-1.3.2.tgz", @@ -1207,6 +2183,12 @@ "node": "^8.16.0 || ^10.6.0 || >=11.0.0" } }, + "node_modules/function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", + "dev": true + }, "node_modules/gensync": { "version": "1.0.0-beta.2", "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", @@ -1225,15 +2207,6 @@ "node": "6.* || 8.* || >= 10.*" } }, - "node_modules/get-func-name": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", - "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", - "dev": true, - "engines": { - "node": "*" - } - }, "node_modules/get-package-type": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", @@ -1243,6 +2216,18 @@ "node": ">=8.0.0" } }, + "node_modules/get-stream": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", + "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/glob": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", @@ -1263,18 +2248,6 @@ "url": "https://github.com/sponsors/isaacs" } }, - "node_modules/glob-parent": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", - "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", - "dev": true, - "dependencies": { - "is-glob": "^4.0.1" - }, - "engines": { - "node": ">= 6" - } - }, "node_modules/glob/node_modules/minimatch": { "version": "3.1.2", "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", @@ -1302,13 +2275,16 @@ "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", "dev": true }, - "node_modules/growl": { - "version": "1.10.5", - "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", - "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", + "node_modules/has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", "dev": true, + "dependencies": { + "function-bind": "^1.1.1" + }, "engines": { - "node": ">=4.x" + "node": ">= 0.4.0" } }, "node_modules/has-flag": { @@ -1336,13 +2312,16 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/he": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", - "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", + "node_modules/html-encoding-sniffer": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-2.0.1.tgz", + "integrity": "sha512-D5JbOMBIR/TVZkubHT+OyT2705QvogUW4IBn6nHd756OwieSF9aDYFj4dv6HHEVGYbHaLETa3WggZYWWMyy3ZQ==", "dev": true, - "bin": { - "he": "bin/he" + "dependencies": { + "whatwg-encoding": "^1.0.5" + }, + "engines": { + "node": ">=10" } }, "node_modules/html-escaper": { @@ -1351,6 +2330,73 @@ "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", "dev": true }, + "node_modules/http-proxy-agent": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", + "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", + "dev": true, + "dependencies": { + "@tootallnate/once": "1", + "agent-base": "6", + "debug": "4" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/https-proxy-agent": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", + "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", + "dev": true, + "dependencies": { + "agent-base": "6", + "debug": "4" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/human-signals": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", + "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", + "dev": true, + "engines": { + "node": ">=10.17.0" + } + }, + "node_modules/iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dev": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/import-local": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", + "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", + "dev": true, + "dependencies": { + "pkg-dir": "^4.2.0", + "resolve-cwd": "^3.0.0" + }, + "bin": { + "import-local-fixture": "fixtures/cli.js" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/imurmurhash": { "version": "0.1.4", "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", @@ -1385,25 +2431,22 @@ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", "dev": true }, - "node_modules/is-binary-path": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", - "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "node_modules/is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", + "dev": true + }, + "node_modules/is-core-module": { + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", + "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", "dev": true, "dependencies": { - "binary-extensions": "^2.0.0" + "has": "^1.0.3" }, - "engines": { - "node": ">=8" - } - }, - "node_modules/is-extglob": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", - "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", - "dev": true, - "engines": { - "node": ">=0.10.0" + "funding": { + "url": "https://github.com/sponsors/ljharb" } }, "node_modules/is-fullwidth-code-point": { @@ -1415,16 +2458,13 @@ "node": ">=8" } }, - "node_modules/is-glob": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", - "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "node_modules/is-generator-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", + "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", "dev": true, - "dependencies": { - "is-extglob": "^2.1.1" - }, "engines": { - "node": ">=0.10.0" + "node": ">=6" } }, "node_modules/is-number": { @@ -1436,14 +2476,11 @@ "node": ">=0.12.0" } }, - "node_modules/is-plain-obj": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", - "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", - "dev": true, - "engines": { - "node": ">=8" - } + "node_modules/is-potential-custom-element-name": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz", + "integrity": "sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==", + "dev": true }, "node_modules/is-stream": { "version": "2.0.1", @@ -1463,18 +2500,6 @@ "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", "dev": true }, - "node_modules/is-unicode-supported": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", - "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/is-windows": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", @@ -1606,36 +2631,705 @@ "node": ">=8" } }, - "node_modules/js-tokens": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", - "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", - "dev": true - }, - "node_modules/js-yaml": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", - "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "node_modules/jest": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest/-/jest-27.5.1.tgz", + "integrity": "sha512-Yn0mADZB89zTtjkPJEXwrac3LHudkQMR+Paqa8uxJHCBr9agxztUifWCyiYrjhMPBoUVBjyny0I7XH6ozDr7QQ==", "dev": true, "dependencies": { - "argparse": "^2.0.1" + "@jest/core": "^27.5.1", + "import-local": "^3.0.2", + "jest-cli": "^27.5.1" }, "bin": { - "js-yaml": "bin/js-yaml.js" - } - }, - "node_modules/jsesc": { - "version": "2.5.2", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", - "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", - "dev": true, - "bin": { - "jsesc": "bin/jsesc" + "jest": "bin/jest.js" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" + }, + "peerDependenciesMeta": { + "node-notifier": { + "optional": true + } + } + }, + "node_modules/jest-changed-files": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-27.5.1.tgz", + "integrity": "sha512-buBLMiByfWGCoMsLLzGUUSpAmIAGnbR2KJoMN10ziLhOLvP4e0SlypHnAel8iqQXTrcbmfEY9sSqae5sgUsTvw==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "execa": "^5.0.0", + "throat": "^6.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-circus": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-27.5.1.tgz", + "integrity": "sha512-D95R7x5UtlMA5iBYsOHFFbMD/GVA4R/Kdq15f7xYWUfWHBto9NYRsOvnSauTgdF+ogCpJ4tyKOXhUifxS65gdw==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "co": "^4.6.0", + "dedent": "^0.7.0", + "expect": "^27.5.1", + "is-generator-fn": "^2.0.0", + "jest-each": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "pretty-format": "^27.5.1", + "slash": "^3.0.0", + "stack-utils": "^2.0.3", + "throat": "^6.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-cli": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-27.5.1.tgz", + "integrity": "sha512-Hc6HOOwYq4/74/c62dEE3r5elx8wjYqxY0r0G/nFrLDPMFRu6RA/u8qINOIkvhxG7mMQ5EJsOGfRpI8L6eFUVw==", + "dev": true, + "dependencies": { + "@jest/core": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "exit": "^0.1.2", + "graceful-fs": "^4.2.9", + "import-local": "^3.0.2", + "jest-config": "^27.5.1", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "prompts": "^2.0.1", + "yargs": "^16.2.0" + }, + "bin": { + "jest": "bin/jest.js" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" + }, + "peerDependenciesMeta": { + "node-notifier": { + "optional": true + } + } + }, + "node_modules/jest-config": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-27.5.1.tgz", + "integrity": "sha512-5sAsjm6tGdsVbW9ahcChPAFCk4IlkQUknH5AvKjuLTSlcO/wCZKyFdn7Rg0EkC+OGgWODEy2hDpWB1PgzH0JNA==", + "dev": true, + "dependencies": { + "@babel/core": "^7.8.0", + "@jest/test-sequencer": "^27.5.1", + "@jest/types": "^27.5.1", + "babel-jest": "^27.5.1", + "chalk": "^4.0.0", + "ci-info": "^3.2.0", + "deepmerge": "^4.2.2", + "glob": "^7.1.1", + "graceful-fs": "^4.2.9", + "jest-circus": "^27.5.1", + "jest-environment-jsdom": "^27.5.1", + "jest-environment-node": "^27.5.1", + "jest-get-type": "^27.5.1", + "jest-jasmine2": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-runner": "^27.5.1", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "micromatch": "^4.0.4", + "parse-json": "^5.2.0", + "pretty-format": "^27.5.1", + "slash": "^3.0.0", + "strip-json-comments": "^3.1.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "ts-node": ">=9.0.0" + }, + "peerDependenciesMeta": { + "ts-node": { + "optional": true + } + } + }, + "node_modules/jest-diff": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-27.5.1.tgz", + "integrity": "sha512-m0NvkX55LDt9T4mctTEgnZk3fmEg3NRYutvMPWM/0iPnkFj2wIeF45O1718cMSOFO1vINkqmxqD8vE37uTEbqw==", + "dev": true, + "dependencies": { + "chalk": "^4.0.0", + "diff-sequences": "^27.5.1", + "jest-get-type": "^27.5.1", + "pretty-format": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-docblock": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-27.5.1.tgz", + "integrity": "sha512-rl7hlABeTsRYxKiUfpHrQrG4e2obOiTQWfMEH3PxPjOtdsfLQO4ReWSZaQ7DETm4xu07rl4q/h4zcKXyU0/OzQ==", + "dev": true, + "dependencies": { + "detect-newline": "^3.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-each": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-27.5.1.tgz", + "integrity": "sha512-1Ff6p+FbhT/bXQnEouYy00bkNSY7OUpfIcmdl8vZ31A1UUaurOLPA8a8BbJOF2RDUElwJhmeaV7LnagI+5UwNQ==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "jest-get-type": "^27.5.1", + "jest-util": "^27.5.1", + "pretty-format": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-environment-jsdom": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-27.5.1.tgz", + "integrity": "sha512-TFBvkTC1Hnnnrka/fUb56atfDtJ9VMZ94JkjTbggl1PEpwrYtUBKMezB3inLmWqQsXYLcMwNoDQwoBTAvFfsfw==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/fake-timers": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "jest-mock": "^27.5.1", + "jest-util": "^27.5.1", + "jsdom": "^16.6.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-environment-node": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-27.5.1.tgz", + "integrity": "sha512-Jt4ZUnxdOsTGwSRAfKEnE6BcwsSPNOijjwifq5sDFSA2kesnXTvNqKHYgM0hDq3549Uf/KzdXNYn4wMZJPlFLw==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/fake-timers": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "jest-mock": "^27.5.1", + "jest-util": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-extended": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/jest-extended/-/jest-extended-2.0.0.tgz", + "integrity": "sha512-6AgjJQVaBEKGSK3FH90kOiRUWJsbzn9NWtW0pjGkAFIdH0oPilfkV/gHPJdVvJeBiqT3jMHw8TUg9pUGC1azDg==", + "dev": true, + "dependencies": { + "jest-diff": "^27.2.5", + "jest-get-type": "^27.0.6" + }, + "engines": { + "node": "^12.13.0 || ^14.15.0 || >=16.0.0" + }, + "peerDependencies": { + "jest": ">=27.2.5" + } + }, + "node_modules/jest-get-type": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-27.5.1.tgz", + "integrity": "sha512-2KY95ksYSaK7DMBWQn6dQz3kqAf3BB64y2udeG+hv4KfSOb9qwcYQstTJc1KCbsix+wLZWZYN8t7nwX3GOBLRw==", + "dev": true, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-haste-map": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-27.5.1.tgz", + "integrity": "sha512-7GgkZ4Fw4NFbMSDSpZwXeBiIbx+t/46nJ2QitkOjvwPYyZmqttu2TDSimMHP1EkPOi4xUZAN1doE5Vd25H4Jng==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "@types/graceful-fs": "^4.1.2", + "@types/node": "*", + "anymatch": "^3.0.3", + "fb-watchman": "^2.0.0", + "graceful-fs": "^4.2.9", + "jest-regex-util": "^27.5.1", + "jest-serializer": "^27.5.1", + "jest-util": "^27.5.1", + "jest-worker": "^27.5.1", + "micromatch": "^4.0.4", + "walker": "^1.0.7" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "optionalDependencies": { + "fsevents": "^2.3.2" + } + }, + "node_modules/jest-jasmine2": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-jasmine2/-/jest-jasmine2-27.5.1.tgz", + "integrity": "sha512-jtq7VVyG8SqAorDpApwiJJImd0V2wv1xzdheGHRGyuT7gZm6gG47QEskOlzsN1PG/6WNaCo5pmwMHDf3AkG2pQ==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/source-map": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "co": "^4.6.0", + "expect": "^27.5.1", + "is-generator-fn": "^2.0.0", + "jest-each": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "pretty-format": "^27.5.1", + "throat": "^6.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-leak-detector": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-27.5.1.tgz", + "integrity": "sha512-POXfWAMvfU6WMUXftV4HolnJfnPOGEu10fscNCA76KBpRRhcMN2c8d3iT2pxQS3HLbA+5X4sOUPzYO2NUyIlHQ==", + "dev": true, + "dependencies": { + "jest-get-type": "^27.5.1", + "pretty-format": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-matcher-utils": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-27.5.1.tgz", + "integrity": "sha512-z2uTx/T6LBaCoNWNFWwChLBKYxTMcGBRjAt+2SbP929/Fflb9aa5LGma654Rz8z9HLxsrUaYzxE9T/EFIL/PAw==", + "dev": true, + "dependencies": { + "chalk": "^4.0.0", + "jest-diff": "^27.5.1", + "jest-get-type": "^27.5.1", + "pretty-format": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-message-util": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-27.5.1.tgz", + "integrity": "sha512-rMyFe1+jnyAAf+NHwTclDz0eAaLkVDdKVHHBFWsBWHnnh5YeJMNWWsv7AbFYXfK3oTqvL7VTWkhNLu1jX24D+g==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.12.13", + "@jest/types": "^27.5.1", + "@types/stack-utils": "^2.0.0", + "chalk": "^4.0.0", + "graceful-fs": "^4.2.9", + "micromatch": "^4.0.4", + "pretty-format": "^27.5.1", + "slash": "^3.0.0", + "stack-utils": "^2.0.3" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-mock": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-27.5.1.tgz", + "integrity": "sha512-K4jKbY1d4ENhbrG2zuPWaQBvDly+iZ2yAW+T1fATN78hc0sInwn7wZB8XtlNnvHug5RMwV897Xm4LqmPM4e2Og==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "@types/node": "*" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-pnp-resolver": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz", + "integrity": "sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w==", + "dev": true, + "engines": { + "node": ">=6" + }, + "peerDependencies": { + "jest-resolve": "*" + }, + "peerDependenciesMeta": { + "jest-resolve": { + "optional": true + } + } + }, + "node_modules/jest-regex-util": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-27.5.1.tgz", + "integrity": "sha512-4bfKq2zie+x16okqDXjXn9ql2B0dScQu+vcwe4TvFVhkVyuWLqpZrZtXxLLWoXYgn0E87I6r6GRYHF7wFZBUvg==", + "dev": true, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-resolve": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-27.5.1.tgz", + "integrity": "sha512-FFDy8/9E6CV83IMbDpcjOhumAQPDyETnU2KZ1O98DwTnz8AOBsW/Xv3GySr1mOZdItLR+zDZ7I/UdTFbgSOVCw==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-pnp-resolver": "^1.2.2", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "resolve": "^1.20.0", + "resolve.exports": "^1.1.0", + "slash": "^3.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-resolve-dependencies": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-27.5.1.tgz", + "integrity": "sha512-QQOOdY4PE39iawDn5rzbIePNigfe5B9Z91GDD1ae/xNDlu9kaat8QQ5EKnNmVWPV54hUdxCVwwj6YMgR2O7IOg==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-snapshot": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-runner": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-27.5.1.tgz", + "integrity": "sha512-g4NPsM4mFCOwFKXO4p/H/kWGdJp9V8kURY2lX8Me2drgXqG7rrZAx5kv+5H7wtt/cdFIjhqYx1HrlqWHaOvDaQ==", + "dev": true, + "dependencies": { + "@jest/console": "^27.5.1", + "@jest/environment": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "emittery": "^0.8.1", + "graceful-fs": "^4.2.9", + "jest-docblock": "^27.5.1", + "jest-environment-jsdom": "^27.5.1", + "jest-environment-node": "^27.5.1", + "jest-haste-map": "^27.5.1", + "jest-leak-detector": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-util": "^27.5.1", + "jest-worker": "^27.5.1", + "source-map-support": "^0.5.6", + "throat": "^6.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-runtime": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-27.5.1.tgz", + "integrity": "sha512-o7gxw3Gf+H2IGt8fv0RiyE1+r83FJBRruoA+FXrlHw6xEyBsU8ugA6IPfTdVyA0w8HClpbK+DGJxH59UrNMx8A==", + "dev": true, + "dependencies": { + "@jest/environment": "^27.5.1", + "@jest/fake-timers": "^27.5.1", + "@jest/globals": "^27.5.1", + "@jest/source-map": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "cjs-module-lexer": "^1.0.0", + "collect-v8-coverage": "^1.0.0", + "execa": "^5.0.0", + "glob": "^7.1.3", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-mock": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "slash": "^3.0.0", + "strip-bom": "^4.0.0" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-serializer": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-serializer/-/jest-serializer-27.5.1.tgz", + "integrity": "sha512-jZCyo6iIxO1aqUxpuBlwTDMkzOAJS4a3eYz3YzgxxVQFwLeSA7Jfq5cbqCY+JLvTDrWirgusI/0KwxKMgrdf7w==", + "dev": true, + "dependencies": { + "@types/node": "*", + "graceful-fs": "^4.2.9" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-snapshot": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-27.5.1.tgz", + "integrity": "sha512-yYykXI5a0I31xX67mgeLw1DZ0bJB+gpq5IpSuCAoyDi0+BhgU/RIrL+RTzDmkNTchvDFWKP8lp+w/42Z3us5sA==", + "dev": true, + "dependencies": { + "@babel/core": "^7.7.2", + "@babel/generator": "^7.7.2", + "@babel/plugin-syntax-typescript": "^7.7.2", + "@babel/traverse": "^7.7.2", + "@babel/types": "^7.0.0", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/babel__traverse": "^7.0.4", + "@types/prettier": "^2.1.5", + "babel-preset-current-node-syntax": "^1.0.0", + "chalk": "^4.0.0", + "expect": "^27.5.1", + "graceful-fs": "^4.2.9", + "jest-diff": "^27.5.1", + "jest-get-type": "^27.5.1", + "jest-haste-map": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-util": "^27.5.1", + "natural-compare": "^1.4.0", + "pretty-format": "^27.5.1", + "semver": "^7.3.2" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-snapshot/node_modules/semver": { + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", + "dev": true, + "dependencies": { + "lru-cache": "^6.0.0" + }, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/jest-util": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-27.5.1.tgz", + "integrity": "sha512-Kv2o/8jNvX1MQ0KGtw480E/w4fBCDOnH6+6DmeKi6LZUIlKA5kwY0YNdlzaWTiVgxqAqik11QyxDOKk543aKXw==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "ci-info": "^3.2.0", + "graceful-fs": "^4.2.9", + "picomatch": "^2.2.3" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-validate": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-27.5.1.tgz", + "integrity": "sha512-thkNli0LYTmOI1tDB3FI1S1RTp/Bqyd9pTarJwL87OIBFuqEb5Apv5EaApEudYg4g86e3CT6kM0RowkhtEnCBQ==", + "dev": true, + "dependencies": { + "@jest/types": "^27.5.1", + "camelcase": "^6.2.0", + "chalk": "^4.0.0", + "jest-get-type": "^27.5.1", + "leven": "^3.1.0", + "pretty-format": "^27.5.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-validate/node_modules/camelcase": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", + "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/jest-watcher": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-27.5.1.tgz", + "integrity": "sha512-z676SuD6Z8o8qbmEGhoEUFOM1+jfEiL3DXHK/xgEiG2EyNYfFG60jluWcupY6dATjfEsKQuibReS1djInQnoVw==", + "dev": true, + "dependencies": { + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "ansi-escapes": "^4.2.1", + "chalk": "^4.0.0", + "jest-util": "^27.5.1", + "string-length": "^4.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/jest-worker": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.1.tgz", + "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==", + "dev": true, + "dependencies": { + "@types/node": "*", + "merge-stream": "^2.0.0", + "supports-color": "^8.0.0" + }, + "engines": { + "node": ">= 10.13.0" + } + }, + "node_modules/js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "node_modules/jsdom": { + "version": "16.7.0", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-16.7.0.tgz", + "integrity": "sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw==", + "dev": true, + "dependencies": { + "abab": "^2.0.5", + "acorn": "^8.2.4", + "acorn-globals": "^6.0.0", + "cssom": "^0.4.4", + "cssstyle": "^2.3.0", + "data-urls": "^2.0.0", + "decimal.js": "^10.2.1", + "domexception": "^2.0.1", + "escodegen": "^2.0.0", + "form-data": "^3.0.0", + "html-encoding-sniffer": "^2.0.1", + "http-proxy-agent": "^4.0.1", + "https-proxy-agent": "^5.0.0", + "is-potential-custom-element-name": "^1.0.1", + "nwsapi": "^2.2.0", + "parse5": "6.0.1", + "saxes": "^5.0.1", + "symbol-tree": "^3.2.4", + "tough-cookie": "^4.0.0", + "w3c-hr-time": "^1.0.2", + "w3c-xmlserializer": "^2.0.0", + "webidl-conversions": "^6.1.0", + "whatwg-encoding": "^1.0.5", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^8.5.0", + "ws": "^7.4.6", + "xml-name-validator": "^3.0.0" + }, + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "canvas": "^2.5.0" + }, + "peerDependenciesMeta": { + "canvas": { + "optional": true + } + } + }, + "node_modules/jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "dev": true, + "bin": { + "jsesc": "bin/jsesc" }, "engines": { "node": ">=4" } }, + "node_modules/json-parse-even-better-errors": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", + "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", + "dev": true + }, "node_modules/json5": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.0.tgz", @@ -1651,50 +3345,71 @@ "node": ">=6" } }, - "node_modules/locate-path": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", - "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "node_modules/kleur": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", + "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/leven": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", + "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/levn": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", + "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", "dev": true, "dependencies": { - "p-locate": "^5.0.0" + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2" }, "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "node": ">= 0.8.0" } }, + "node_modules/lines-and-columns": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", + "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", + "dev": true + }, + "node_modules/lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "dev": true + }, "node_modules/lodash.flattendeep": { "version": "4.4.0", "resolved": "https://registry.npmjs.org/lodash.flattendeep/-/lodash.flattendeep-4.4.0.tgz", "integrity": "sha1-+wMJF/hqMTTlvJvsDWngAT3f7bI=", "dev": true }, - "node_modules/log-symbols": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", - "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", + "node_modules/lodash.memoize": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", + "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=", + "dev": true + }, + "node_modules/lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", "dev": true, "dependencies": { - "chalk": "^4.1.0", - "is-unicode-supported": "^0.1.0" + "yallist": "^4.0.0" }, "engines": { "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/loupe": { - "version": "2.3.4", - "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.4.tgz", - "integrity": "sha512-OvKfgCC2Ndby6aSTREl5aCCPTNIzlDfQZvZxNUrBrihDhL3xcrYegTblhmEiCrg2kKQz4XsFIaemE5BF4ybSaQ==", - "dev": true, - "dependencies": { - "get-func-name": "^2.0.0" } }, "node_modules/make-dir": { @@ -1718,85 +3433,82 @@ "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", "dev": true }, - "node_modules/minimatch": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-4.2.1.tgz", - "integrity": "sha512-9Uq1ChtSZO+Mxa/CL1eGizn2vRn3MlLgzhT0Iz8zaY8NdvxvB0d5QdPFmCKf7JKA9Lerx5vRrnwO03jsSfGG9g==", + "node_modules/makeerror": { + "version": "1.0.12", + "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", + "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", "dev": true, "dependencies": { - "brace-expansion": "^1.1.7" - }, - "engines": { - "node": ">=10" + "tmpl": "1.0.5" } }, - "node_modules/minimist": { - "version": "1.2.5", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", - "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", + "node_modules/merge-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", + "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", "dev": true }, - "node_modules/mocha": { - "version": "9.2.2", - "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.2.2.tgz", - "integrity": "sha512-L6XC3EdwT6YrIk0yXpavvLkn8h+EU+Y5UcCHKECyMbdUIxyMuZj4bX4U9e1nvnvUUvQVsV2VHQr5zLdcUkhW/g==", - "dev": true, - "dependencies": { - "@ungap/promise-all-settled": "1.1.2", - "ansi-colors": "4.1.1", - "browser-stdout": "1.3.1", - "chokidar": "3.5.3", - "debug": "4.3.3", - "diff": "5.0.0", - "escape-string-regexp": "4.0.0", - "find-up": "5.0.0", - "glob": "7.2.0", - "growl": "1.10.5", - "he": "1.2.0", - "js-yaml": "4.1.0", - "log-symbols": "4.1.0", - "minimatch": "4.2.1", - "ms": "2.1.3", - "nanoid": "3.3.1", - "serialize-javascript": "6.0.0", - "strip-json-comments": "3.1.1", - "supports-color": "8.1.1", - "which": "2.0.2", - "workerpool": "6.2.0", - "yargs": "16.2.0", - "yargs-parser": "20.2.4", - "yargs-unparser": "2.0.0" - }, - "bin": { - "_mocha": "bin/_mocha", - "mocha": "bin/mocha" + "node_modules/micromatch": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", + "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", + "dev": true, + "dependencies": { + "braces": "^3.0.1", + "picomatch": "^2.2.3" }, "engines": { - "node": ">= 12.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/mochajs" + "node": ">=8.6" } }, - "node_modules/ms": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", - "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", - "dev": true + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "dev": true, + "engines": { + "node": ">= 0.6" + } }, - "node_modules/nanoid": { - "version": "3.3.1", - "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.1.tgz", - "integrity": "sha512-n6Vs/3KGyxPQd6uO0eH4Bv0ojGSUvuLlIHtC3Y0kEO23YRge8H9x1GCzLn28YX0H66pMkxuaeESFq4tKISKwdw==", + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", "dev": true, - "bin": { - "nanoid": "bin/nanoid.cjs" + "dependencies": { + "mime-db": "1.52.0" }, "engines": { - "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" + "node": ">= 0.6" } }, + "node_modules/mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/minimist": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", + "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", + "dev": true + }, + "node_modules/natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", + "dev": true + }, + "node_modules/node-int64": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", + "integrity": "sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs=", + "dev": true + }, "node_modules/node-preload": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/node-preload/-/node-preload-0.2.1.tgz", @@ -1824,6 +3536,24 @@ "node": ">=0.10.0" } }, + "node_modules/npm-run-path": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", + "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", + "dev": true, + "dependencies": { + "path-key": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/nwsapi": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.0.tgz", + "integrity": "sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ==", + "dev": true + }, "node_modules/nyc": { "version": "15.1.0", "resolved": "https://registry.npmjs.org/nyc/-/nyc-15.1.0.tgz", @@ -1992,34 +3722,36 @@ "wrappy": "1" } }, - "node_modules/p-limit": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", - "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "node_modules/onetime": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", + "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", "dev": true, "dependencies": { - "yocto-queue": "^0.1.0" + "mimic-fn": "^2.1.0" }, "engines": { - "node": ">=10" + "node": ">=6" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/p-locate": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", - "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "node_modules/optionator": { + "version": "0.8.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", + "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", "dev": true, "dependencies": { - "p-limit": "^3.0.2" + "deep-is": "~0.1.3", + "fast-levenshtein": "~2.0.6", + "levn": "~0.3.0", + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2", + "word-wrap": "~1.2.3" }, "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "node": ">= 0.8.0" } }, "node_modules/p-map": { @@ -2058,6 +3790,30 @@ "node": ">=8" } }, + "node_modules/parse-json": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", + "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.0.0", + "error-ex": "^1.3.1", + "json-parse-even-better-errors": "^2.3.0", + "lines-and-columns": "^1.1.6" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/parse5": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz", + "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==", + "dev": true + }, "node_modules/path-exists": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", @@ -2085,14 +3841,11 @@ "node": ">=8" } }, - "node_modules/pathval": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", - "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", - "dev": true, - "engines": { - "node": "*" - } + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true }, "node_modules/picocolors": { "version": "1.0.0", @@ -2112,6 +3865,15 @@ "url": "https://github.com/sponsors/jonschlinkert" } }, + "node_modules/pirates": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz", + "integrity": "sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ==", + "dev": true, + "engines": { + "node": ">= 6" + } + }, "node_modules/pkg-dir": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", @@ -2176,6 +3938,41 @@ "node": ">=8" } }, + "node_modules/prelude-ls": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", + "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", + "dev": true, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/pretty-format": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.1.tgz", + "integrity": "sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.1", + "ansi-styles": "^5.0.0", + "react-is": "^17.0.1" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + } + }, + "node_modules/pretty-format/node_modules/ansi-styles": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", + "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, "node_modules/process-on-spawn": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/process-on-spawn/-/process-on-spawn-1.0.0.tgz", @@ -2188,6 +3985,34 @@ "node": ">=8" } }, + "node_modules/prompts": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", + "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", + "dev": true, + "dependencies": { + "kleur": "^3.0.3", + "sisteransi": "^1.0.5" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/psl": { + "version": "1.8.0", + "resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz", + "integrity": "sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==", + "dev": true + }, + "node_modules/punycode": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", + "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", + "dev": true, + "engines": { + "node": ">=6" + } + }, "node_modules/ramda": { "version": "0.28.0", "resolved": "https://registry.npmjs.org/ramda/-/ramda-0.28.0.tgz", @@ -2197,26 +4022,11 @@ "url": "https://opencollective.com/ramda" } }, - "node_modules/randombytes": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", - "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", - "dev": true, - "dependencies": { - "safe-buffer": "^5.1.0" - } - }, - "node_modules/readdirp": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", - "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", - "dev": true, - "dependencies": { - "picomatch": "^2.2.1" - }, - "engines": { - "node": ">=8.10.0" - } + "node_modules/react-is": { + "version": "17.0.2", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", + "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", + "dev": true }, "node_modules/release-zalgo": { "version": "1.0.0", @@ -2245,6 +4055,35 @@ "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", "dev": true }, + "node_modules/resolve": { + "version": "1.22.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", + "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", + "dev": true, + "dependencies": { + "is-core-module": "^2.8.1", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve-cwd": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", + "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", + "dev": true, + "dependencies": { + "resolve-from": "^5.0.0" + }, + "engines": { + "node": ">=8" + } + }, "node_modules/resolve-from": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", @@ -2254,6 +4093,15 @@ "node": ">=8" } }, + "node_modules/resolve.exports": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-1.1.0.tgz", + "integrity": "sha512-J1l+Zxxp4XK3LUDZ9m60LRJF/mAe4z6a4xyabPHk7pvK5t35dACV32iIjJDFeWZFfZlO29w6SZ67knR0tHzJtQ==", + "dev": true, + "engines": { + "node": ">=10" + } + }, "node_modules/rimraf": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", @@ -2280,6 +4128,24 @@ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", "dev": true }, + "node_modules/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true + }, + "node_modules/saxes": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/saxes/-/saxes-5.0.1.tgz", + "integrity": "sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw==", + "dev": true, + "dependencies": { + "xmlchars": "^2.2.0" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/semver": { "version": "6.3.0", "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", @@ -2289,15 +4155,6 @@ "semver": "bin/semver.js" } }, - "node_modules/serialize-javascript": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", - "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", - "dev": true, - "dependencies": { - "randombytes": "^2.1.0" - } - }, "node_modules/set-blocking": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", @@ -2331,6 +4188,21 @@ "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", "dev": true }, + "node_modules/sisteransi": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", + "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", + "dev": true + }, + "node_modules/slash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", + "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, "node_modules/source-map": { "version": "0.5.7", "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", @@ -2340,6 +4212,25 @@ "node": ">=0.10.0" } }, + "node_modules/source-map-support": { + "version": "0.5.21", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", + "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", + "dev": true, + "dependencies": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, + "node_modules/source-map-support/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/spawn-wrap": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/spawn-wrap/-/spawn-wrap-2.0.0.tgz", @@ -2363,6 +4254,40 @@ "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", "dev": true }, + "node_modules/stack-utils": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.5.tgz", + "integrity": "sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA==", + "dev": true, + "dependencies": { + "escape-string-regexp": "^2.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/stack-utils/node_modules/escape-string-regexp": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", + "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/string-length": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", + "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", + "dev": true, + "dependencies": { + "char-regex": "^1.0.2", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/string-width": { "version": "4.2.3", "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", @@ -2398,6 +4323,15 @@ "node": ">=8" } }, + "node_modules/strip-final-newline": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", + "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", + "dev": true, + "engines": { + "node": ">=6" + } + }, "node_modules/strip-json-comments": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", @@ -2425,6 +4359,65 @@ "url": "https://github.com/chalk/supports-color?sponsor=1" } }, + "node_modules/supports-hyperlinks": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz", + "integrity": "sha512-6sXEzV5+I5j8Bmq9/vUphGRM/RJNT9SCURJLjwfOg51heRtguGWDzcaBlgAzKhQa0EVNpPEKzQuBwZ8S8WaCeQ==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0", + "supports-color": "^7.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/supports-hyperlinks/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==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/symbol-tree": { + "version": "3.2.4", + "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", + "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==", + "dev": true + }, + "node_modules/terminal-link": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz", + "integrity": "sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ==", + "dev": true, + "dependencies": { + "ansi-escapes": "^4.2.1", + "supports-hyperlinks": "^2.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/test-exclude": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", @@ -2451,6 +4444,18 @@ "node": "*" } }, + "node_modules/throat": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/throat/-/throat-6.0.1.tgz", + "integrity": "sha512-8hmiGIJMDlwjg7dlJ4yKGLK8EsYqKgPWbG3b4wjJddKNwc7N7Dpn08Df4szr/sZdMVeOstrdYSsqzX6BYbcB+w==", + "dev": true + }, + "node_modules/tmpl": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", + "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", + "dev": true + }, "node_modules/to-fast-properties": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", @@ -2469,7 +4474,92 @@ "is-number": "^7.0.0" }, "engines": { - "node": ">=8.0" + "node": ">=8.0" + } + }, + "node_modules/tough-cookie": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.0.0.tgz", + "integrity": "sha512-tHdtEpQCMrc1YLrMaqXXcj6AxhYi/xgit6mZu1+EDWUn+qhUf8wMQoFIy9NXuq23zAwtcB0t/MjACGR18pcRbg==", + "dev": true, + "dependencies": { + "psl": "^1.1.33", + "punycode": "^2.1.1", + "universalify": "^0.1.2" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/tr46": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-2.1.0.tgz", + "integrity": "sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==", + "dev": true, + "dependencies": { + "punycode": "^2.1.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/ts-jest": { + "version": "27.1.3", + "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-27.1.3.tgz", + "integrity": "sha512-6Nlura7s6uM9BVUAoqLH7JHyMXjz8gluryjpPXxr3IxZdAXnU6FhjvVLHFtfd1vsE1p8zD1OJfskkc0jhTSnkA==", + "dev": true, + "dependencies": { + "bs-logger": "0.x", + "fast-json-stable-stringify": "2.x", + "jest-util": "^27.0.0", + "json5": "2.x", + "lodash.memoize": "4.x", + "make-error": "1.x", + "semver": "7.x", + "yargs-parser": "20.x" + }, + "bin": { + "ts-jest": "cli.js" + }, + "engines": { + "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" + }, + "peerDependencies": { + "@babel/core": ">=7.0.0-beta.0 <8", + "@types/jest": "^27.0.0", + "babel-jest": ">=27.0.0 <28", + "esbuild": "~0.14.0", + "jest": "^27.0.0", + "typescript": ">=3.8 <5.0" + }, + "peerDependenciesMeta": { + "@babel/core": { + "optional": true + }, + "@types/jest": { + "optional": true + }, + "babel-jest": { + "optional": true + }, + "esbuild": { + "optional": true + } + } + }, + "node_modules/ts-jest/node_modules/semver": { + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", + "dev": true, + "dependencies": { + "lru-cache": "^6.0.0" + }, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" } }, "node_modules/ts-node": { @@ -2530,6 +4620,18 @@ "integrity": "sha512-FZIXf1ksVyLcfr7M317jbB67XFJhOO1YqdTcuGaq9q5jLUoTikukZ+98TPjKiP2jC5CgmYdWWYs0s2nLSU0/1A==", "dev": true }, + "node_modules/type-check": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", + "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", + "dev": true, + "dependencies": { + "prelude-ls": "~1.1.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, "node_modules/type-detect": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", @@ -2570,6 +4672,15 @@ "node": ">=4.2.0" } }, + "node_modules/universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", + "dev": true, + "engines": { + "node": ">= 4.0.0" + } + }, "node_modules/uuid": { "version": "3.4.0", "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", @@ -2586,6 +4697,97 @@ "integrity": "sha512-mpSYqfsFvASnSn5qMiwrr4VKfumbPyONLCOPmsR3A6pTY/r0+tSaVbgPWSAIuzbk3lCTa+FForeTiO+wBQGkjA==", "dev": true }, + "node_modules/v8-to-istanbul": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-8.1.1.tgz", + "integrity": "sha512-FGtKtv3xIpR6BYhvgH8MI/y78oT7d8Au3ww4QIxymrCtZEh5b8gCw2siywE+puhEmuWKDtmfrvF5UlB298ut3w==", + "dev": true, + "dependencies": { + "@types/istanbul-lib-coverage": "^2.0.1", + "convert-source-map": "^1.6.0", + "source-map": "^0.7.3" + }, + "engines": { + "node": ">=10.12.0" + } + }, + "node_modules/v8-to-istanbul/node_modules/source-map": { + "version": "0.7.3", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", + "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/w3c-hr-time": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz", + "integrity": "sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ==", + "dev": true, + "dependencies": { + "browser-process-hrtime": "^1.0.0" + } + }, + "node_modules/w3c-xmlserializer": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-2.0.0.tgz", + "integrity": "sha512-4tzD0mF8iSiMiNs30BiLO3EpfGLZUT2MSX/G+o7ZywDzliWQ3OPtTZ0PTC3B3ca1UAf4cJMHB+2Bf56EriJuRA==", + "dev": true, + "dependencies": { + "xml-name-validator": "^3.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/walker": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", + "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", + "dev": true, + "dependencies": { + "makeerror": "1.0.12" + } + }, + "node_modules/webidl-conversions": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-6.1.0.tgz", + "integrity": "sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w==", + "dev": true, + "engines": { + "node": ">=10.4" + } + }, + "node_modules/whatwg-encoding": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz", + "integrity": "sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw==", + "dev": true, + "dependencies": { + "iconv-lite": "0.4.24" + } + }, + "node_modules/whatwg-mimetype": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz", + "integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==", + "dev": true + }, + "node_modules/whatwg-url": { + "version": "8.7.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-8.7.0.tgz", + "integrity": "sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==", + "dev": true, + "dependencies": { + "lodash": "^4.7.0", + "tr46": "^2.1.0", + "webidl-conversions": "^6.1.0" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/which": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", @@ -2607,11 +4809,14 @@ "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", "dev": true }, - "node_modules/workerpool": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.0.tgz", - "integrity": "sha512-Rsk5qQHJ9eowMH28Jwhe8HEbmdYDX4lwoMWshiCXugjtHqMD9ZbiqSDLxcsfdqsETPzVUtX5s1Z5kStiIM6l4A==", - "dev": true + "node_modules/word-wrap": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", + "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } }, "node_modules/wrap-ansi": { "version": "7.0.0", @@ -2648,6 +4853,39 @@ "typedarray-to-buffer": "^3.1.5" } }, + "node_modules/ws": { + "version": "7.5.7", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.7.tgz", + "integrity": "sha512-KMvVuFzpKBuiIXW3E4u3mySRO2/mCHSyZDJQM5NQ9Q9KHWHWh0NHgfbRMLLrceUK5qAL4ytALJbpRMjixFZh8A==", + "dev": true, + "engines": { + "node": ">=8.3.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": "^5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + }, + "node_modules/xml-name-validator": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-3.0.0.tgz", + "integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==", + "dev": true + }, + "node_modules/xmlchars": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz", + "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==", + "dev": true + }, "node_modules/y18n": { "version": "5.0.8", "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", @@ -2657,6 +4895,12 @@ "node": ">=10" } }, + "node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, "node_modules/yargs": { "version": "16.2.0", "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", @@ -2684,45 +4928,6 @@ "node": ">=10" } }, - "node_modules/yargs-unparser": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", - "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", - "dev": true, - "dependencies": { - "camelcase": "^6.0.0", - "decamelize": "^4.0.0", - "flat": "^5.0.2", - "is-plain-obj": "^2.1.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/yargs-unparser/node_modules/camelcase": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/yargs-unparser/node_modules/decamelize": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", - "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/yn": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", @@ -2731,18 +4936,6 @@ "engines": { "node": ">=6" } - }, - "node_modules/yocto-queue": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", - "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } } }, "dependencies": { @@ -2879,6 +5072,12 @@ "@babel/types": "^7.17.0" } }, + "@babel/helper-plugin-utils": { + "version": "7.16.7", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.16.7.tgz", + "integrity": "sha512-Qg3Nk7ZxpgMrsox6HreY1ZNKdBq7K72tDSliA6dCl5f007jR4ne8iD5UzuNnCJH2xBf2BEEVGr+/OL6Gdp7RxA==", + "dev": true + }, "@babel/helper-simple-access": { "version": "7.16.7", "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.16.7.tgz", @@ -2995,6 +5194,123 @@ "integrity": "sha512-7yJPvPV+ESz2IUTPbOL+YkIGyCqOyNIzdguKQuJGnH7bg1WTIifuM21YqokFt/THWh1AkCRn9IgoykTRCBVpzA==", "dev": true }, + "@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-bigint": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", + "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-class-properties": { + "version": "7.12.13", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", + "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.12.13" + } + }, + "@babel/plugin-syntax-import-meta": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", + "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, + "@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-logical-assignment-operators": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", + "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, + "@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", + "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-numeric-separator": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", + "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, + "@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", + "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", + "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-chaining": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", + "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-top-level-await": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", + "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-typescript": { + "version": "7.16.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.16.7.tgz", + "integrity": "sha512-YhUIJHHGkqPgEcMYkPCKTyGUdoGKWtopIycQyjJH8OjvRgOYsXsaKehLVPScKJWAULPxMa4N1vCe6szREFlZ7A==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.16.7" + } + }, "@babel/template": { "version": "7.16.7", "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.16.7.tgz", @@ -3034,6 +5350,12 @@ "to-fast-properties": "^2.0.0" } }, + "@bcoe/v8-coverage": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", + "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", + "dev": true + }, "@cspotcode/source-map-consumer": { "version": "0.8.0", "resolved": "https://registry.npmjs.org/@cspotcode/source-map-consumer/-/source-map-consumer-0.8.0.tgz", @@ -3120,11 +5442,239 @@ } } }, - "@istanbuljs/schema": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", - "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", - "dev": true + "@istanbuljs/schema": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", + "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", + "dev": true + }, + "@jest/console": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/console/-/console-27.5.1.tgz", + "integrity": "sha512-kZ/tNpS3NXn0mlXXXPNuDZnb4c0oZ20r4K5eemM2k30ZC3G0T02nXUvyhf5YdbXWHPEJLc9qGLxEZ216MdL+Zg==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "jest-message-util": "^27.5.1", + "jest-util": "^27.5.1", + "slash": "^3.0.0" + } + }, + "@jest/core": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/core/-/core-27.5.1.tgz", + "integrity": "sha512-AK6/UTrvQD0Cd24NSqmIA6rKsu0tKIxfiCducZvqxYdmMisOYAsdItspT+fQDQYARPf8XgjAFZi0ogW2agH5nQ==", + "dev": true, + "requires": { + "@jest/console": "^27.5.1", + "@jest/reporters": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "ansi-escapes": "^4.2.1", + "chalk": "^4.0.0", + "emittery": "^0.8.1", + "exit": "^0.1.2", + "graceful-fs": "^4.2.9", + "jest-changed-files": "^27.5.1", + "jest-config": "^27.5.1", + "jest-haste-map": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-resolve-dependencies": "^27.5.1", + "jest-runner": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "jest-watcher": "^27.5.1", + "micromatch": "^4.0.4", + "rimraf": "^3.0.0", + "slash": "^3.0.0", + "strip-ansi": "^6.0.0" + } + }, + "@jest/environment": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-27.5.1.tgz", + "integrity": "sha512-/WQjhPJe3/ghaol/4Bq480JKXV/Rfw8nQdN7f41fM8VDHLcxKXou6QyXAh3EFr9/bVG3x74z1NWDkP87EiY8gA==", + "dev": true, + "requires": { + "@jest/fake-timers": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "jest-mock": "^27.5.1" + } + }, + "@jest/fake-timers": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-27.5.1.tgz", + "integrity": "sha512-/aPowoolwa07k7/oM3aASneNeBGCmGQsc3ugN4u6s4C/+s5M64MFo/+djTdiwcbQlRfFElGuDXWzaWj6QgKObQ==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "@sinonjs/fake-timers": "^8.0.1", + "@types/node": "*", + "jest-message-util": "^27.5.1", + "jest-mock": "^27.5.1", + "jest-util": "^27.5.1" + } + }, + "@jest/globals": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-27.5.1.tgz", + "integrity": "sha512-ZEJNB41OBQQgGzgyInAv0UUfDDj3upmHydjieSxFvTRuZElrx7tXg/uVQ5hYVEwiXs3+aMsAeEc9X7xiSKCm4Q==", + "dev": true, + "requires": { + "@jest/environment": "^27.5.1", + "@jest/types": "^27.5.1", + "expect": "^27.5.1" + } + }, + "@jest/reporters": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-27.5.1.tgz", + "integrity": "sha512-cPXh9hWIlVJMQkVk84aIvXuBB4uQQmFqZiacloFuGiP3ah1sbCxCosidXFDfqG8+6fO1oR2dTJTlsOy4VFmUfw==", + "dev": true, + "requires": { + "@bcoe/v8-coverage": "^0.2.3", + "@jest/console": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "collect-v8-coverage": "^1.0.0", + "exit": "^0.1.2", + "glob": "^7.1.2", + "graceful-fs": "^4.2.9", + "istanbul-lib-coverage": "^3.0.0", + "istanbul-lib-instrument": "^5.1.0", + "istanbul-lib-report": "^3.0.0", + "istanbul-lib-source-maps": "^4.0.0", + "istanbul-reports": "^3.1.3", + "jest-haste-map": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-util": "^27.5.1", + "jest-worker": "^27.5.1", + "slash": "^3.0.0", + "source-map": "^0.6.0", + "string-length": "^4.0.1", + "terminal-link": "^2.0.0", + "v8-to-istanbul": "^8.1.0" + }, + "dependencies": { + "istanbul-lib-instrument": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.1.0.tgz", + "integrity": "sha512-czwUz525rkOFDJxfKK6mYfIs9zBKILyrZQxjz3ABhjQXhbhFsSbo1HW/BFcsDnfJYJWA6thRR5/TUY2qs5W99Q==", + "dev": true, + "requires": { + "@babel/core": "^7.12.3", + "@babel/parser": "^7.14.7", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-coverage": "^3.2.0", + "semver": "^6.3.0" + } + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "@jest/source-map": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-27.5.1.tgz", + "integrity": "sha512-y9NIHUYF3PJRlHk98NdC/N1gl88BL08aQQgu4k4ZopQkCw9t9cV8mtl3TV8b/YCB8XaVTFrmUTAJvjsntDireg==", + "dev": true, + "requires": { + "callsites": "^3.0.0", + "graceful-fs": "^4.2.9", + "source-map": "^0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "@jest/test-result": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-27.5.1.tgz", + "integrity": "sha512-EW35l2RYFUcUQxFJz5Cv5MTOxlJIQs4I7gxzi2zVU7PJhOwfYq1MdC5nhSmYjX1gmMmLPvB3sIaC+BkcHRBfag==", + "dev": true, + "requires": { + "@jest/console": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/istanbul-lib-coverage": "^2.0.0", + "collect-v8-coverage": "^1.0.0" + } + }, + "@jest/test-sequencer": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-27.5.1.tgz", + "integrity": "sha512-LCheJF7WB2+9JuCS7VB/EmGIdQuhtqjRNI9A43idHv3E4KltCTsPsLxvdaubFHSYwY/fNjMWjl6vNRhDiN7vpQ==", + "dev": true, + "requires": { + "@jest/test-result": "^27.5.1", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-runtime": "^27.5.1" + } + }, + "@jest/transform": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-27.5.1.tgz", + "integrity": "sha512-ipON6WtYgl/1329g5AIJVbUuEh0wZVbdpGwC99Jw4LwuoBNS95MVphU6zOeD9pDkon+LLbFL7lOQRapbB8SCHw==", + "dev": true, + "requires": { + "@babel/core": "^7.1.0", + "@jest/types": "^27.5.1", + "babel-plugin-istanbul": "^6.1.1", + "chalk": "^4.0.0", + "convert-source-map": "^1.4.0", + "fast-json-stable-stringify": "^2.0.0", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-util": "^27.5.1", + "micromatch": "^4.0.4", + "pirates": "^4.0.4", + "slash": "^3.0.0", + "source-map": "^0.6.1", + "write-file-atomic": "^3.0.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "@jest/types": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-27.5.1.tgz", + "integrity": "sha512-Cx46iJ9QpwQTjIdq5VJu2QTMMs3QlEjI0x1QbBP5W1+nMzyc2XmimiRR/CbX9TO0cPTeUlxWMOu8mslYsJ8DEw==", + "dev": true, + "requires": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^3.0.0", + "@types/node": "*", + "@types/yargs": "^16.0.0", + "chalk": "^4.0.0" + } }, "@jridgewell/resolve-uri": { "version": "3.0.5", @@ -3148,6 +5698,30 @@ "@jridgewell/sourcemap-codec": "^1.4.10" } }, + "@sinonjs/commons": { + "version": "1.8.3", + "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.3.tgz", + "integrity": "sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ==", + "dev": true, + "requires": { + "type-detect": "4.0.8" + } + }, + "@sinonjs/fake-timers": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-8.1.0.tgz", + "integrity": "sha512-OAPJUAtgeINhh/TAlUID4QTs53Njm7xzddaVlEs/SXwgtiD1tW22zAB/W1wdqfrpmikgaWQ9Fw6Ws+hsiRm5Vg==", + "dev": true, + "requires": { + "@sinonjs/commons": "^1.7.0" + } + }, + "@tootallnate/once": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", + "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", + "dev": true + }, "@tsconfig/node10": { "version": "1.0.8", "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.8.tgz", @@ -3172,24 +5746,102 @@ "integrity": "sha512-eZxlbI8GZscaGS7kkc/trHTT5xgrjH3/1n2JDwusC9iahPKWMRvRjJSAN5mCXviuTGQ/lHnhvv8Q1YTpnfz9gA==", "dev": true }, - "@types/chai": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.0.tgz", - "integrity": "sha512-/ceqdqeRraGolFTcfoXNiqjyQhZzbINDngeoAq9GoHa8PPK1yNzTaxWjA6BFWp5Ua9JpXEMSS4s5i9tS0hOJtw==", - "dev": true + "@types/babel__core": { + "version": "7.1.18", + "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.18.tgz", + "integrity": "sha512-S7unDjm/C7z2A2R9NzfKCK1I+BAALDtxEmsJBwlB3EzNfb929ykjL++1CK9LO++EIp2fQrC8O+BwjKvz6UeDyQ==", + "dev": true, + "requires": { + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0", + "@types/babel__generator": "*", + "@types/babel__template": "*", + "@types/babel__traverse": "*" + } + }, + "@types/babel__generator": { + "version": "7.6.4", + "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz", + "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==", + "dev": true, + "requires": { + "@babel/types": "^7.0.0" + } + }, + "@types/babel__template": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz", + "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==", + "dev": true, + "requires": { + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0" + } + }, + "@types/babel__traverse": { + "version": "7.14.2", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.14.2.tgz", + "integrity": "sha512-K2waXdXBi2302XUdcHcR1jCeU0LL4TD9HRs/gk0N2Xvrht+G/BfJa4QObBQZfhMdxiCpV3COl5Nfq4uKTeTnJA==", + "dev": true, + "requires": { + "@babel/types": "^7.3.0" + } + }, + "@types/graceful-fs": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.5.tgz", + "integrity": "sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw==", + "dev": true, + "requires": { + "@types/node": "*" + } }, - "@types/mocha": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.1.0.tgz", - "integrity": "sha512-QCWHkbMv4Y5U9oW10Uxbr45qMMSzl4OzijsozynUAgx3kEHUdXB00udx2dWDQ7f2TU2a2uuiFaRZjCe3unPpeg==", + "@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==", "dev": true }, + "@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==", + "dev": true, + "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==", + "dev": true, + "requires": { + "@types/istanbul-lib-report": "*" + } + }, + "@types/jest": { + "version": "27.4.1", + "resolved": "https://registry.npmjs.org/@types/jest/-/jest-27.4.1.tgz", + "integrity": "sha512-23iPJADSmicDVrWk+HT58LMJtzLAnB2AgIzplQuq/bSrGaxCrlvRFjGbXmamnnk/mAmCdLStiGqggu28ocUyiw==", + "dev": true, + "requires": { + "jest-matcher-utils": "^27.0.0", + "pretty-format": "^27.0.0" + } + }, "@types/node": { "version": "17.0.21", "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.21.tgz", "integrity": "sha512-DBZCJbhII3r90XbQxI8Y9IjjiiOGlZ0Hr32omXIZvwwZ7p4DMMXGrKXVyPfuoBOri9XNtL0UK69jYIBIsRX3QQ==", "dev": true }, + "@types/prettier": { + "version": "2.4.4", + "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.4.4.tgz", + "integrity": "sha512-ReVR2rLTV1kvtlWFyuot+d1pkpG2Fw/XKE3PDAdj57rbM97ttSp9JZ2UsP+2EHTylra9cUf6JA7tGwW1INzUrA==", + "dev": true + }, "@types/ramda": { "version": "0.28.1", "resolved": "https://registry.npmjs.org/@types/ramda/-/ramda-0.28.1.tgz", @@ -3199,10 +5851,31 @@ "ts-toolbelt": "^6.15.1" } }, - "@ungap/promise-all-settled": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", - "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", + "@types/stack-utils": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", + "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", + "dev": true + }, + "@types/yargs": { + "version": "16.0.4", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz", + "integrity": "sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw==", + "dev": true, + "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==", + "dev": true + }, + "abab": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.5.tgz", + "integrity": "sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q==", "dev": true }, "acorn": { @@ -3211,12 +5884,45 @@ "integrity": "sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==", "dev": true }, + "acorn-globals": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-6.0.0.tgz", + "integrity": "sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg==", + "dev": true, + "requires": { + "acorn": "^7.1.1", + "acorn-walk": "^7.1.1" + }, + "dependencies": { + "acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true + }, + "acorn-walk": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", + "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==", + "dev": true + } + } + }, "acorn-walk": { "version": "8.2.0", "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", "dev": true }, + "agent-base": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", + "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", + "dev": true, + "requires": { + "debug": "4" + } + }, "aggregate-error": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", @@ -3227,11 +5933,22 @@ "indent-string": "^4.0.0" } }, - "ansi-colors": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", - "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", - "dev": true + "ansi-escapes": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", + "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", + "dev": true, + "requires": { + "type-fest": "^0.21.3" + }, + "dependencies": { + "type-fest": { + "version": "0.21.3", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", + "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", + "dev": true + } + } }, "ansi-regex": { "version": "5.0.1", @@ -3279,17 +5996,97 @@ "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", "dev": true }, - "argparse": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", - "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", "dev": true }, - "assertion-error": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", - "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", - "dev": true + "babel-jest": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-27.5.1.tgz", + "integrity": "sha512-cdQ5dXjGRd0IBRATiQ4mZGlGlRE8kJpjPOixdNRdT+m3UcNqmYWN6rK6nvtXYfY3D76cb8s/O1Ss8ea24PIwcg==", + "dev": true, + "requires": { + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/babel__core": "^7.1.14", + "babel-plugin-istanbul": "^6.1.1", + "babel-preset-jest": "^27.5.1", + "chalk": "^4.0.0", + "graceful-fs": "^4.2.9", + "slash": "^3.0.0" + } + }, + "babel-plugin-istanbul": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", + "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@istanbuljs/load-nyc-config": "^1.0.0", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-instrument": "^5.0.4", + "test-exclude": "^6.0.0" + }, + "dependencies": { + "istanbul-lib-instrument": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.1.0.tgz", + "integrity": "sha512-czwUz525rkOFDJxfKK6mYfIs9zBKILyrZQxjz3ABhjQXhbhFsSbo1HW/BFcsDnfJYJWA6thRR5/TUY2qs5W99Q==", + "dev": true, + "requires": { + "@babel/core": "^7.12.3", + "@babel/parser": "^7.14.7", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-coverage": "^3.2.0", + "semver": "^6.3.0" + } + } + } + }, + "babel-plugin-jest-hoist": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-27.5.1.tgz", + "integrity": "sha512-50wCwD5EMNW4aRpOwtqzyZHIewTYNxLA4nhB+09d8BIssfNfzBRhkBIHiaPv1Si226TQSvp8gxAJm2iY2qs2hQ==", + "dev": true, + "requires": { + "@babel/template": "^7.3.3", + "@babel/types": "^7.3.3", + "@types/babel__core": "^7.0.0", + "@types/babel__traverse": "^7.0.6" + } + }, + "babel-preset-current-node-syntax": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", + "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", + "dev": true, + "requires": { + "@babel/plugin-syntax-async-generators": "^7.8.4", + "@babel/plugin-syntax-bigint": "^7.8.3", + "@babel/plugin-syntax-class-properties": "^7.8.3", + "@babel/plugin-syntax-import-meta": "^7.8.3", + "@babel/plugin-syntax-json-strings": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.8.3", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.3", + "@babel/plugin-syntax-top-level-await": "^7.8.3" + } + }, + "babel-preset-jest": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-27.5.1.tgz", + "integrity": "sha512-Nptf2FzlPCWYuJg41HBqXVT8ym6bXOevuCTbhxlUpjwtysGaIWFvDEjp4y+G7fl13FgOdjs7P/DmErqH7da0Ag==", + "dev": true, + "requires": { + "babel-plugin-jest-hoist": "^27.5.1", + "babel-preset-current-node-syntax": "^1.0.0" + } }, "balanced-match": { "version": "1.0.2", @@ -3297,12 +6094,6 @@ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", "dev": true }, - "binary-extensions": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", - "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", - "dev": true - }, "brace-expansion": { "version": "1.1.11", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", @@ -3322,10 +6113,10 @@ "fill-range": "^7.0.1" } }, - "browser-stdout": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", - "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", + "browser-process-hrtime": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", + "integrity": "sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==", "dev": true }, "browserslist": { @@ -3341,6 +6132,30 @@ "picocolors": "^1.0.0" } }, + "bs-logger": { + "version": "0.2.6", + "resolved": "https://registry.npmjs.org/bs-logger/-/bs-logger-0.2.6.tgz", + "integrity": "sha512-pd8DCoxmbgc7hyPKOvxtqNcjYoOsABPQdcCUjGp3d42VR2CX1ORhk2A87oqqu5R1kk+76nsxZupkmyd+MVtCog==", + "dev": true, + "requires": { + "fast-json-stable-stringify": "2.x" + } + }, + "bser": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", + "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", + "dev": true, + "requires": { + "node-int64": "^0.4.0" + } + }, + "buffer-from": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", + "dev": true + }, "caching-transform": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/caching-transform/-/caching-transform-4.0.0.tgz", @@ -3353,6 +6168,12 @@ "write-file-atomic": "^3.0.0" } }, + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true + }, "camelcase": { "version": "5.3.1", "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", @@ -3365,21 +6186,6 @@ "integrity": "sha512-5v7LFQU4Sb/qvkz7JcZkvtSH1Ko+1x2kgo3ocdBeMGZSOFpuE1kkm0kpTwLtWeFrw5qw08ulLxJjVIXIS8MkiQ==", "dev": true }, - "chai": { - "version": "4.3.6", - "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.6.tgz", - "integrity": "sha512-bbcp3YfHCUzMOvKqsztczerVgBKSsEijCySNlHHbX3VG1nskvqjz5Rfso1gGwD6w6oOV3eI60pKuMOV5MV7p3Q==", - "dev": true, - "requires": { - "assertion-error": "^1.1.0", - "check-error": "^1.0.2", - "deep-eql": "^3.0.1", - "get-func-name": "^2.0.0", - "loupe": "^2.3.1", - "pathval": "^1.1.1", - "type-detect": "^4.0.5" - } - }, "chalk": { "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", @@ -3401,27 +6207,23 @@ } } }, - "check-error": { + "char-regex": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", - "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", + "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", + "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", "dev": true }, - "chokidar": { - "version": "3.5.3", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", - "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", - "dev": true, - "requires": { - "anymatch": "~3.1.2", - "braces": "~3.0.2", - "fsevents": "~2.3.2", - "glob-parent": "~5.1.2", - "is-binary-path": "~2.1.0", - "is-glob": "~4.0.1", - "normalize-path": "~3.0.0", - "readdirp": "~3.6.0" - } + "ci-info": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.3.0.tgz", + "integrity": "sha512-riT/3vI5YpVH6/qomlDnJow6TBee2PBKSEpx3O32EGPYbWGIRsIlGRms3Sm74wYE1JMo8RnO04Hb12+v1J5ICw==", + "dev": true + }, + "cjs-module-lexer": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz", + "integrity": "sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA==", + "dev": true }, "clean-stack": { "version": "2.2.0", @@ -3440,6 +6242,18 @@ "wrap-ansi": "^7.0.0" } }, + "co": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", + "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", + "dev": true + }, + "collect-v8-coverage": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz", + "integrity": "sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg==", + "dev": true + }, "color-convert": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", @@ -3455,6 +6269,15 @@ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", "dev": true }, + "combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dev": true, + "requires": { + "delayed-stream": "~1.0.0" + } + }, "commondir": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", @@ -3493,6 +6316,40 @@ "which": "^2.0.1" } }, + "cssom": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.4.4.tgz", + "integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw==", + "dev": true + }, + "cssstyle": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.3.0.tgz", + "integrity": "sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==", + "dev": true, + "requires": { + "cssom": "~0.3.6" + }, + "dependencies": { + "cssom": { + "version": "0.3.8", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", + "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==", + "dev": true + } + } + }, + "data-urls": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-2.0.0.tgz", + "integrity": "sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ==", + "dev": true, + "requires": { + "abab": "^2.0.3", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^8.0.0" + } + }, "debug": { "version": "4.3.3", "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", @@ -3516,14 +6373,29 @@ "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", "dev": true }, - "deep-eql": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", - "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", - "dev": true, - "requires": { - "type-detect": "^4.0.0" - } + "decimal.js": { + "version": "10.3.1", + "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.3.1.tgz", + "integrity": "sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ==", + "dev": true + }, + "dedent": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", + "integrity": "sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw=", + "dev": true + }, + "deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true + }, + "deepmerge": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz", + "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==", + "dev": true }, "default-require-extensions": { "version": "3.0.0", @@ -3534,24 +6406,68 @@ "strip-bom": "^4.0.0" } }, - "diff": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", - "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", + "delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", + "dev": true + }, + "detect-newline": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", + "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", "dev": true }, + "diff-sequences": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-27.5.1.tgz", + "integrity": "sha512-k1gCAXAsNgLwEL+Y8Wvl+M6oEFj5bgazfZULpS5CneoPPXRaCCW7dm+q21Ky2VEE5X+VeRDBVg1Pcvvsr4TtNQ==", + "dev": true + }, + "domexception": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/domexception/-/domexception-2.0.1.tgz", + "integrity": "sha512-yxJ2mFy/sibVQlu5qHjOkf9J3K6zgmCxgJ94u2EdvDOV09H+32LtRswEcUsmUWN72pVLOEnTSRaIVVzVQgS0dg==", + "dev": true, + "requires": { + "webidl-conversions": "^5.0.0" + }, + "dependencies": { + "webidl-conversions": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-5.0.0.tgz", + "integrity": "sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA==", + "dev": true + } + } + }, "electron-to-chromium": { "version": "1.4.82", "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.82.tgz", "integrity": "sha512-Ks+ANzLoIrFDUOJdjxYMH6CMKB8UQo5modAwvSZTxgF+vEs/U7G5IbWFUp6dS4klPkTDVdxbORuk8xAXXhMsWw==", "dev": true }, + "emittery": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.8.1.tgz", + "integrity": "sha512-uDfvUjVrfGJJhymx/kz6prltenw1u7WrCg1oa94zYY8xxVpLLUu045LAT0dhDZdXG58/EpPL/5kA180fQ/qudg==", + "dev": true + }, "emoji-regex": { "version": "8.0.0", "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", "dev": true }, + "error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "requires": { + "is-arrayish": "^0.2.1" + } + }, "es6-error": { "version": "4.1.1", "resolved": "https://registry.npmjs.org/es6-error/-/es6-error-4.1.1.tgz", @@ -3564,18 +6480,102 @@ "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", "dev": true }, - "escape-string-regexp": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", - "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "escodegen": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.0.0.tgz", + "integrity": "sha512-mmHKys/C8BFUGI+MAWNcSYoORYLMdPzjrknd2Vc+bUsjN5bXcr8EhrNB+UTqfL1y3I9c4fw2ihgtMPQLBRiQxw==", + "dev": true, + "requires": { + "esprima": "^4.0.1", + "estraverse": "^5.2.0", + "esutils": "^2.0.2", + "optionator": "^0.8.1", + "source-map": "~0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "optional": true + } + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true + }, + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true + }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true + }, + "execa": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", + "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", + "dev": true, + "requires": { + "cross-spawn": "^7.0.3", + "get-stream": "^6.0.0", + "human-signals": "^2.1.0", + "is-stream": "^2.0.0", + "merge-stream": "^2.0.0", + "npm-run-path": "^4.0.1", + "onetime": "^5.1.2", + "signal-exit": "^3.0.3", + "strip-final-newline": "^2.0.0" + } + }, + "exit": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", + "integrity": "sha1-BjJjj42HfMghB9MKD/8aF8uhzQw=", + "dev": true + }, + "expect": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/expect/-/expect-27.5.1.tgz", + "integrity": "sha512-E1q5hSUG2AmYQwQJ041nvgpkODHQvB+RKlB4IYdru6uJsyFTRyZAP463M+1lINorwbqAmUggi6+WwkD8lCS/Dw==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "jest-get-type": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1" + } + }, + "fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", "dev": true }, - "esprima": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", - "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", "dev": true }, + "fb-watchman": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.1.tgz", + "integrity": "sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg==", + "dev": true, + "requires": { + "bser": "2.1.1" + } + }, "fill-range": { "version": "7.0.1", "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", @@ -3596,22 +6596,6 @@ "pkg-dir": "^4.1.0" } }, - "find-up": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", - "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", - "dev": true, - "requires": { - "locate-path": "^6.0.0", - "path-exists": "^4.0.0" - } - }, - "flat": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", - "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", - "dev": true - }, "foreground-child": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", @@ -3622,6 +6606,17 @@ "signal-exit": "^3.0.2" } }, + "form-data": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", + "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", + "dev": true, + "requires": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + } + }, "fromentries": { "version": "1.3.2", "resolved": "https://registry.npmjs.org/fromentries/-/fromentries-1.3.2.tgz", @@ -3641,6 +6636,12 @@ "dev": true, "optional": true }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", + "dev": true + }, "gensync": { "version": "1.0.0-beta.2", "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", @@ -3653,18 +6654,18 @@ "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", "dev": true }, - "get-func-name": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", - "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", - "dev": true - }, "get-package-type": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", "dev": true }, + "get-stream": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", + "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", + "dev": true + }, "glob": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", @@ -3690,15 +6691,6 @@ } } }, - "glob-parent": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", - "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", - "dev": true, - "requires": { - "is-glob": "^4.0.1" - } - }, "globals": { "version": "11.12.0", "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", @@ -3711,11 +6703,14 @@ "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", "dev": true }, - "growl": { - "version": "1.10.5", - "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", - "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", - "dev": true + "has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "dev": true, + "requires": { + "function-bind": "^1.1.1" + } }, "has-flag": { "version": "4.0.0", @@ -3733,11 +6728,14 @@ "type-fest": "^0.8.0" } }, - "he": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", - "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", - "dev": true + "html-encoding-sniffer": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-2.0.1.tgz", + "integrity": "sha512-D5JbOMBIR/TVZkubHT+OyT2705QvogUW4IBn6nHd756OwieSF9aDYFj4dv6HHEVGYbHaLETa3WggZYWWMyy3ZQ==", + "dev": true, + "requires": { + "whatwg-encoding": "^1.0.5" + } }, "html-escaper": { "version": "2.0.2", @@ -3745,6 +6743,52 @@ "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", "dev": true }, + "http-proxy-agent": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", + "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", + "dev": true, + "requires": { + "@tootallnate/once": "1", + "agent-base": "6", + "debug": "4" + } + }, + "https-proxy-agent": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", + "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", + "dev": true, + "requires": { + "agent-base": "6", + "debug": "4" + } + }, + "human-signals": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", + "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", + "dev": true + }, + "iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dev": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "import-local": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", + "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", + "dev": true, + "requires": { + "pkg-dir": "^4.2.0", + "resolve-cwd": "^3.0.0" + } + }, "imurmurhash": { "version": "0.1.4", "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", @@ -3773,35 +6817,32 @@ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", "dev": true }, - "is-binary-path": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", - "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", + "dev": true + }, + "is-core-module": { + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", + "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", "dev": true, "requires": { - "binary-extensions": "^2.0.0" + "has": "^1.0.3" } }, - "is-extglob": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", - "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", - "dev": true - }, "is-fullwidth-code-point": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", "dev": true }, - "is-glob": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", - "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", - "dev": true, - "requires": { - "is-extglob": "^2.1.1" - } + "is-generator-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", + "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", + "dev": true }, "is-number": { "version": "7.0.0", @@ -3809,10 +6850,10 @@ "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", "dev": true }, - "is-plain-obj": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", - "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", + "is-potential-custom-element-name": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz", + "integrity": "sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==", "dev": true }, "is-stream": { @@ -3827,12 +6868,6 @@ "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", "dev": true }, - "is-unicode-supported": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", - "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", - "dev": true - }, "is-windows": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", @@ -3938,19 +6973,534 @@ "istanbul-lib-report": "^3.0.0" } }, + "jest": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest/-/jest-27.5.1.tgz", + "integrity": "sha512-Yn0mADZB89zTtjkPJEXwrac3LHudkQMR+Paqa8uxJHCBr9agxztUifWCyiYrjhMPBoUVBjyny0I7XH6ozDr7QQ==", + "dev": true, + "requires": { + "@jest/core": "^27.5.1", + "import-local": "^3.0.2", + "jest-cli": "^27.5.1" + } + }, + "jest-changed-files": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-27.5.1.tgz", + "integrity": "sha512-buBLMiByfWGCoMsLLzGUUSpAmIAGnbR2KJoMN10ziLhOLvP4e0SlypHnAel8iqQXTrcbmfEY9sSqae5sgUsTvw==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "execa": "^5.0.0", + "throat": "^6.0.1" + } + }, + "jest-circus": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-27.5.1.tgz", + "integrity": "sha512-D95R7x5UtlMA5iBYsOHFFbMD/GVA4R/Kdq15f7xYWUfWHBto9NYRsOvnSauTgdF+ogCpJ4tyKOXhUifxS65gdw==", + "dev": true, + "requires": { + "@jest/environment": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "co": "^4.6.0", + "dedent": "^0.7.0", + "expect": "^27.5.1", + "is-generator-fn": "^2.0.0", + "jest-each": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "pretty-format": "^27.5.1", + "slash": "^3.0.0", + "stack-utils": "^2.0.3", + "throat": "^6.0.1" + } + }, + "jest-cli": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-27.5.1.tgz", + "integrity": "sha512-Hc6HOOwYq4/74/c62dEE3r5elx8wjYqxY0r0G/nFrLDPMFRu6RA/u8qINOIkvhxG7mMQ5EJsOGfRpI8L6eFUVw==", + "dev": true, + "requires": { + "@jest/core": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "exit": "^0.1.2", + "graceful-fs": "^4.2.9", + "import-local": "^3.0.2", + "jest-config": "^27.5.1", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "prompts": "^2.0.1", + "yargs": "^16.2.0" + } + }, + "jest-config": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-27.5.1.tgz", + "integrity": "sha512-5sAsjm6tGdsVbW9ahcChPAFCk4IlkQUknH5AvKjuLTSlcO/wCZKyFdn7Rg0EkC+OGgWODEy2hDpWB1PgzH0JNA==", + "dev": true, + "requires": { + "@babel/core": "^7.8.0", + "@jest/test-sequencer": "^27.5.1", + "@jest/types": "^27.5.1", + "babel-jest": "^27.5.1", + "chalk": "^4.0.0", + "ci-info": "^3.2.0", + "deepmerge": "^4.2.2", + "glob": "^7.1.1", + "graceful-fs": "^4.2.9", + "jest-circus": "^27.5.1", + "jest-environment-jsdom": "^27.5.1", + "jest-environment-node": "^27.5.1", + "jest-get-type": "^27.5.1", + "jest-jasmine2": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-runner": "^27.5.1", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "micromatch": "^4.0.4", + "parse-json": "^5.2.0", + "pretty-format": "^27.5.1", + "slash": "^3.0.0", + "strip-json-comments": "^3.1.1" + } + }, + "jest-diff": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-27.5.1.tgz", + "integrity": "sha512-m0NvkX55LDt9T4mctTEgnZk3fmEg3NRYutvMPWM/0iPnkFj2wIeF45O1718cMSOFO1vINkqmxqD8vE37uTEbqw==", + "dev": true, + "requires": { + "chalk": "^4.0.0", + "diff-sequences": "^27.5.1", + "jest-get-type": "^27.5.1", + "pretty-format": "^27.5.1" + } + }, + "jest-docblock": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-27.5.1.tgz", + "integrity": "sha512-rl7hlABeTsRYxKiUfpHrQrG4e2obOiTQWfMEH3PxPjOtdsfLQO4ReWSZaQ7DETm4xu07rl4q/h4zcKXyU0/OzQ==", + "dev": true, + "requires": { + "detect-newline": "^3.0.0" + } + }, + "jest-each": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-27.5.1.tgz", + "integrity": "sha512-1Ff6p+FbhT/bXQnEouYy00bkNSY7OUpfIcmdl8vZ31A1UUaurOLPA8a8BbJOF2RDUElwJhmeaV7LnagI+5UwNQ==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "jest-get-type": "^27.5.1", + "jest-util": "^27.5.1", + "pretty-format": "^27.5.1" + } + }, + "jest-environment-jsdom": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-27.5.1.tgz", + "integrity": "sha512-TFBvkTC1Hnnnrka/fUb56atfDtJ9VMZ94JkjTbggl1PEpwrYtUBKMezB3inLmWqQsXYLcMwNoDQwoBTAvFfsfw==", + "dev": true, + "requires": { + "@jest/environment": "^27.5.1", + "@jest/fake-timers": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "jest-mock": "^27.5.1", + "jest-util": "^27.5.1", + "jsdom": "^16.6.0" + } + }, + "jest-environment-node": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-27.5.1.tgz", + "integrity": "sha512-Jt4ZUnxdOsTGwSRAfKEnE6BcwsSPNOijjwifq5sDFSA2kesnXTvNqKHYgM0hDq3549Uf/KzdXNYn4wMZJPlFLw==", + "dev": true, + "requires": { + "@jest/environment": "^27.5.1", + "@jest/fake-timers": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "jest-mock": "^27.5.1", + "jest-util": "^27.5.1" + } + }, + "jest-extended": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/jest-extended/-/jest-extended-2.0.0.tgz", + "integrity": "sha512-6AgjJQVaBEKGSK3FH90kOiRUWJsbzn9NWtW0pjGkAFIdH0oPilfkV/gHPJdVvJeBiqT3jMHw8TUg9pUGC1azDg==", + "dev": true, + "requires": { + "jest-diff": "^27.2.5", + "jest-get-type": "^27.0.6" + } + }, + "jest-get-type": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-27.5.1.tgz", + "integrity": "sha512-2KY95ksYSaK7DMBWQn6dQz3kqAf3BB64y2udeG+hv4KfSOb9qwcYQstTJc1KCbsix+wLZWZYN8t7nwX3GOBLRw==", + "dev": true + }, + "jest-haste-map": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-27.5.1.tgz", + "integrity": "sha512-7GgkZ4Fw4NFbMSDSpZwXeBiIbx+t/46nJ2QitkOjvwPYyZmqttu2TDSimMHP1EkPOi4xUZAN1doE5Vd25H4Jng==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "@types/graceful-fs": "^4.1.2", + "@types/node": "*", + "anymatch": "^3.0.3", + "fb-watchman": "^2.0.0", + "fsevents": "^2.3.2", + "graceful-fs": "^4.2.9", + "jest-regex-util": "^27.5.1", + "jest-serializer": "^27.5.1", + "jest-util": "^27.5.1", + "jest-worker": "^27.5.1", + "micromatch": "^4.0.4", + "walker": "^1.0.7" + } + }, + "jest-jasmine2": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-jasmine2/-/jest-jasmine2-27.5.1.tgz", + "integrity": "sha512-jtq7VVyG8SqAorDpApwiJJImd0V2wv1xzdheGHRGyuT7gZm6gG47QEskOlzsN1PG/6WNaCo5pmwMHDf3AkG2pQ==", + "dev": true, + "requires": { + "@jest/environment": "^27.5.1", + "@jest/source-map": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "co": "^4.6.0", + "expect": "^27.5.1", + "is-generator-fn": "^2.0.0", + "jest-each": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "pretty-format": "^27.5.1", + "throat": "^6.0.1" + } + }, + "jest-leak-detector": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-27.5.1.tgz", + "integrity": "sha512-POXfWAMvfU6WMUXftV4HolnJfnPOGEu10fscNCA76KBpRRhcMN2c8d3iT2pxQS3HLbA+5X4sOUPzYO2NUyIlHQ==", + "dev": true, + "requires": { + "jest-get-type": "^27.5.1", + "pretty-format": "^27.5.1" + } + }, + "jest-matcher-utils": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-27.5.1.tgz", + "integrity": "sha512-z2uTx/T6LBaCoNWNFWwChLBKYxTMcGBRjAt+2SbP929/Fflb9aa5LGma654Rz8z9HLxsrUaYzxE9T/EFIL/PAw==", + "dev": true, + "requires": { + "chalk": "^4.0.0", + "jest-diff": "^27.5.1", + "jest-get-type": "^27.5.1", + "pretty-format": "^27.5.1" + } + }, + "jest-message-util": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-27.5.1.tgz", + "integrity": "sha512-rMyFe1+jnyAAf+NHwTclDz0eAaLkVDdKVHHBFWsBWHnnh5YeJMNWWsv7AbFYXfK3oTqvL7VTWkhNLu1jX24D+g==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.12.13", + "@jest/types": "^27.5.1", + "@types/stack-utils": "^2.0.0", + "chalk": "^4.0.0", + "graceful-fs": "^4.2.9", + "micromatch": "^4.0.4", + "pretty-format": "^27.5.1", + "slash": "^3.0.0", + "stack-utils": "^2.0.3" + } + }, + "jest-mock": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-27.5.1.tgz", + "integrity": "sha512-K4jKbY1d4ENhbrG2zuPWaQBvDly+iZ2yAW+T1fATN78hc0sInwn7wZB8XtlNnvHug5RMwV897Xm4LqmPM4e2Og==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "@types/node": "*" + } + }, + "jest-pnp-resolver": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz", + "integrity": "sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w==", + "dev": true, + "requires": {} + }, + "jest-regex-util": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-27.5.1.tgz", + "integrity": "sha512-4bfKq2zie+x16okqDXjXn9ql2B0dScQu+vcwe4TvFVhkVyuWLqpZrZtXxLLWoXYgn0E87I6r6GRYHF7wFZBUvg==", + "dev": true + }, + "jest-resolve": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-27.5.1.tgz", + "integrity": "sha512-FFDy8/9E6CV83IMbDpcjOhumAQPDyETnU2KZ1O98DwTnz8AOBsW/Xv3GySr1mOZdItLR+zDZ7I/UdTFbgSOVCw==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-pnp-resolver": "^1.2.2", + "jest-util": "^27.5.1", + "jest-validate": "^27.5.1", + "resolve": "^1.20.0", + "resolve.exports": "^1.1.0", + "slash": "^3.0.0" + } + }, + "jest-resolve-dependencies": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-27.5.1.tgz", + "integrity": "sha512-QQOOdY4PE39iawDn5rzbIePNigfe5B9Z91GDD1ae/xNDlu9kaat8QQ5EKnNmVWPV54hUdxCVwwj6YMgR2O7IOg==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-snapshot": "^27.5.1" + } + }, + "jest-runner": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-27.5.1.tgz", + "integrity": "sha512-g4NPsM4mFCOwFKXO4p/H/kWGdJp9V8kURY2lX8Me2drgXqG7rrZAx5kv+5H7wtt/cdFIjhqYx1HrlqWHaOvDaQ==", + "dev": true, + "requires": { + "@jest/console": "^27.5.1", + "@jest/environment": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "emittery": "^0.8.1", + "graceful-fs": "^4.2.9", + "jest-docblock": "^27.5.1", + "jest-environment-jsdom": "^27.5.1", + "jest-environment-node": "^27.5.1", + "jest-haste-map": "^27.5.1", + "jest-leak-detector": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-runtime": "^27.5.1", + "jest-util": "^27.5.1", + "jest-worker": "^27.5.1", + "source-map-support": "^0.5.6", + "throat": "^6.0.1" + } + }, + "jest-runtime": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-27.5.1.tgz", + "integrity": "sha512-o7gxw3Gf+H2IGt8fv0RiyE1+r83FJBRruoA+FXrlHw6xEyBsU8ugA6IPfTdVyA0w8HClpbK+DGJxH59UrNMx8A==", + "dev": true, + "requires": { + "@jest/environment": "^27.5.1", + "@jest/fake-timers": "^27.5.1", + "@jest/globals": "^27.5.1", + "@jest/source-map": "^27.5.1", + "@jest/test-result": "^27.5.1", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "chalk": "^4.0.0", + "cjs-module-lexer": "^1.0.0", + "collect-v8-coverage": "^1.0.0", + "execa": "^5.0.0", + "glob": "^7.1.3", + "graceful-fs": "^4.2.9", + "jest-haste-map": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-mock": "^27.5.1", + "jest-regex-util": "^27.5.1", + "jest-resolve": "^27.5.1", + "jest-snapshot": "^27.5.1", + "jest-util": "^27.5.1", + "slash": "^3.0.0", + "strip-bom": "^4.0.0" + } + }, + "jest-serializer": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-serializer/-/jest-serializer-27.5.1.tgz", + "integrity": "sha512-jZCyo6iIxO1aqUxpuBlwTDMkzOAJS4a3eYz3YzgxxVQFwLeSA7Jfq5cbqCY+JLvTDrWirgusI/0KwxKMgrdf7w==", + "dev": true, + "requires": { + "@types/node": "*", + "graceful-fs": "^4.2.9" + } + }, + "jest-snapshot": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-27.5.1.tgz", + "integrity": "sha512-yYykXI5a0I31xX67mgeLw1DZ0bJB+gpq5IpSuCAoyDi0+BhgU/RIrL+RTzDmkNTchvDFWKP8lp+w/42Z3us5sA==", + "dev": true, + "requires": { + "@babel/core": "^7.7.2", + "@babel/generator": "^7.7.2", + "@babel/plugin-syntax-typescript": "^7.7.2", + "@babel/traverse": "^7.7.2", + "@babel/types": "^7.0.0", + "@jest/transform": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/babel__traverse": "^7.0.4", + "@types/prettier": "^2.1.5", + "babel-preset-current-node-syntax": "^1.0.0", + "chalk": "^4.0.0", + "expect": "^27.5.1", + "graceful-fs": "^4.2.9", + "jest-diff": "^27.5.1", + "jest-get-type": "^27.5.1", + "jest-haste-map": "^27.5.1", + "jest-matcher-utils": "^27.5.1", + "jest-message-util": "^27.5.1", + "jest-util": "^27.5.1", + "natural-compare": "^1.4.0", + "pretty-format": "^27.5.1", + "semver": "^7.3.2" + }, + "dependencies": { + "semver": { + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + } + } + }, + "jest-util": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-27.5.1.tgz", + "integrity": "sha512-Kv2o/8jNvX1MQ0KGtw480E/w4fBCDOnH6+6DmeKi6LZUIlKA5kwY0YNdlzaWTiVgxqAqik11QyxDOKk543aKXw==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "@types/node": "*", + "chalk": "^4.0.0", + "ci-info": "^3.2.0", + "graceful-fs": "^4.2.9", + "picomatch": "^2.2.3" + } + }, + "jest-validate": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-27.5.1.tgz", + "integrity": "sha512-thkNli0LYTmOI1tDB3FI1S1RTp/Bqyd9pTarJwL87OIBFuqEb5Apv5EaApEudYg4g86e3CT6kM0RowkhtEnCBQ==", + "dev": true, + "requires": { + "@jest/types": "^27.5.1", + "camelcase": "^6.2.0", + "chalk": "^4.0.0", + "jest-get-type": "^27.5.1", + "leven": "^3.1.0", + "pretty-format": "^27.5.1" + }, + "dependencies": { + "camelcase": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", + "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", + "dev": true + } + } + }, + "jest-watcher": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-27.5.1.tgz", + "integrity": "sha512-z676SuD6Z8o8qbmEGhoEUFOM1+jfEiL3DXHK/xgEiG2EyNYfFG60jluWcupY6dATjfEsKQuibReS1djInQnoVw==", + "dev": true, + "requires": { + "@jest/test-result": "^27.5.1", + "@jest/types": "^27.5.1", + "@types/node": "*", + "ansi-escapes": "^4.2.1", + "chalk": "^4.0.0", + "jest-util": "^27.5.1", + "string-length": "^4.0.1" + } + }, + "jest-worker": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.1.tgz", + "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==", + "dev": true, + "requires": { + "@types/node": "*", + "merge-stream": "^2.0.0", + "supports-color": "^8.0.0" + } + }, "js-tokens": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", "dev": true }, - "js-yaml": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", - "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "jsdom": { + "version": "16.7.0", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-16.7.0.tgz", + "integrity": "sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw==", "dev": true, "requires": { - "argparse": "^2.0.1" + "abab": "^2.0.5", + "acorn": "^8.2.4", + "acorn-globals": "^6.0.0", + "cssom": "^0.4.4", + "cssstyle": "^2.3.0", + "data-urls": "^2.0.0", + "decimal.js": "^10.2.1", + "domexception": "^2.0.1", + "escodegen": "^2.0.0", + "form-data": "^3.0.0", + "html-encoding-sniffer": "^2.0.1", + "http-proxy-agent": "^4.0.1", + "https-proxy-agent": "^5.0.0", + "is-potential-custom-element-name": "^1.0.1", + "nwsapi": "^2.2.0", + "parse5": "6.0.1", + "saxes": "^5.0.1", + "symbol-tree": "^3.2.4", + "tough-cookie": "^4.0.0", + "w3c-hr-time": "^1.0.2", + "w3c-xmlserializer": "^2.0.0", + "webidl-conversions": "^6.1.0", + "whatwg-encoding": "^1.0.5", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^8.5.0", + "ws": "^7.4.6", + "xml-name-validator": "^3.0.0" } }, "jsesc": { @@ -3959,6 +7509,12 @@ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", "dev": true }, + "json-parse-even-better-errors": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", + "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", + "dev": true + }, "json5": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.0.tgz", @@ -3968,38 +7524,59 @@ "minimist": "^1.2.5" } }, - "locate-path": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", - "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "kleur": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", + "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", + "dev": true + }, + "leven": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", + "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", + "dev": true + }, + "levn": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", + "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", "dev": true, "requires": { - "p-locate": "^5.0.0" + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2" } }, + "lines-and-columns": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", + "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", + "dev": true + }, + "lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "dev": true + }, "lodash.flattendeep": { "version": "4.4.0", "resolved": "https://registry.npmjs.org/lodash.flattendeep/-/lodash.flattendeep-4.4.0.tgz", "integrity": "sha1-+wMJF/hqMTTlvJvsDWngAT3f7bI=", "dev": true }, - "log-symbols": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", - "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", - "dev": true, - "requires": { - "chalk": "^4.1.0", - "is-unicode-supported": "^0.1.0" - } + "lodash.memoize": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", + "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=", + "dev": true }, - "loupe": { - "version": "2.3.4", - "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.4.tgz", - "integrity": "sha512-OvKfgCC2Ndby6aSTREl5aCCPTNIzlDfQZvZxNUrBrihDhL3xcrYegTblhmEiCrg2kKQz4XsFIaemE5BF4ybSaQ==", + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", "dev": true, "requires": { - "get-func-name": "^2.0.0" + "yallist": "^4.0.0" } }, "make-dir": { @@ -4008,72 +7585,77 @@ "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", "dev": true, "requires": { - "semver": "^6.0.0" + "semver": "^6.0.0" + } + }, + "make-error": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", + "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", + "dev": true + }, + "makeerror": { + "version": "1.0.12", + "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", + "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", + "dev": true, + "requires": { + "tmpl": "1.0.5" + } + }, + "merge-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", + "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", + "dev": true + }, + "micromatch": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", + "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", + "dev": true, + "requires": { + "braces": "^3.0.1", + "picomatch": "^2.2.3" } }, - "make-error": { - "version": "1.3.6", - "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", - "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", + "mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", "dev": true }, - "minimatch": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-4.2.1.tgz", - "integrity": "sha512-9Uq1ChtSZO+Mxa/CL1eGizn2vRn3MlLgzhT0Iz8zaY8NdvxvB0d5QdPFmCKf7JKA9Lerx5vRrnwO03jsSfGG9g==", + "mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", "dev": true, "requires": { - "brace-expansion": "^1.1.7" + "mime-db": "1.52.0" } }, + "mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", + "dev": true + }, "minimist": { "version": "1.2.5", "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", "dev": true }, - "mocha": { - "version": "9.2.2", - "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.2.2.tgz", - "integrity": "sha512-L6XC3EdwT6YrIk0yXpavvLkn8h+EU+Y5UcCHKECyMbdUIxyMuZj4bX4U9e1nvnvUUvQVsV2VHQr5zLdcUkhW/g==", - "dev": true, - "requires": { - "@ungap/promise-all-settled": "1.1.2", - "ansi-colors": "4.1.1", - "browser-stdout": "1.3.1", - "chokidar": "3.5.3", - "debug": "4.3.3", - "diff": "5.0.0", - "escape-string-regexp": "4.0.0", - "find-up": "5.0.0", - "glob": "7.2.0", - "growl": "1.10.5", - "he": "1.2.0", - "js-yaml": "4.1.0", - "log-symbols": "4.1.0", - "minimatch": "4.2.1", - "ms": "2.1.3", - "nanoid": "3.3.1", - "serialize-javascript": "6.0.0", - "strip-json-comments": "3.1.1", - "supports-color": "8.1.1", - "which": "2.0.2", - "workerpool": "6.2.0", - "yargs": "16.2.0", - "yargs-parser": "20.2.4", - "yargs-unparser": "2.0.0" - } - }, - "ms": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", - "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", - "dev": true - }, - "nanoid": { - "version": "3.3.1", - "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.1.tgz", - "integrity": "sha512-n6Vs/3KGyxPQd6uO0eH4Bv0ojGSUvuLlIHtC3Y0kEO23YRge8H9x1GCzLn28YX0H66pMkxuaeESFq4tKISKwdw==", + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", + "dev": true + }, + "node-int64": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", + "integrity": "sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs=", "dev": true }, "node-preload": { @@ -4097,6 +7679,21 @@ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", "dev": true }, + "npm-run-path": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", + "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", + "dev": true, + "requires": { + "path-key": "^3.0.0" + } + }, + "nwsapi": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.0.tgz", + "integrity": "sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ==", + "dev": true + }, "nyc": { "version": "15.1.0", "resolved": "https://registry.npmjs.org/nyc/-/nyc-15.1.0.tgz", @@ -4237,22 +7834,27 @@ "wrappy": "1" } }, - "p-limit": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", - "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "onetime": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", + "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", "dev": true, "requires": { - "yocto-queue": "^0.1.0" + "mimic-fn": "^2.1.0" } }, - "p-locate": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", - "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "optionator": { + "version": "0.8.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", + "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", "dev": true, "requires": { - "p-limit": "^3.0.2" + "deep-is": "~0.1.3", + "fast-levenshtein": "~2.0.6", + "levn": "~0.3.0", + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2", + "word-wrap": "~1.2.3" } }, "p-map": { @@ -4282,6 +7884,24 @@ "release-zalgo": "^1.0.0" } }, + "parse-json": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", + "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "error-ex": "^1.3.1", + "json-parse-even-better-errors": "^2.3.0", + "lines-and-columns": "^1.1.6" + } + }, + "parse5": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz", + "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==", + "dev": true + }, "path-exists": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", @@ -4300,10 +7920,10 @@ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", "dev": true }, - "pathval": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", - "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", + "path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", "dev": true }, "picocolors": { @@ -4318,6 +7938,12 @@ "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", "dev": true }, + "pirates": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz", + "integrity": "sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ==", + "dev": true + }, "pkg-dir": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", @@ -4366,6 +7992,31 @@ } } }, + "prelude-ls": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", + "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", + "dev": true + }, + "pretty-format": { + "version": "27.5.1", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.1.tgz", + "integrity": "sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1", + "ansi-styles": "^5.0.0", + "react-is": "^17.0.1" + }, + "dependencies": { + "ansi-styles": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", + "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", + "dev": true + } + } + }, "process-on-spawn": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/process-on-spawn/-/process-on-spawn-1.0.0.tgz", @@ -4375,28 +8026,38 @@ "fromentries": "^1.2.0" } }, + "prompts": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", + "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", + "dev": true, + "requires": { + "kleur": "^3.0.3", + "sisteransi": "^1.0.5" + } + }, + "psl": { + "version": "1.8.0", + "resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz", + "integrity": "sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==", + "dev": true + }, + "punycode": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", + "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", + "dev": true + }, "ramda": { "version": "0.28.0", "resolved": "https://registry.npmjs.org/ramda/-/ramda-0.28.0.tgz", "integrity": "sha512-9QnLuG/kPVgWvMQ4aODhsBUFKOUmnbUnsSXACv+NCQZcHbeb+v8Lodp8OVxtRULN1/xOyYLLaL6npE6dMq5QTA==" }, - "randombytes": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", - "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", - "dev": true, - "requires": { - "safe-buffer": "^5.1.0" - } - }, - "readdirp": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", - "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", - "dev": true, - "requires": { - "picomatch": "^2.2.1" - } + "react-is": { + "version": "17.0.2", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", + "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", + "dev": true }, "release-zalgo": { "version": "1.0.0", @@ -4419,12 +8080,38 @@ "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", "dev": true }, + "resolve": { + "version": "1.22.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", + "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", + "dev": true, + "requires": { + "is-core-module": "^2.8.1", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + } + }, + "resolve-cwd": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", + "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", + "dev": true, + "requires": { + "resolve-from": "^5.0.0" + } + }, "resolve-from": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", "dev": true }, + "resolve.exports": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-1.1.0.tgz", + "integrity": "sha512-J1l+Zxxp4XK3LUDZ9m60LRJF/mAe4z6a4xyabPHk7pvK5t35dACV32iIjJDFeWZFfZlO29w6SZ67knR0tHzJtQ==", + "dev": true + }, "rimraf": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", @@ -4445,21 +8132,27 @@ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", "dev": true }, - "semver": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", "dev": true }, - "serialize-javascript": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", - "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", + "saxes": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/saxes/-/saxes-5.0.1.tgz", + "integrity": "sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw==", "dev": true, "requires": { - "randombytes": "^2.1.0" + "xmlchars": "^2.2.0" } }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + }, "set-blocking": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", @@ -4487,12 +8180,42 @@ "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", "dev": true }, + "sisteransi": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", + "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", + "dev": true + }, + "slash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", + "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", + "dev": true + }, "source-map": { "version": "0.5.7", "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", "dev": true }, + "source-map-support": { + "version": "0.5.21", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", + "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, "spawn-wrap": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/spawn-wrap/-/spawn-wrap-2.0.0.tgz", @@ -4513,6 +8236,33 @@ "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", "dev": true }, + "stack-utils": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.5.tgz", + "integrity": "sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA==", + "dev": true, + "requires": { + "escape-string-regexp": "^2.0.0" + }, + "dependencies": { + "escape-string-regexp": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", + "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", + "dev": true + } + } + }, + "string-length": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", + "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", + "dev": true, + "requires": { + "char-regex": "^1.0.2", + "strip-ansi": "^6.0.0" + } + }, "string-width": { "version": "4.2.3", "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", @@ -4539,6 +8289,12 @@ "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", "dev": true }, + "strip-final-newline": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", + "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", + "dev": true + }, "strip-json-comments": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", @@ -4554,6 +8310,49 @@ "has-flag": "^4.0.0" } }, + "supports-hyperlinks": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz", + "integrity": "sha512-6sXEzV5+I5j8Bmq9/vUphGRM/RJNT9SCURJLjwfOg51heRtguGWDzcaBlgAzKhQa0EVNpPEKzQuBwZ8S8WaCeQ==", + "dev": true, + "requires": { + "has-flag": "^4.0.0", + "supports-color": "^7.0.0" + }, + "dependencies": { + "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==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true + }, + "symbol-tree": { + "version": "3.2.4", + "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", + "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==", + "dev": true + }, + "terminal-link": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz", + "integrity": "sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ==", + "dev": true, + "requires": { + "ansi-escapes": "^4.2.1", + "supports-hyperlinks": "^2.0.0" + } + }, "test-exclude": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", @@ -4576,6 +8375,18 @@ } } }, + "throat": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/throat/-/throat-6.0.1.tgz", + "integrity": "sha512-8hmiGIJMDlwjg7dlJ4yKGLK8EsYqKgPWbG3b4wjJddKNwc7N7Dpn08Df4szr/sZdMVeOstrdYSsqzX6BYbcB+w==", + "dev": true + }, + "tmpl": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", + "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", + "dev": true + }, "to-fast-properties": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", @@ -4591,6 +8402,53 @@ "is-number": "^7.0.0" } }, + "tough-cookie": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.0.0.tgz", + "integrity": "sha512-tHdtEpQCMrc1YLrMaqXXcj6AxhYi/xgit6mZu1+EDWUn+qhUf8wMQoFIy9NXuq23zAwtcB0t/MjACGR18pcRbg==", + "dev": true, + "requires": { + "psl": "^1.1.33", + "punycode": "^2.1.1", + "universalify": "^0.1.2" + } + }, + "tr46": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-2.1.0.tgz", + "integrity": "sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==", + "dev": true, + "requires": { + "punycode": "^2.1.1" + } + }, + "ts-jest": { + "version": "27.1.3", + "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-27.1.3.tgz", + "integrity": "sha512-6Nlura7s6uM9BVUAoqLH7JHyMXjz8gluryjpPXxr3IxZdAXnU6FhjvVLHFtfd1vsE1p8zD1OJfskkc0jhTSnkA==", + "dev": true, + "requires": { + "bs-logger": "0.x", + "fast-json-stable-stringify": "2.x", + "jest-util": "^27.0.0", + "json5": "2.x", + "lodash.memoize": "4.x", + "make-error": "1.x", + "semver": "7.x", + "yargs-parser": "20.x" + }, + "dependencies": { + "semver": { + "version": "7.3.5", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", + "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + } + } + }, "ts-node": { "version": "10.7.0", "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.7.0.tgz", @@ -4626,6 +8484,15 @@ "integrity": "sha512-FZIXf1ksVyLcfr7M317jbB67XFJhOO1YqdTcuGaq9q5jLUoTikukZ+98TPjKiP2jC5CgmYdWWYs0s2nLSU0/1A==", "dev": true }, + "type-check": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", + "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", + "dev": true, + "requires": { + "prelude-ls": "~1.1.2" + } + }, "type-detect": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", @@ -4653,6 +8520,12 @@ "integrity": "sha512-HM/hFigTBHZhLXshn9sN37H085+hQGeJHJ/X7LpBWLID/fbc2acUMfU+lGD98X81sKP+pFa9f0DZmCwB9GnbAg==", "dev": true }, + "universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", + "dev": true + }, "uuid": { "version": "3.4.0", "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", @@ -4665,6 +8538,84 @@ "integrity": "sha512-mpSYqfsFvASnSn5qMiwrr4VKfumbPyONLCOPmsR3A6pTY/r0+tSaVbgPWSAIuzbk3lCTa+FForeTiO+wBQGkjA==", "dev": true }, + "v8-to-istanbul": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-8.1.1.tgz", + "integrity": "sha512-FGtKtv3xIpR6BYhvgH8MI/y78oT7d8Au3ww4QIxymrCtZEh5b8gCw2siywE+puhEmuWKDtmfrvF5UlB298ut3w==", + "dev": true, + "requires": { + "@types/istanbul-lib-coverage": "^2.0.1", + "convert-source-map": "^1.6.0", + "source-map": "^0.7.3" + }, + "dependencies": { + "source-map": { + "version": "0.7.3", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", + "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==", + "dev": true + } + } + }, + "w3c-hr-time": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz", + "integrity": "sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ==", + "dev": true, + "requires": { + "browser-process-hrtime": "^1.0.0" + } + }, + "w3c-xmlserializer": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-2.0.0.tgz", + "integrity": "sha512-4tzD0mF8iSiMiNs30BiLO3EpfGLZUT2MSX/G+o7ZywDzliWQ3OPtTZ0PTC3B3ca1UAf4cJMHB+2Bf56EriJuRA==", + "dev": true, + "requires": { + "xml-name-validator": "^3.0.0" + } + }, + "walker": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", + "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", + "dev": true, + "requires": { + "makeerror": "1.0.12" + } + }, + "webidl-conversions": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-6.1.0.tgz", + "integrity": "sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w==", + "dev": true + }, + "whatwg-encoding": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz", + "integrity": "sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw==", + "dev": true, + "requires": { + "iconv-lite": "0.4.24" + } + }, + "whatwg-mimetype": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz", + "integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==", + "dev": true + }, + "whatwg-url": { + "version": "8.7.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-8.7.0.tgz", + "integrity": "sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==", + "dev": true, + "requires": { + "lodash": "^4.7.0", + "tr46": "^2.1.0", + "webidl-conversions": "^6.1.0" + } + }, "which": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", @@ -4680,10 +8631,10 @@ "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", "dev": true }, - "workerpool": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.0.tgz", - "integrity": "sha512-Rsk5qQHJ9eowMH28Jwhe8HEbmdYDX4lwoMWshiCXugjtHqMD9ZbiqSDLxcsfdqsETPzVUtX5s1Z5kStiIM6l4A==", + "word-wrap": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", + "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", "dev": true }, "wrap-ansi": { @@ -4715,12 +8666,37 @@ "typedarray-to-buffer": "^3.1.5" } }, + "ws": { + "version": "7.5.7", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.7.tgz", + "integrity": "sha512-KMvVuFzpKBuiIXW3E4u3mySRO2/mCHSyZDJQM5NQ9Q9KHWHWh0NHgfbRMLLrceUK5qAL4ytALJbpRMjixFZh8A==", + "dev": true, + "requires": {} + }, + "xml-name-validator": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-3.0.0.tgz", + "integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==", + "dev": true + }, + "xmlchars": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz", + "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==", + "dev": true + }, "y18n": { "version": "5.0.8", "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", "dev": true }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + }, "yargs": { "version": "16.2.0", "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", @@ -4742,43 +8718,11 @@ "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", "dev": true }, - "yargs-unparser": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", - "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", - "dev": true, - "requires": { - "camelcase": "^6.0.0", - "decamelize": "^4.0.0", - "flat": "^5.0.2", - "is-plain-obj": "^2.1.0" - }, - "dependencies": { - "camelcase": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", - "dev": true - }, - "decamelize": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", - "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", - "dev": true - } - } - }, "yn": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", "dev": true - }, - "yocto-queue": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", - "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", - "dev": true } } } diff --git a/package.json b/package.json index ce71ae0..fb2b7dd 100644 --- a/package.json +++ b/package.json @@ -4,7 +4,7 @@ "description": "Code for \"Principles of Programming Languages\" course", "main": "index.js", "scripts": { - "test": "mocha --require ts-node/register test/**/*.test.ts", + "test": "jest", "coverage": "nyc --reporter=html npm test" }, "keywords": [], @@ -15,14 +15,14 @@ "s-expression": "^3.1.1" }, "devDependencies": { - "@types/chai": "^4.3.0", - "@types/mocha": "^9.1.0", + "@types/jest": "^27.4.1", "@types/node": "^17.0.21", "@types/ramda": "^0.28.1", - "chai": "^4.3.6", - "mocha": "^9.2.2", + "jest": "^27.5.1", + "jest-extended": "^2.0.0", "nyc": "^15.1.0", + "ts-jest": "^27.1.3", "ts-node": "^10.7.0", "typescript": "^4.6.2" } -} +} \ No newline at end of file diff --git a/test/L1/L1-ast.test.ts b/test/L1/L1-ast.test.ts index 0eedee6..b15ccf0 100644 --- a/test/L1/L1-ast.test.ts +++ b/test/L1/L1-ast.test.ts @@ -1,77 +1,76 @@ -import { expect } from "chai"; import { isNumExp, parseL1Exp, isBoolExp, isVarRef, isDefineExp, isVarDecl, isAppExp, isProgram, parseL1 } from "../../src/L1/L1-ast"; import { isOkT, isFailure, bind } from "../../src/shared/result"; import { parse as p } from "../../src/shared/parser"; describe("L1 Parsing", () => { it("parses a number as NumExp", () => { - expect(bind(p("1"), parseL1Exp)).to.satisfy(isOkT(isNumExp)); + expect(bind(p("1"), parseL1Exp)).toSatisfy(isOkT(isNumExp)); }); it("parses a boolean as BoolExp", () => { - expect(bind(p("#t"), parseL1Exp)).to.satisfy(isOkT(isBoolExp)); - expect(bind(p("#f"), parseL1Exp)).to.satisfy(isOkT(isBoolExp)); + expect(bind(p("#t"), parseL1Exp)).toSatisfy(isOkT(isBoolExp)); + expect(bind(p("#f"), parseL1Exp)).toSatisfy(isOkT(isBoolExp)); }); it("parses a variable as VarRef", () => { - expect(bind(p("x"), parseL1Exp)).to.satisfy(isOkT(isVarRef)); + expect(bind(p("x"), parseL1Exp)).toSatisfy(isOkT(isVarRef)); }); it('parses "define" expressions as DefineExp', () => { const parsed = bind(p("(define x 1)"), parseL1Exp); - expect(parsed).to.satisfy(isOkT(isDefineExp)); + expect(parsed).toSatisfy(isOkT(isDefineExp)); if (isOkT(isDefineExp)(parsed)) { - expect(parsed.value.var).to.satisfy(isVarDecl); - expect(parsed.value.val).to.satisfy(isNumExp); + expect(parsed.value.var).toSatisfy(isVarDecl); + expect(parsed.value.val).toSatisfy(isNumExp); } else { expect.fail(`${JSON.stringify(parsed)} not a "define" expression`); } }); it("parses application expressions as AppExp", () => { - expect(bind(p("(> x 1)"), parseL1Exp)).to.satisfy(isOkT(isAppExp)); - expect(bind(p("(> (+ x x) (* x x))"), parseL1Exp)).to.satisfy(isOkT(isAppExp)); + expect(bind(p("(> x 1)"), parseL1Exp)).toSatisfy(isOkT(isAppExp)); + expect(bind(p("(> (+ x x) (* x x))"), parseL1Exp)).toSatisfy(isOkT(isAppExp)); }); it("parses a program as Program", () => { - expect(parseL1("(L1 (define x 1) (> (+ x 1) (* x x)))")).to.satisfy(isOkT(isProgram)); + expect(parseL1("(L1 (define x 1) (> (+ x 1) (* x x)))")).toSatisfy(isOkT(isProgram)); }); describe("Failures", () => { it("returns a Failure when parsing a single-token program", () => { - expect(parseL1("x")).to.satisfy(isFailure); + expect(parseL1("x")).toSatisfy(isFailure); }); it("returns a Failure when parsing an empty program", () => { - expect(parseL1("")).to.satisfy(isFailure); + expect(parseL1("")).toSatisfy(isFailure); }); it("returns a Failure if the program does not start with (L1 ...)", () => { - expect(parseL1("(+ 1 2)")).to.satisfy(isFailure); + expect(parseL1("(+ 1 2)")).toSatisfy(isFailure); }); it("returns a Failure for a program with no Exps", () => { - expect(parseL1("(L1)")).to.satisfy(isFailure); + expect(parseL1("(L1)")).toSatisfy(isFailure); }); it("returns a Failure if a program has an empty Exp", () => { - expect(parseL1("(L1 ())")).to.satisfy(isFailure); + expect(parseL1("(L1 ())")).toSatisfy(isFailure); }); it('returns a Failure for an ill-formed "define"', () => { - expect(bind(p("(define)"), parseL1Exp)).to.satisfy(isFailure); - expect(bind(p("(define x)"), parseL1Exp)).to.satisfy(isFailure); - expect(bind(p("(define x y z)"), parseL1Exp)).to.satisfy(isFailure); - expect(bind(p('(define "1" y)'), parseL1Exp)).to.satisfy(isFailure); - expect(bind(p('(define 1 y)'), parseL1Exp)).to.satisfy(isFailure); + expect(bind(p("(define)"), parseL1Exp)).toSatisfy(isFailure); + expect(bind(p("(define x)"), parseL1Exp)).toSatisfy(isFailure); + expect(bind(p("(define x y z)"), parseL1Exp)).toSatisfy(isFailure); + expect(bind(p('(define "1" y)'), parseL1Exp)).toSatisfy(isFailure); + expect(bind(p('(define 1 y)'), parseL1Exp)).toSatisfy(isFailure); }); it("returns a Failure for an empty CExp", () => { - expect(bind(p("(+ ())"), parseL1Exp)).to.satisfy(isFailure); + expect(bind(p("(+ ())"), parseL1Exp)).toSatisfy(isFailure); }); it("retruns a Failure when parsing SexpStrings", () => { - expect(bind(p('"string"'), parseL1Exp)).to.satisfy(isFailure); + expect(bind(p('"string"'), parseL1Exp)).toSatisfy(isFailure); }); }) }); diff --git a/test/L1/L1-eval.test.ts b/test/L1/L1-eval.test.ts index 682a765..17fa158 100644 --- a/test/L1/L1-eval.test.ts +++ b/test/L1/L1-eval.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { parseL1, parseL1Exp, Exp } from "../../src/L1/L1-ast"; import { evalL1program, makeEnv, makeEmptyEnv, evalSequence } from '../../src/L1/L1-eval'; import { bind, makeOk, isFailure } from '../../src/shared/result'; @@ -6,19 +5,19 @@ import { parse as p } from "../../src/shared/parser"; describe('L1 Eval', () => { it('Evaluates a program without an explicit environment', () => { - expect(bind(parseL1(`(L1 (define x 3) + #t (+ (* x x) (+ x x)))`), evalL1program)).to.deep.equal(makeOk(15)); + expect(bind(parseL1(`(L1 (define x 3) + #t (+ (* x x) (+ x x)))`), evalL1program)).toEqual(makeOk(15)); }); it('Evaluates a program with an explicit environment', () => { const env1 = makeEnv("x", 1, makeEmptyEnv()); const result1 = bind(bind(p("(+ x 2)"), parseL1Exp), (exp: Exp) => evalSequence([exp], env1)); - expect(result1).to.deep.equal(makeOk(3)); + expect(result1).toEqual(makeOk(3)); const env2 = makeEnv("x", 1, makeEnv("y", 2, makeEmptyEnv())); const result2 = bind(bind(p("(+ y 2)"), parseL1Exp), (exp: Exp) => evalSequence([exp], env2)); - expect(result2).to.deep.equal(makeOk(4)); + expect(result2).toEqual(makeOk(4)); }); describe("Failures", () => { @@ -26,22 +25,22 @@ describe('L1 Eval', () => { const env = makeEmptyEnv(); const result = bind(bind(p("(+ y 2)"), parseL1Exp), (exp: Exp) => evalSequence([exp], env)); - expect(result).to.satisfy(isFailure); + expect(result).toSatisfy(isFailure); }); it("returns a Failure when accessing a variable not present in the env", () => { const env = makeEnv("x", 1, makeEmptyEnv()); const result = bind(bind(p("(+ y 2)"), parseL1Exp), (exp: Exp) => evalSequence([exp], env)); - expect(result).to.satisfy(isFailure); + expect(result).toSatisfy(isFailure); }); it("returns a Failure when evaluating an empty sequence of Exps", () => { - expect(evalL1program({ tag: "Program", exps: []})).to.satisfy(isFailure); + expect(evalL1program({ tag: "Program", exps: []})).toSatisfy(isFailure); }); it("returns a Failure for an unknown primitive op", () => { - expect(bind(bind(p("(eq? 1 1)"), parseL1Exp), exp => evalSequence([exp], makeEmptyEnv()))).to.satisfy(isFailure); + expect(bind(bind(p("(eq? 1 1)"), parseL1Exp), exp => evalSequence([exp], makeEmptyEnv()))).toSatisfy(isFailure); }) }); }); diff --git a/test/L3/L3-normal.test.ts b/test/L3/L3-normal.test.ts index f938f91..21b879a 100644 --- a/test/L3/L3-normal.test.ts +++ b/test/L3/L3-normal.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { parseL3, makePrimOp } from '../../src/L3/L3-ast'; import { listPrim } from "../../src/L3/evalPrimitive"; import { evalNormalParse, evalNormalProgram } from '../../src/L3/L3-normal'; @@ -7,46 +6,46 @@ import { makeOk, isOk, Result, bind } from "../../src/shared/result"; describe('L3 Normal Eval', () => { it('evaluates atoms', () => { - expect(evalNormalParse("1")).to.deep.equal(makeOk(1)); - expect(evalNormalParse("#t")).to.deep.equal(makeOk(true)); - expect(evalNormalParse("+")).to.deep.equal(makeOk(makePrimOp("+"))); + expect(evalNormalParse("1")).toEqual(makeOk(1)); + expect(evalNormalParse("#t")).toEqual(makeOk(true)); + expect(evalNormalParse("+")).toEqual(makeOk(makePrimOp("+"))); }); it('evaluates primitive procedures', () => { - expect(evalNormalParse("(+ 1 2)")).to.deep.equal(makeOk(3)); - expect(evalNormalParse("(< 1 2)")).to.deep.equal(makeOk(true)); - expect(evalNormalParse("(not (> 1 2))")).to.deep.equal(makeOk(true)); - expect(evalNormalParse("(+ (* 2 2) 3)")).to.deep.equal(makeOk(7)); + expect(evalNormalParse("(+ 1 2)")).toEqual(makeOk(3)); + expect(evalNormalParse("(< 1 2)")).toEqual(makeOk(true)); + expect(evalNormalParse("(not (> 1 2))")).toEqual(makeOk(true)); + expect(evalNormalParse("(+ (* 2 2) 3)")).toEqual(makeOk(7)); }); it('evaluates L2 syntactic forms', () => { - expect(evalNormalParse("(if (< 1 2) 3 -3)")).to.deep.equal(makeOk(3)); - expect(evalNormalParse("(lambda (x) x)")).to.satisfy((e: Result) => isOk(e) && isClosure(e.value)); + expect(evalNormalParse("(if (< 1 2) 3 -3)")).toEqual(makeOk(3)); + expect(evalNormalParse("(lambda (x) x)")).toSatisfy((e: Result) => isOk(e) && isClosure(e.value)); }); it('evaluates L3 syntactic forms', () => { - expect(evalNormalParse("(cons 1 '())")).to.deep.equal(makeOk(listPrim([1]))); - expect(evalNormalParse("(car '(1 2))")).to.deep.equal(makeOk(1)); - expect(evalNormalParse("(cdr '(1 2))")).to.deep.equal(makeOk(listPrim([2]))); - expect(evalNormalParse("(number? 'x)")).to.deep.equal(makeOk(false)); - expect(evalNormalParse("(number? 1)")).to.deep.equal(makeOk(true)); - expect(evalNormalParse("(symbol? 'x)")).to.deep.equal(makeOk(true)); - expect(evalNormalParse("(symbol? 1)")).to.deep.equal(makeOk(false)); - expect(evalNormalParse("(pair? 1)")).to.deep.equal(makeOk(false)); - expect(evalNormalParse("(pair? '(1 2))")).to.deep.equal(makeOk(true)); - expect(evalNormalParse("(boolean? 1)")).to.deep.equal(makeOk(false)); - expect(evalNormalParse("(boolean? #t)")).to.deep.equal(makeOk(true)); - expect(evalNormalParse("(eq? 'x 'x)")).to.deep.equal(makeOk(true)); + expect(evalNormalParse("(cons 1 '())")).toEqual(makeOk(listPrim([1]))); + expect(evalNormalParse("(car '(1 2))")).toEqual(makeOk(1)); + expect(evalNormalParse("(cdr '(1 2))")).toEqual(makeOk(listPrim([2]))); + expect(evalNormalParse("(number? 'x)")).toEqual(makeOk(false)); + expect(evalNormalParse("(number? 1)")).toEqual(makeOk(true)); + expect(evalNormalParse("(symbol? 'x)")).toEqual(makeOk(true)); + expect(evalNormalParse("(symbol? 1)")).toEqual(makeOk(false)); + expect(evalNormalParse("(pair? 1)")).toEqual(makeOk(false)); + expect(evalNormalParse("(pair? '(1 2))")).toEqual(makeOk(true)); + expect(evalNormalParse("(boolean? 1)")).toEqual(makeOk(false)); + expect(evalNormalParse("(boolean? #t)")).toEqual(makeOk(true)); + expect(evalNormalParse("(eq? 'x 'x)")).toEqual(makeOk(true)); }); it('evaluates programs', () => { - expect(bind(parseL3(`(L3 (define x (+ 3 2)) (* x x))`), evalNormalProgram)).to.deep.equal(makeOk(25)); - expect(bind(parseL3(`(L3 (define x (+ 3 2)) (* x x) (+ x x))`), evalNormalProgram)).to.deep.equal(makeOk(10)); + expect(bind(parseL3(`(L3 (define x (+ 3 2)) (* x x))`), evalNormalProgram)).toEqual(makeOk(25)); + expect(bind(parseL3(`(L3 (define x (+ 3 2)) (* x x) (+ x x))`), evalNormalProgram)).toEqual(makeOk(10)); }); it('evaluates procedures', () => { - expect(bind(parseL3(`(L3 (define f (lambda (x) (* x x))) (f 3))`), evalNormalProgram)).to.deep.equal(makeOk(9)); - expect(bind(parseL3(`(L3 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))`), evalNormalProgram)).to.deep.equal(makeOk(3)); + expect(bind(parseL3(`(L3 (define f (lambda (x) (* x x))) (f 3))`), evalNormalProgram)).toEqual(makeOk(9)); + expect(bind(parseL3(`(L3 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))`), evalNormalProgram)).toEqual(makeOk(3)); }); it('evaluates recursive procedures', () => { @@ -55,7 +54,7 @@ describe('L3 Normal Eval', () => { (if (= x 0) 1 (* x (f (- x 1)))))) - (f 5))`), evalNormalProgram)).to.deep.equal(makeOk(120)); + (f 5))`), evalNormalProgram)).toEqual(makeOk(120)); }); it('evaluates higher-order functions', () => { @@ -65,7 +64,7 @@ describe('L3 Normal Eval', () => { (if (eq? l '()) l (cons (f (car l)) (map f (cdr l)))))) - (map (lambda (x) (* x x)) '(1 2 3)))`), evalNormalProgram)).to.deep.equal(makeOk(listPrim([1, 4, 9]))); + (map (lambda (x) (* x x)) '(1 2 3)))`), evalNormalProgram)).toEqual(makeOk(listPrim([1, 4, 9]))); expect(bind(parseL3(` (L3 (define empty? (lambda (x) (eq? x '()))) @@ -75,11 +74,11 @@ describe('L3 Normal Eval', () => { (if (pred (car l)) (cons (car l) (filter pred (cdr l))) (filter pred (cdr l)))))) - (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalNormalProgram)).to.deep.equal(makeOk(listPrim([1, 3]))); + (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalNormalProgram)).toEqual(makeOk(listPrim([1, 3]))); expect(bind(parseL3(` (L3 (define compose (lambda (f g) (lambda (x) (f (g x))))) - ((compose not number?) 2))`), evalNormalProgram)).to.deep.equal(makeOk(false)); + ((compose not number?) 2))`), evalNormalProgram)).toEqual(makeOk(false)); }); it('evaluates the examples', () => { @@ -92,12 +91,12 @@ describe('L3 Normal Eval', () => { (if (= n 1) f (lambda (x) (f ((nf f (- n 1)) x))))))) - ((nf (lambda (x) (* x x)) 2) 3))`), evalNormalProgram)).to.deep.equal(makeOk(81)); + ((nf (lambda (x) (* x x)) 2) 3))`), evalNormalProgram)).toEqual(makeOk(81)); // Accidental capture of the z variable if no renaming expect(bind(parseL3(` (L3 (define z (lambda (x) (* x x))) - (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalNormalProgram)).to.deep.equal(makeOk(4)); + (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalNormalProgram)).toEqual(makeOk(4)); // Y-combinator expect(bind(parseL3(` @@ -106,19 +105,19 @@ describe('L3 Normal Eval', () => { (lambda (n) (if (= n 0) 1 - (* n ((fact fact) (- n 1))))))) 6))`), evalNormalProgram)).to.deep.equal(makeOk(720)); + (* n ((fact fact) (- n 1))))))) 6))`), evalNormalProgram)).toEqual(makeOk(720)); }); it('evaluates programs which would loop in applicative order, but complete in normal order', () => { expect(bind(parseL3(` (L3 (define loop (lambda () (loop))) (define f (lambda (x y z) (if (= x 1) y z))) - (f 1 2 (loop)))`), evalNormalProgram)).to.deep.equal(makeOk(2)); + (f 1 2 (loop)))`), evalNormalProgram)).toEqual(makeOk(2)); expect(bind(parseL3(` (L3 (define loop (lambda (x) (loop x))) (define g (lambda (x) 5)) - (g (loop 0)))`), evalNormalProgram)).to.deep.equal(makeOk(5)); + (g (loop 0)))`), evalNormalProgram)).toEqual(makeOk(5)); }); it('evaluates programs which would give an error in applicative order, but not in normal order', () => { @@ -128,13 +127,13 @@ describe('L3 Normal Eval', () => { (if (= a 0) 1 b))) - (try 0 (/ 1 0)))`), evalNormalProgram)).to.deep.equal(makeOk(1)); + (try 0 (/ 1 0)))`), evalNormalProgram)).toEqual(makeOk(1)); }); it('evaluates programs which would cause side-effects in applicative order, but not in normal order', () => { expect(bind(parseL3(` (L3 (define f (lambda (x) (display x) (newline) (+ x 1))) (define g (lambda (x) 5)) - (g (f 0)))`), evalNormalProgram)).to.deep.equal(makeOk(5)); + (g (f 0)))`), evalNormalProgram)).toEqual(makeOk(5)); }); }); diff --git a/test/L3/L3.test.ts b/test/L3/L3.test.ts index ed3723a..a737ba3 100644 --- a/test/L3/L3.test.ts +++ b/test/L3/L3.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { makeNumExp, parseL3Exp, unparseL3, parseL3, Exp } from '../../src/L3/L3-ast'; import { makeVarDecl, makeVarRef } from '../../src/L3/L3-ast'; import { isAppExp, isBoolExp, isCExp, isDefineExp, isIfExp, isLetExp, isLitExp, isNumExp, isPrimOp, @@ -18,113 +17,113 @@ describe('L3 Environment', () => { const env2 = makeEnv("b", 2, env1); const env3 = makeEnv("a", 3, env2); - expect(isEnv(emptyEnv)).to.be.true; - expect(isEnv(env1)).to.be.true; - expect(applyEnv(env1, "a")).to.deep.equal(makeOk(1)); - expect(applyEnv(env2, "a")).to.deep.equal(makeOk(1)); - expect(applyEnv(env2, "b")).to.deep.equal(makeOk(2)); - expect(applyEnv(env3, "a")).to.deep.equal(makeOk(3)); - expect(applyEnv(env3, "b")).to.deep.equal(makeOk(2)); + expect(isEnv(emptyEnv)).toBe(true); + expect(isEnv(env1)).toBe(true); + expect(applyEnv(env1, "a")).toEqual(makeOk(1)); + expect(applyEnv(env2, "a")).toEqual(makeOk(1)); + expect(applyEnv(env2, "b")).toEqual(makeOk(2)); + expect(applyEnv(env3, "a")).toEqual(makeOk(3)); + expect(applyEnv(env3, "b")).toEqual(makeOk(2)); }); }); describe('L3 Parsing', () => { it('parses atomic expressions', () => { - expect(bind(p("1"), parseL3Exp)).to.satisfy(isOkT(isNumExp)); - expect(bind(p("#t"), parseL3Exp)).to.satisfy(isOkT(isBoolExp)); - expect(bind(p("x"), parseL3Exp)).to.satisfy(isOkT(isVarRef)); - expect(bind(p('"a"'), parseL3Exp)).to.satisfy(isOkT(isStrExp)); - expect(bind(p(">"), parseL3Exp)).to.satisfy(isOkT(isPrimOp)); - expect(bind(p("="), parseL3Exp)).to.satisfy(isOkT(isPrimOp)); - expect(bind(p("string=?"), parseL3Exp)).to.satisfy(isOkT(isPrimOp)); - expect(bind(p("eq?"), parseL3Exp)).to.satisfy(isOkT(isPrimOp)); - expect(bind(p("cons"), parseL3Exp)).to.satisfy(isOkT(isPrimOp)); + expect(bind(p("1"), parseL3Exp)).toSatisfy(isOkT(isNumExp)); + expect(bind(p("#t"), parseL3Exp)).toSatisfy(isOkT(isBoolExp)); + expect(bind(p("x"), parseL3Exp)).toSatisfy(isOkT(isVarRef)); + expect(bind(p('"a"'), parseL3Exp)).toSatisfy(isOkT(isStrExp)); + expect(bind(p(">"), parseL3Exp)).toSatisfy(isOkT(isPrimOp)); + expect(bind(p("="), parseL3Exp)).toSatisfy(isOkT(isPrimOp)); + expect(bind(p("string=?"), parseL3Exp)).toSatisfy(isOkT(isPrimOp)); + expect(bind(p("eq?"), parseL3Exp)).toSatisfy(isOkT(isPrimOp)); + expect(bind(p("cons"), parseL3Exp)).toSatisfy(isOkT(isPrimOp)); }); it('parses programs', () => { - expect(parseL3("(L3 (define x 1) (> (+ x 1) (* x x)))")).to.satisfy(isOkT(isProgram)); + expect(parseL3("(L3 (define x 1) (> (+ x 1) (* x x)))")).toSatisfy(isOkT(isProgram)); }); it('parses define expressions', () => { const parsed = bind(p("(define x 1)"), parseL3Exp); - expect(parsed).to.satisfy(isOkT(isDefineExp)); + expect(parsed).toSatisfy(isOkT(isDefineExp)); if (isOkT(isDefineExp)(parsed)) { - expect(parsed.value.var).to.satisfy(isVarDecl); - expect(parsed.value.val).to.satisfy(isNumExp); + expect(parsed.value.var).toSatisfy(isVarDecl); + expect(parsed.value.val).toSatisfy(isNumExp); } }); it('parses applications', () => { - expect(bind(p("(> x 1)"), parseL3Exp)).to.satisfy(isOkT(isAppExp)); - expect(bind(p("(> (+ x x) (* x x))"), parseL3Exp)).to.satisfy(isOkT(isAppExp)); + expect(bind(p("(> x 1)"), parseL3Exp)).toSatisfy(isOkT(isAppExp)); + expect(bind(p("(> (+ x x) (* x x))"), parseL3Exp)).toSatisfy(isOkT(isAppExp)); }); it('parses "if" expressions', () => { - expect(bind(p("(if #t 1 2)"), parseL3Exp)).to.satisfy(isOkT(isIfExp)); - expect(bind(p("(if (< x 2) x 2)"), parseL3Exp)).to.satisfy(isOkT(isIfExp)); + expect(bind(p("(if #t 1 2)"), parseL3Exp)).toSatisfy(isOkT(isIfExp)); + expect(bind(p("(if (< x 2) x 2)"), parseL3Exp)).toSatisfy(isOkT(isIfExp)); }); it('parses procedures', () => { - expect(bind(p("(lambda () 1)"), parseL3Exp)).to.satisfy(isOkT(isProcExp)); - expect(bind(p("(lambda (x) x x)"), parseL3Exp)).to.satisfy(isOkT(isProcExp)); + expect(bind(p("(lambda () 1)"), parseL3Exp)).toSatisfy(isOkT(isProcExp)); + expect(bind(p("(lambda (x) x x)"), parseL3Exp)).toSatisfy(isOkT(isProcExp)); }); it('parses "let" expressions', () => { - expect(bind(p("(let ((a 1) (b #t)) (if b a (+ a 1)))"), parseL3Exp)).to.satisfy(isOkT(isLetExp)); + expect(bind(p("(let ((a 1) (b #t)) (if b a (+ a 1)))"), parseL3Exp)).toSatisfy(isOkT(isLetExp)); }); it('parses literal expressions', () => { - expect(bind(p("'a"), parseL3Exp)).to.satisfy(isOkT(isLitExp)); - expect(bind(p("'()"), parseL3Exp)).to.satisfy(isOkT(isLitExp)); - expect(bind(p("'(1)"), parseL3Exp)).to.satisfy(isOkT(isLitExp)); - expect(bind(p("'(1 . 2)"), parseL3Exp)).to.satisfy(isOkT(isLitExp)); - expect(bind(p("'(1 . (2 . 3))"), parseL3Exp)).to.satisfy(isOkT(isLitExp)); + expect(bind(p("'a"), parseL3Exp)).toSatisfy(isOkT(isLitExp)); + expect(bind(p("'()"), parseL3Exp)).toSatisfy(isOkT(isLitExp)); + expect(bind(p("'(1)"), parseL3Exp)).toSatisfy(isOkT(isLitExp)); + expect(bind(p("'(1 . 2)"), parseL3Exp)).toSatisfy(isOkT(isLitExp)); + expect(bind(p("'(1 . (2 . 3))"), parseL3Exp)).toSatisfy(isOkT(isLitExp)); }); it('returns an error for an invalid literal', () => { - expect(bind(p("'(1 . 2 3)"), parseL3Exp)).to.satisfy(isFailure); + expect(bind(p("'(1 . 2 3)"), parseL3Exp)).toSatisfy(isFailure); }); describe("Failures", () => { it("returns a Failure when parsing a single-token program", () => { - expect(parseL3("x")).to.satisfy(isFailure); + expect(parseL3("x")).toSatisfy(isFailure); }); it("returns a Failure when parsing an empty program", () => { - expect(parseL3("")).to.satisfy(isFailure); + expect(parseL3("")).toSatisfy(isFailure); }); it("returns a Failure if the program does not start with (L3 ...)", () => { - expect(parseL3("(+ 1 2)")).to.satisfy(isFailure); + expect(parseL3("(+ 1 2)")).toSatisfy(isFailure); }); it("returns a Failure for a program with no Exps", () => { - expect(parseL3("(L3)")).to.satisfy(isFailure); + expect(parseL3("(L3)")).toSatisfy(isFailure); }); it("returns a Failure if a program has an empty Exp", () => { - expect(parseL3("(L3 ())")).to.satisfy(isFailure); + expect(parseL3("(L3 ())")).toSatisfy(isFailure); }); it('returns a Failure for an ill-formed "define"', () => { - expect(bind(p("(define)"), parseL3Exp)).to.satisfy(isFailure); - expect(bind(p("(define x)"), parseL3Exp)).to.satisfy(isFailure); - expect(bind(p("(define x y z)"), parseL3Exp)).to.satisfy(isFailure); - expect(bind(p('(define "1" y)'), parseL3Exp)).to.satisfy(isFailure); - expect(bind(p('(define 1 y)'), parseL3Exp)).to.satisfy(isFailure); + expect(bind(p("(define)"), parseL3Exp)).toSatisfy(isFailure); + expect(bind(p("(define x)"), parseL3Exp)).toSatisfy(isFailure); + expect(bind(p("(define x y z)"), parseL3Exp)).toSatisfy(isFailure); + expect(bind(p('(define "1" y)'), parseL3Exp)).toSatisfy(isFailure); + expect(bind(p('(define 1 y)'), parseL3Exp)).toSatisfy(isFailure); }); it("returns a Failure for an empty CExp", () => { - expect(bind(p("(+ ())"), parseL3Exp)).to.satisfy(isFailure); + expect(bind(p("(+ ())"), parseL3Exp)).toSatisfy(isFailure); }); it("returns a Failure for an ill-formed special form", () => { - expect(bind(p("(if)"), parseL3Exp)).to.satisfy(isFailure); - expect(bind(p("(if 1)"), parseL3Exp)).to.satisfy(isFailure); - expect(bind(p("(lambda x x)"), parseL3Exp)).to.satisfy(isFailure); - expect(bind(p("(let x x)"), parseL3Exp)).to.satisfy(isFailure); - expect(bind(p("(let (x y) x)"), parseL3Exp)).to.satisfy(isFailure); - expect(bind(p("(let ((1 y)) x)"), parseL3Exp)).to.satisfy(isFailure); + expect(bind(p("(if)"), parseL3Exp)).toSatisfy(isFailure); + expect(bind(p("(if 1)"), parseL3Exp)).toSatisfy(isFailure); + expect(bind(p("(lambda x x)"), parseL3Exp)).toSatisfy(isFailure); + expect(bind(p("(let x x)"), parseL3Exp)).toSatisfy(isFailure); + expect(bind(p("(let (x y) x)"), parseL3Exp)).toSatisfy(isFailure); + expect(bind(p("(let ((1 y)) x)"), parseL3Exp)).toSatisfy(isFailure); }); }); }); @@ -136,191 +135,191 @@ describe('L3 Unparse', () => { it("doesn't change concrete values", () => { const concretes = ["1", "#t", "x", '"a"', ">", "=", "string=?", "eq?", "cons"]; concretes.forEach(concrete => { - expect(roundTrip(concrete)).to.deep.equal(makeOk(concrete)); + expect(roundTrip(concrete)).toEqual(makeOk(concrete)); }); }); it('unparses a program', () => { const program = "(L3 (define x 1) (> (+ x 1) (* x x)))"; const result = bind(parseL3(program), program => makeOk(unparseL3(program))); - expect(result).to.deep.equal(makeOk(program)); + expect(result).toEqual(makeOk(program)); }); it('unparses "define" expressions', () => { const define = "(define x 1)"; - expect(roundTrip(define)).to.deep.equal(makeOk(define)); + expect(roundTrip(define)).toEqual(makeOk(define)); }); it('unparses applications', () => { const app1 = "(> x 1)"; const app2 = "(> (+ x x) (* x x))"; - expect(roundTrip(app1)).to.deep.equal(makeOk(app1)); - expect(roundTrip(app2)).to.deep.equal(makeOk(app2)); + expect(roundTrip(app1)).toEqual(makeOk(app1)); + expect(roundTrip(app2)).toEqual(makeOk(app2)); }); it('unparses "if" expressions', () => { const if1 = "(if #t 1 2)"; const if2 = "(if (< x 2) x 2)"; - expect(roundTrip(if1)).to.deep.equal(makeOk(if1)); - expect(roundTrip(if2)).to.deep.equal(makeOk(if2)); + expect(roundTrip(if1)).toEqual(makeOk(if1)); + expect(roundTrip(if2)).toEqual(makeOk(if2)); }); it('unparses procedures', () => { const proc1 = "(lambda () 1)"; const proc2 = "(lambda (x) x x)"; - expect(roundTrip(proc1)).to.deep.equal(makeOk(proc1)); - expect(roundTrip(proc2)).to.deep.equal(makeOk(proc2)); + expect(roundTrip(proc1)).toEqual(makeOk(proc1)); + expect(roundTrip(proc2)).toEqual(makeOk(proc2)); }); it('unparses "let" expressions', () => { const let1 = "(let ((a 1) (b #t)) (if b a (+ a 1)))"; - expect(roundTrip(let1)).to.deep.equal(makeOk(let1)); + expect(roundTrip(let1)).toEqual(makeOk(let1)); }); it('unparses literal expressions', () => { const lits = ["'a", "'()", "'(1)", "'(1 . 2)", "'(1 2 . 3)"]; lits.forEach(lit => { - expect(roundTrip(lit)).to.deep.equal(makeOk(lit)); + expect(roundTrip(lit)).toEqual(makeOk(lit)); }); }); it('normalizes dotted pairs', () => { - expect(roundTrip("'(1 . (2 . 3))")).to.deep.equal(makeOk("'(1 2 . 3)")); + expect(roundTrip("'(1 . (2 . 3))")).toEqual(makeOk("'(1 2 . 3)")); }); }); describe('L3 Eval', () => { it('evaluates data type literals', () => { - expect(evalParse("1")).to.deep.equal(makeOk(1)); - expect(evalParse("#t")).to.deep.equal(makeOk(true)); - expect(evalParse("#f")).to.deep.equal(makeOk(false)); - expect(evalParse("'a")).to.deep.equal(makeOk(makeSymbolSExp("a"))); - expect(evalParse('"a"')).to.deep.equal(makeOk("a")); - expect(evalParse("'()")).to.deep.equal(makeOk(makeEmptySExp())); - expect(evalParse("'(1 2)")).to.deep.equal(makeOk(listPrim([1, 2]))); - expect(evalParse("'(1 (2))")).to.deep.equal(makeOk(listPrim([1, listPrim([2])]))); + expect(evalParse("1")).toEqual(makeOk(1)); + expect(evalParse("#t")).toEqual(makeOk(true)); + expect(evalParse("#f")).toEqual(makeOk(false)); + expect(evalParse("'a")).toEqual(makeOk(makeSymbolSExp("a"))); + expect(evalParse('"a"')).toEqual(makeOk("a")); + expect(evalParse("'()")).toEqual(makeOk(makeEmptySExp())); + expect(evalParse("'(1 2)")).toEqual(makeOk(listPrim([1, 2]))); + expect(evalParse("'(1 (2))")).toEqual(makeOk(listPrim([1, listPrim([2])]))); }); describe('Primitive Procedures', () => { it('evaluates "+"', () => { - expect(evalParse("(+ 1 2)")).to.deep.equal(makeOk(3)); + expect(evalParse("(+ 1 2)")).toEqual(makeOk(3)); }); it('evaluates "-"', () => { - expect(evalParse("(- 2 1)")).to.deep.equal(makeOk(1)); + expect(evalParse("(- 2 1)")).toEqual(makeOk(1)); }); it('evaluates "*"', () => { - expect(evalParse("(* 2 3)")).to.deep.equal(makeOk(6)); + expect(evalParse("(* 2 3)")).toEqual(makeOk(6)); }); it('evaluates "/"', () => { - expect(evalParse("(/ 4 2)")).to.deep.equal(makeOk(2)); + expect(evalParse("(/ 4 2)")).toEqual(makeOk(2)); }); it('evaluates "<"', () => { - expect(evalParse("(< 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(< 4 2)")).toEqual(makeOk(false)); }); it('evaluates ">"', () => { - expect(evalParse("(> 4 2)")).to.deep.equal(makeOk(true)); + expect(evalParse("(> 4 2)")).toEqual(makeOk(true)); }); it('evaluates "="', () => { - expect(evalParse("(= 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(= 4 2)")).toEqual(makeOk(false)); }); it('evaluates "not"', () => { - expect(evalParse("(not #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(not #t)")).toEqual(makeOk(false)); }); it('evaluates "eq?"', () => { - expect(evalParse("(eq? 'a 'a)")).to.deep.equal(makeOk(true)); + expect(evalParse("(eq? 'a 'a)")).toEqual(makeOk(true)); }); it('evaluates "string=?"', () => { - expect(evalParse('(string=? "a" "a")')).to.deep.equal(makeOk(true)); + expect(evalParse('(string=? "a" "a")')).toEqual(makeOk(true)); }); it('evaluates "cons"', () => { - expect(evalParse("(cons 1 '())")).to.deep.equal(makeOk(listPrim([1]))); - expect(evalParse("(cons 1 '(2))")).to.deep.equal(makeOk(listPrim([1, 2]))); + expect(evalParse("(cons 1 '())")).toEqual(makeOk(listPrim([1]))); + expect(evalParse("(cons 1 '(2))")).toEqual(makeOk(listPrim([1, 2]))); }); it('evaluates "car"', () => { - expect(evalParse("(car '(1 2))")).to.deep.equal(makeOk(1)); + expect(evalParse("(car '(1 2))")).toEqual(makeOk(1)); }); it('evaluates "cdr"', () => { - expect(evalParse("(cdr '(1 2))")).to.deep.equal(makeOk(listPrim([2]))); - expect(evalParse("(cdr '(1))")).to.deep.equal(makeOk(makeEmptySExp())); + expect(evalParse("(cdr '(1 2))")).toEqual(makeOk(listPrim([2]))); + expect(evalParse("(cdr '(1))")).toEqual(makeOk(makeEmptySExp())); }); it('evaluates "pair?"', () => { - expect(evalParse("(pair? '(1))")).to.deep.equal(makeOk(true)); - expect(evalParse("(pair? '())")).to.deep.equal(makeOk(false)); + expect(evalParse("(pair? '(1))")).toEqual(makeOk(true)); + expect(evalParse("(pair? '())")).toEqual(makeOk(false)); }); it('evaluates "number?"', () => { - expect(evalParse("(number? 1)")).to.deep.equal(makeOk(true)); - expect(evalParse("(number? #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(number? 1)")).toEqual(makeOk(true)); + expect(evalParse("(number? #t)")).toEqual(makeOk(false)); }); it('evaluates "boolean?"', () => { - expect(evalParse("(boolean? #t)")).to.deep.equal(makeOk(true)); - expect(evalParse("(boolean? 0)")).to.deep.equal(makeOk(false)); + expect(evalParse("(boolean? #t)")).toEqual(makeOk(true)); + expect(evalParse("(boolean? 0)")).toEqual(makeOk(false)); }); it('evaluates "symbol?"', () => { - expect(evalParse("(symbol? 'a)")).to.deep.equal(makeOk(true)); - expect(evalParse('(symbol? "a")')).to.deep.equal(makeOk(false)); + expect(evalParse("(symbol? 'a)")).toEqual(makeOk(true)); + expect(evalParse('(symbol? "a")')).toEqual(makeOk(false)); }); it('evaluates "string?"', () => { - expect(evalParse('(string? "a")')).to.deep.equal(makeOk(true)); - expect(evalParse("(string? 'a)")).to.deep.equal(makeOk(false)); + expect(evalParse('(string? "a")')).toEqual(makeOk(true)); + expect(evalParse("(string? 'a)")).toEqual(makeOk(false)); }); }); it('evaluates dotted pairs', () => { - expect(evalParse("(cons 1 2)")).to.deep.equal(makeOk(makeCompoundSExp(1, 2))); - expect(evalParse("(car (cons 1 2))")).to.deep.equal(makeOk(1)); - expect(evalParse("(cdr (cons 1 2))")).to.deep.equal(makeOk(2)); - expect(evalParse("(pair? (cons 1 2))")).to.deep.equal(makeOk(true)); - expect(evalParse("(car '(1 . 2))")).to.deep.equal(makeOk(1)); - expect(evalParse("(cdr '(1 . 2))")).to.deep.equal(makeOk(2)); - expect(evalParse("(car (cdr '(1 . (2 . 3))))")).to.deep.equal(makeOk(2)); - expect(evalParse("(cdr (cdr '(1 . (2 . 3))))")).to.deep.equal(makeOk(3)); - expect(evalParse("(car (cdr (list 1 2 3 4)))")).to.deep.equal(makeOk(2)); + expect(evalParse("(cons 1 2)")).toEqual(makeOk(makeCompoundSExp(1, 2))); + expect(evalParse("(car (cons 1 2))")).toEqual(makeOk(1)); + expect(evalParse("(cdr (cons 1 2))")).toEqual(makeOk(2)); + expect(evalParse("(pair? (cons 1 2))")).toEqual(makeOk(true)); + expect(evalParse("(car '(1 . 2))")).toEqual(makeOk(1)); + expect(evalParse("(cdr '(1 . 2))")).toEqual(makeOk(2)); + expect(evalParse("(car (cdr '(1 . (2 . 3))))")).toEqual(makeOk(2)); + expect(evalParse("(cdr (cdr '(1 . (2 . 3))))")).toEqual(makeOk(3)); + expect(evalParse("(car (cdr (list 1 2 3 4)))")).toEqual(makeOk(2)); }); it('evaluates programs with "define"', () => { const program1 = parseL3("(L3 (define x 1) (+ x x))"); if (isOk(program1)) { - expect(evalL3program(program1.value)).to.deep.equal(makeOk(2)); + expect(evalL3program(program1.value)).toEqual(makeOk(2)); } const program2 = parseL3("(L3 (define x 1) (define y (+ x x)) (* y y))"); if (isOk(program2)) { - expect(evalL3program(program2.value)).to.deep.equal(makeOk(4)); + expect(evalL3program(program2.value)).toEqual(makeOk(4)); } }); it('evaluates "if"', () => { - expect(evalParse('(if (string? "a") 1 2)')).to.deep.equal(makeOk(1)); - expect(evalParse('(if (not (string? "a")) 1 2)')).to.deep.equal(makeOk(2)); + expect(evalParse('(if (string? "a") 1 2)')).toEqual(makeOk(1)); + expect(evalParse('(if (not (string? "a")) 1 2)')).toEqual(makeOk(2)); }); it('evaluates procedures', () => { - expect(evalParse("(lambda (x) x)")).to.deep.equal(makeOk(makeClosure([makeVarDecl("x")], [makeVarRef("x")]))); + expect(evalParse("(lambda (x) x)")).toEqual(makeOk(makeClosure([makeVarDecl("x")], [makeVarRef("x")]))); }); it('substitutes', () => { const cexp1 = bind(p("((lambda (x) (* x x)) x)"), parseL3Exp); const expected1 = bind(p("((lambda (x) (* x x)) 3)"), parseL3Exp); if (isOkT(isCExp)(cexp1) && isOk(expected1)) { - expect(substitute([cexp1.value], ["x"], [makeNumExp(3)])).to.deep.equal([expected1.value]); + expect(substitute([cexp1.value], ["x"], [makeNumExp(3)])).toEqual([expected1.value]); } const e1 = ` @@ -345,14 +344,14 @@ describe('L3 Eval', () => { isOkT(isCExp)(parsed2) && isOkT(isCExp)(vn) && isOkT(isCExp)(vf)) { - expect(substitute([parsed1.value], ["n", "f"], [vn.value, vf.value])).to.deep.equal([parsed2.value]); + expect(substitute([parsed1.value], ["n", "f"], [vn.value, vf.value])).toEqual([parsed2.value]); } const lzxz = bind(p("(lambda (z) (x z))"), parseL3Exp); const lwzw = bind(p("(lambda (w) (z w))"), parseL3Exp); const lzlwzwz = bind(p("(lambda (z) ((lambda (w) (z w)) z))"), parseL3Exp); if (isOkT(isCExp)(lzxz) && isOkT(isCExp)(lwzw) && isOk(lzlwzwz)) { - expect(substitute([lzxz.value], ["x"], [lwzw.value])).to.deep.equal([lzlwzwz.value]); + expect(substitute([lzxz.value], ["x"], [lwzw.value])).toEqual([lzlwzwz.value]); } }); @@ -360,31 +359,31 @@ describe('L3 Eval', () => { const lxx = bind(p("(lambda (x) x)"), parseL3Exp); const lx1x1 = bind(p("(lambda (x__1) x__1)"), parseL3Exp); if (isOkT(isCExp)(lxx) && isOkT(isCExp)(lx1x1)) { - expect(renameExps([lxx.value])).to.deep.equal([lx1x1.value]); + expect(renameExps([lxx.value])).toEqual([lx1x1.value]); } const l1 = bind(p(`(((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2)`), parseL3Exp); const rl1 = bind(p(`(((lambda (x__1) (lambda (z__2) (x__1 z__2))) (lambda (w__3) (z w__3))) 2)`), parseL3Exp); if (isOkT(isCExp)(l1) && isOkT(isCExp)(rl1)) { - expect(renameExps([l1.value])).to.deep.equal([rl1.value]); + expect(renameExps([l1.value])).toEqual([rl1.value]); } }); it('applies procedures', () => { - expect(evalParse("((lambda (x) (* x x)) 2)")).to.deep.equal(makeOk(4)); + expect(evalParse("((lambda (x) (* x x)) 2)")).toEqual(makeOk(4)); const program1 = parseL3("(L3 (define square (lambda (x) (* x x))) (square 3))"); if (isOk(program1)) { - expect(evalL3program(program1.value)).to.deep.equal(makeOk(9)); + expect(evalL3program(program1.value)).toEqual(makeOk(9)); } const program2 = parseL3("(L3 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))"); if (isOk(program2)) { - expect(evalL3program(program2.value)).to.deep.equal(makeOk(3)); + expect(evalL3program(program2.value)).toEqual(makeOk(3)); } }); it('applies recursive procedures', () => { const program = parseL3("(L3 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))"); if (isOk(program)) { - expect(evalL3program(program.value)).to.deep.equal(makeOk(6)); + expect(evalL3program(program.value)).toEqual(makeOk(6)); } }); @@ -397,7 +396,7 @@ describe('L3 Eval', () => { (if (eq? l '()) l (cons (f (car l)) (map f (cdr l)))))) - (map (lambda (x) (* x x)) '(1 2 3)))`), evalL3program)).to.deep.equal(makeOk(listPrim([1, 4, 9]))); + (map (lambda (x) (* x x)) '(1 2 3)))`), evalL3program)).toEqual(makeOk(listPrim([1, 4, 9]))); expect(bind(parseL3(` (L3 (define empty? (lambda (x) (eq? x '()))) @@ -408,11 +407,11 @@ describe('L3 Eval', () => { (if (pred (car l)) (cons (car l) (filter pred (cdr l))) (filter pred (cdr l)))))) - (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalL3program)).to.deep.equal(makeOk(listPrim([1, 3]))); + (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalL3program)).toEqual(makeOk(listPrim([1, 3]))); expect(bind(parseL3(` (L3 (define compose (lambda (f g) (lambda (x) (f (g x))))) - ((compose not number?) 2))`), evalL3program)).to.deep.equal(makeOk(false)); + ((compose not number?) 2))`), evalL3program)).toEqual(makeOk(false)); expect(bind(parseL3(` (L3 (define equal? (lambda (e1 e2) @@ -421,7 +420,7 @@ describe('L3 Eval', () => { (if (and (pair? e1) (pair? e2)) (and (equal? (car e1) (car e2)) (equal? (cdr e1) (cdr e2))) #f)))) - (and (equal? '(1 . (2 . 3)) '(1 2 . 3)) (equal? '(1 . (2)) '(1 2))))`), evalL3program)).to.deep.equal(makeOk(true)); + (and (equal? '(1 . (2 . 3)) '(1 2 . 3)) (equal? '(1 . (2)) '(1 2))))`), evalL3program)).toEqual(makeOk(true)); }); it('evaluates the examples', () => { @@ -434,12 +433,12 @@ describe('L3 Eval', () => { (if (= n 1) f (lambda (x) (f ((nf f (- n 1)) x))))))) - ((nf (lambda (x) (* x x)) 2) 3))`), evalL3program)).to.deep.equal(makeOk(81)); + ((nf (lambda (x) (* x x)) 2) 3))`), evalL3program)).toEqual(makeOk(81)); // Accidental capture of the z variable if no renaming expect(bind(parseL3(` (L3 (define z (lambda (x) (* x x))) - (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalL3program)).to.deep.equal(makeOk(4)); + (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalL3program)).toEqual(makeOk(4)); // Y-combinator expect(bind(parseL3(` @@ -448,6 +447,6 @@ describe('L3 Eval', () => { (lambda (n) (if (= n 0) 1 - (* n ((fact fact) (- n 1))))))) 6))`), evalL3program)).to.deep.equal(makeOk(720)); + (* n ((fact fact) (- n 1))))))) 6))`), evalL3program)).toEqual(makeOk(720)); }); }); diff --git a/test/L3/freeVars.test.ts b/test/L3/freeVars.test.ts index 0ed66d4..f2ac16c 100644 --- a/test/L3/freeVars.test.ts +++ b/test/L3/freeVars.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { makeVarRef, parseL3Exp, Exp } from '../../src/L3/L3-ast'; import { height, occursFree, referencedVars } from '../../src/L3/freeVars'; import { Result, makeOk, bind } from "../../src/shared/result"; @@ -8,62 +7,62 @@ const p = (x: string): Result => bind(parseSexp(x), parseL3Exp); describe('height', () => { it('calculates the height of the AST', () => { - expect(bind(p("x"), e => makeOk(height(e)))).to.deep.equal(makeOk(1)); - expect(bind(p("(lambda (x) (* x x))"), e => makeOk(height(e)))).to.deep.equal(makeOk(2)); + expect(bind(p("x"), e => makeOk(height(e)))).toEqual(makeOk(1)); + expect(bind(p("(lambda (x) (* x x))"), e => makeOk(height(e)))).toEqual(makeOk(2)); }); }); describe('occursFree', () => { it('returns false for atoms that are not the variable itself', () => { - expect(bind(p("1"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); - expect(bind(p("#t"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); - expect(bind(p('"s"'), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); - expect(bind(p("'s"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); - expect(bind(p("y"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); + expect(bind(p("1"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); + expect(bind(p("#t"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); + expect(bind(p('"s"'), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); + expect(bind(p("'s"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); + expect(bind(p("y"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); }); it('returns true when the expression is the variable itself', () => { - expect(bind(p("x"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); + expect(bind(p("x"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); }); it('returns the correct result for procedures', () => { - expect(bind(p("(lambda () x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(lambda (x) x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); - expect(bind(p("(lambda (y) x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(lambda (y) (lambda (z) x))"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(lambda (x) (lambda (z) x))"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); - expect(bind(p("(lambda (y x) x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); + expect(bind(p("(lambda () x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(lambda (x) x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); + expect(bind(p("(lambda (y) x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(lambda (y) (lambda (z) x))"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(lambda (x) (lambda (z) x))"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); + expect(bind(p("(lambda (y x) x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); }); it('returns the correct result for "if" expressions', () => { - expect(bind(p("(if x 1 2)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(if #t x 2)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(if #t 1 x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(if #t 1 2)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); + expect(bind(p("(if x 1 2)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(if #t x 2)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(if #t 1 x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(if #t 1 2)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); }); it('returns the correct result for applications', () => { - expect(bind(p("(+ 1 x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(+ 1 2)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); + expect(bind(p("(+ 1 x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(+ 1 2)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); }); it.skip('returns the correct result for "let" expressions', () => { - expect(bind(p("(let () x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(let ((x 1)) x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); - expect(bind(p("(let ((y 1)) x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(let ((y 1)) (lambda (z) x))"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(let ((x 1)) (lambda (z) x))"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); - expect(bind(p("(let ((y 1) (x 2)) x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(false)); - expect(bind(p("(let ((y x) (x 2)) x)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); - expect(bind(p("(let ((y x) (x 2)) z)"), e => makeOk(occursFree("x", e)))).to.deep.equal(makeOk(true)); + expect(bind(p("(let () x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(let ((x 1)) x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); + expect(bind(p("(let ((y 1)) x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(let ((y 1)) (lambda (z) x))"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(let ((x 1)) (lambda (z) x))"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); + expect(bind(p("(let ((y 1) (x 2)) x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(false)); + expect(bind(p("(let ((y x) (x 2)) x)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); + expect(bind(p("(let ((y x) (x 2)) z)"), e => makeOk(occursFree("x", e)))).toEqual(makeOk(true)); }); }); describe('referencesVars', () => { it('returns referenced variables for a given expression', () => { - expect(bind(p("(lambda (y) (lambda (z) x))"), e => makeOk(referencedVars(e)))).to.deep.equal(makeOk([makeVarRef("x")])); - expect(bind(p("(+ x y)"), e => makeOk(referencedVars(e)))).to.deep.equal(makeOk([makeVarRef("x"), makeVarRef("y")])); - expect(bind(p("(if x 1 2)"), e => makeOk(referencedVars(e)))).to.deep.equal(makeOk([makeVarRef("x")])); - expect(bind(p("(plus x 1)"), e => makeOk(referencedVars(e)))).to.deep.equal(makeOk([makeVarRef("plus"), makeVarRef("x")])); + expect(bind(p("(lambda (y) (lambda (z) x))"), e => makeOk(referencedVars(e)))).toEqual(makeOk([makeVarRef("x")])); + expect(bind(p("(+ x y)"), e => makeOk(referencedVars(e)))).toEqual(makeOk([makeVarRef("x"), makeVarRef("y")])); + expect(bind(p("(if x 1 2)"), e => makeOk(referencedVars(e)))).toEqual(makeOk([makeVarRef("x")])); + expect(bind(p("(plus x 1)"), e => makeOk(referencedVars(e)))).toEqual(makeOk([makeVarRef("plus"), makeVarRef("x")])); }); }); diff --git a/test/L3/lexicalAddress.test.ts b/test/L3/lexicalAddress.test.ts index 517a50e..9e763e6 100644 --- a/test/L3/lexicalAddress.test.ts +++ b/test/L3/lexicalAddress.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { map } from 'ramda'; import { makeNumExp, makeVarDecl, makeVarRef } from "../../src/L3/L3-ast"; import * as LA from "../../src/L3/lexicalAddress"; @@ -7,19 +6,19 @@ import { Sexp } from "s-expression"; describe('parseLA', () => { it('parses lexical addresses', () => { - expect(LA.parseLA("1")).to.deep.equal(makeOk(makeNumExp(1))); - expect(LA.parseLA("(if #t (+ 1 2) 'ok)")).to.satisfy(isOkT(LA.isIfExpLA)); - expect(LA.parseLA("(lambda (x) x)")).to.satisfy(isOkT(LA.isProcExpLA)); + expect(LA.parseLA("1")).toEqual(makeOk(makeNumExp(1))); + expect(LA.parseLA("(if #t (+ 1 2) 'ok)")).toSatisfy(isOkT(LA.isIfExpLA)); + expect(LA.parseLA("(lambda (x) x)")).toSatisfy(isOkT(LA.isProcExpLA)); }); }); describe('unparseLA', () => { it('unparses lexical addresses', () => { - expect(bind(LA.parseLA("1"), cexpla => makeOk(LA.unparseLA(cexpla)))).to.deep.equal(makeOk("1")); - expect(bind(LA.parseLA("#t"), cexpla => makeOk(LA.unparseLA(cexpla)))).to.deep.equal(makeOk("#t")); - expect(bind(LA.parseLA("(if #t (+ 1 2) 'ok)"), cexpla => makeOk(LA.unparseLA(cexpla)))).to.deep.equal(makeOk(["if", "#t", ["+", "1", "2"], ["quote", "ok"]])); - expect(bind(LA.parseLA("(lambda (x) x)"), cexpla => makeOk(LA.unparseLA(cexpla)))).to.deep.equal(makeOk(["lambda", ["x"], "x"])); - expect(bind(LA.parseLA("(lambda (x) (* x x))"), cexpla => makeOk(LA.unparseLA(cexpla)))).to.deep.equal(makeOk(["lambda", ["x"], ["*", "x", "x"]])); + expect(bind(LA.parseLA("1"), cexpla => makeOk(LA.unparseLA(cexpla)))).toEqual(makeOk("1")); + expect(bind(LA.parseLA("#t"), cexpla => makeOk(LA.unparseLA(cexpla)))).toEqual(makeOk("#t")); + expect(bind(LA.parseLA("(if #t (+ 1 2) 'ok)"), cexpla => makeOk(LA.unparseLA(cexpla)))).toEqual(makeOk(["if", "#t", ["+", "1", "2"], ["quote", "ok"]])); + expect(bind(LA.parseLA("(lambda (x) x)"), cexpla => makeOk(LA.unparseLA(cexpla)))).toEqual(makeOk(["lambda", ["x"], "x"])); + expect(bind(LA.parseLA("(lambda (x) (* x x))"), cexpla => makeOk(LA.unparseLA(cexpla)))).toEqual(makeOk(["lambda", ["x"], ["*", "x", "x"]])); }); }); @@ -27,24 +26,24 @@ describe('getLexicalAddress', () => { it('returns the closest enclosing lexical address given a variable name', () => { const b = makeVarRef("b"); const las1 = [LA.makeLexicalAddress("a", 0, 0), LA.makeLexicalAddress("b", 0, 1)]; - expect(LA.getLexicalAddress(b, las1)).to.deep.equal(LA.makeLexicalAddress("b", 0, 1)); + expect(LA.getLexicalAddress(b, las1)).toEqual(LA.makeLexicalAddress("b", 0, 1)); const c = makeVarRef("c"); const las2 = [LA.makeLexicalAddress("a", 0, 0), LA.makeLexicalAddress("b", 0, 1)]; - expect(LA.getLexicalAddress(c, las2)).to.deep.equal(LA.makeFreeVar("c")); + expect(LA.getLexicalAddress(c, las2)).toEqual(LA.makeFreeVar("c")); const a = makeVarRef("a"); const las3 = [LA.makeLexicalAddress("a", 0, 0), LA.makeLexicalAddress("b", 0, 1), LA.makeLexicalAddress("a", 1, 1)]; - expect(LA.getLexicalAddress(a, las3)).to.deep.equal(LA.makeLexicalAddress("a", 0, 0)); + expect(LA.getLexicalAddress(a, las3)).toEqual(LA.makeLexicalAddress("a", 0, 0)); }); }); describe('indexOfVar', () => { it('returns the pos of a variable in a declaration list', () => { const vds = map(makeVarDecl, ["a", "b"]); - expect(LA.indexOfVar(vds[1], vds)).to.equal(1); + expect(LA.indexOfVar(vds[1], vds)).toBe(1); - expect(LA.indexOfVar(makeVarDecl("c"), vds)).to.equal(-1); + expect(LA.indexOfVar(makeVarDecl("c"), vds)).toBe(-1); }); }); @@ -57,7 +56,7 @@ describe('crossContour', () => { const c01 = LA.makeLexicalAddress("c", 0, 1); const c11 = LA.makeLexicalAddress("c", 1, 1); - expect(LA.crossContour(vds, [a00, c01])).to.deep.equal([a00, b01, a10, c11]); + expect(LA.crossContour(vds, [a00, c01])).toEqual([a00, b01, a10, c11]); }); }); @@ -65,9 +64,12 @@ describe('addLexicalAddress', () => { it('works...', () => { const f = (s: string): Result => bind(LA.parseLA(s), cexpla => bind(LA.addLexicalAddresses(cexpla), cexpla => makeOk(LA.unparseLA(cexpla)))); - expect(f("(lambda (x) x)")).to.deep.equal(makeOk(["lambda", ["x"], ["x", ":", "0", "0"]])); - expect(f("(lambda (x) (lambda (y) (+ x y)))")).to.deep.equal(makeOk(["lambda", ["x"], ["lambda", ["y"], [["+", "free"], ["x", ":", "1", "0"], ["y", ":", "0", "0"]]]])); - expect(f("((lambda (x) (* x x)) ((lambda (x) (+ x x)) 2))")).to.deep.equal( - makeOk([["lambda", ["x"], [["*", "free"], ["x", ":", "0", "0"], ["x", ":", "0", "0"]]], [["lambda", ["x"], [["+", "free"], ["x", ":", "0", "0"], ["x", ":", "0", "0"]]], "2"]])); + expect(f("(lambda (x) x)")).toEqual(makeOk(["lambda", ["x"], ["x", ":", "0", "0"]])); + expect(f("(lambda (x) (lambda (y) (+ x y)))")).toEqual( + makeOk(["lambda", ["x"], ["lambda", ["y"], [["+", "free"], ["x", ":", "1", "0"], ["y", ":", "0", "0"]]]]) + ); + expect(f("((lambda (x) (* x x)) ((lambda (x) (+ x x)) 2))")).toEqual( + makeOk([["lambda", ["x"], [["*", "free"], ["x", ":", "0", "0"], ["x", ":", "0", "0"]]], [["lambda", ["x"], [["+", "free"], ["x", ":", "0", "0"], ["x", ":", "0", "0"]]], "2"]]) + ); }); }); diff --git a/test/L4/L4-ast.test.ts b/test/L4/L4-ast.test.ts index 6156271..d031892 100644 --- a/test/L4/L4-ast.test.ts +++ b/test/L4/L4-ast.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { isBoolExp, isNumExp, isPrimOp, isStrExp, isVarDecl, isVarRef, isSetExp, isAppExp, isDefineExp, isIfExp, isLetrecExp, isLetExp, isLitExp, isProcExp, isProgram, parseL4, unparse, parseL4Exp, Exp } from '../../src/L4/L4-ast'; @@ -9,111 +8,111 @@ const p = (x: string): Result => bind(parseSexp(x), parseL4Exp); describe('L4 Parser', () => { it('parses atomic expressions', () => { - expect(p("1")).to.satisfy(isOkT(isNumExp)); - expect(p("#t")).to.satisfy(isOkT(isBoolExp)); - expect(p("x")).to.satisfy(isOkT(isVarRef)); - expect(p('"a"')).to.satisfy(isOkT(isStrExp)); - expect(p(">")).to.satisfy(isOkT(isPrimOp)); - expect(p("=")).to.satisfy(isOkT(isPrimOp)); - expect(p("string=?")).to.satisfy(isOkT(isPrimOp)); - expect(p("eq?")).to.satisfy(isOkT(isPrimOp)); - expect(p("cons")).to.satisfy(isOkT(isPrimOp)); + expect(p("1")).toSatisfy(isOkT(isNumExp)); + expect(p("#t")).toSatisfy(isOkT(isBoolExp)); + expect(p("x")).toSatisfy(isOkT(isVarRef)); + expect(p('"a"')).toSatisfy(isOkT(isStrExp)); + expect(p(">")).toSatisfy(isOkT(isPrimOp)); + expect(p("=")).toSatisfy(isOkT(isPrimOp)); + expect(p("string=?")).toSatisfy(isOkT(isPrimOp)); + expect(p("eq?")).toSatisfy(isOkT(isPrimOp)); + expect(p("cons")).toSatisfy(isOkT(isPrimOp)); }); it('parses programs', () => { - expect(parseL4("(L4 (define x 1) (> (+ x 1) (* x x)))")).to.satisfy(isOkT(isProgram)); + expect(parseL4("(L4 (define x 1) (> (+ x 1) (* x x)))")).toSatisfy(isOkT(isProgram)); }); it('parses "define" expressions', () => { const def = p("(define x 1)"); - expect(def).to.satisfy(isOkT(isDefineExp)); + expect(def).toSatisfy(isOkT(isDefineExp)); if (isOkT(isDefineExp)(def)) { - expect(def.value.var).to.satisfy(isVarDecl); - expect(def.value.val).to.satisfy(isNumExp); + expect(def.value.var).toSatisfy(isVarDecl); + expect(def.value.val).toSatisfy(isNumExp); } }); it('parses applications', () => { - expect(p("(> x 1)")).to.satisfy(isOkT(isAppExp)); - expect(p("(> (+ x x) (* x x))")).to.satisfy(isOkT(isAppExp)); + expect(p("(> x 1)")).toSatisfy(isOkT(isAppExp)); + expect(p("(> (+ x x) (* x x))")).toSatisfy(isOkT(isAppExp)); }); it('parses "if" expressions', () => { - expect(p("(if #t 1 2)")).to.satisfy(isOkT(isIfExp)); - expect(p("(if (< x 2) x 2)")).to.satisfy(isOkT(isIfExp)); + expect(p("(if #t 1 2)")).toSatisfy(isOkT(isIfExp)); + expect(p("(if (< x 2) x 2)")).toSatisfy(isOkT(isIfExp)); }); it('parses procedures', () => { - expect(p("(lambda () 1)")).to.satisfy(isOkT(isProcExp)); - expect(p("(lambda (x) x x)")).to.satisfy(isOkT(isProcExp)); + expect(p("(lambda () 1)")).toSatisfy(isOkT(isProcExp)); + expect(p("(lambda (x) x x)")).toSatisfy(isOkT(isProcExp)); }); it('parses "let" expressions', () => { - expect(p("(let ((a 1) (b #t)) (if b a (+ a 1)))")).to.satisfy(isOkT(isLetExp)); + expect(p("(let ((a 1) (b #t)) (if b a (+ a 1)))")).toSatisfy(isOkT(isLetExp)); }); it('parses literal expressions', () => { - expect(p("'a")).to.satisfy(isOkT(isLitExp)); - expect(p("'()")).to.satisfy(isOkT(isLitExp)); - expect(p("'(1)")).to.satisfy(isOkT(isLitExp)); + expect(p("'a")).toSatisfy(isOkT(isLitExp)); + expect(p("'()")).toSatisfy(isOkT(isLitExp)); + expect(p("'(1)")).toSatisfy(isOkT(isLitExp)); }); it('parses "letrec" expressions', () => { - expect(p("(letrec ((e (lambda (x) x))) (e 2))")).to.satisfy(isOkT(isLetrecExp)); + expect(p("(letrec ((e (lambda (x) x))) (e 2))")).toSatisfy(isOkT(isLetrecExp)); }); it('parses "set!" expressions', () => { - expect(p("(set! x (+ 1 2))")).to.satisfy(isOkT(isSetExp)); + expect(p("(set! x (+ 1 2))")).toSatisfy(isOkT(isSetExp)); }); describe("Failures", () => { it("returns a Failure when parsing a single-token program", () => { - expect(parseL4("x")).to.satisfy(isFailure); + expect(parseL4("x")).toSatisfy(isFailure); }); it("returns a Failure when parsing an empty program", () => { - expect(parseL4("")).to.satisfy(isFailure); + expect(parseL4("")).toSatisfy(isFailure); }); it("returns a Failure if the program does not start with (L3 ...)", () => { - expect(parseL4("(+ 1 2)")).to.satisfy(isFailure); + expect(parseL4("(+ 1 2)")).toSatisfy(isFailure); }); it("returns a Failure for a program with no Exps", () => { - expect(parseL4("(L4)")).to.satisfy(isFailure); + expect(parseL4("(L4)")).toSatisfy(isFailure); }); it("returns a Failure if a program has an empty Exp", () => { - expect(parseL4("(L4 ())")).to.satisfy(isFailure); + expect(parseL4("(L4 ())")).toSatisfy(isFailure); }); it('returns a Failure for an ill-formed "define"', () => { - expect(p("(define)")).to.satisfy(isFailure); - expect(p("(define x)")).to.satisfy(isFailure); - expect(p("(define x y z)")).to.satisfy(isFailure); - expect(p('(define "1" y)')).to.satisfy(isFailure); - expect(p('(define 1 y)')).to.satisfy(isFailure); + expect(p("(define)")).toSatisfy(isFailure); + expect(p("(define x)")).toSatisfy(isFailure); + expect(p("(define x y z)")).toSatisfy(isFailure); + expect(p('(define "1" y)')).toSatisfy(isFailure); + expect(p('(define 1 y)')).toSatisfy(isFailure); }); it('returns a Failure for an ill-formed "set!"', () => { - expect(p("(set!)")).to.satisfy(isFailure); - expect(p("(set! x)")).to.satisfy(isFailure); - expect(p("(set! x y z)")).to.satisfy(isFailure); - expect(p('(set! "1" y)')).to.satisfy(isFailure); - expect(p('(set! 1 y)')).to.satisfy(isFailure); + expect(p("(set!)")).toSatisfy(isFailure); + expect(p("(set! x)")).toSatisfy(isFailure); + expect(p("(set! x y z)")).toSatisfy(isFailure); + expect(p('(set! "1" y)')).toSatisfy(isFailure); + expect(p('(set! 1 y)')).toSatisfy(isFailure); }); it("returns a Failure for an empty CExp", () => { - expect(p("(+ ())")).to.satisfy(isFailure); + expect(p("(+ ())")).toSatisfy(isFailure); }); it("returns a Failure for an ill-formed special form", () => { - expect(p("(if)")).to.satisfy(isFailure); - expect(p("(if 1)")).to.satisfy(isFailure); - expect(p("(lambda x x)")).to.satisfy(isFailure); - expect(p("(let x x)")).to.satisfy(isFailure); - expect(p("(let (x y) x)")).to.satisfy(isFailure); - expect(p("(let ((1 y)) x)")).to.satisfy(isFailure); + expect(p("(if)")).toSatisfy(isFailure); + expect(p("(if 1)")).toSatisfy(isFailure); + expect(p("(lambda x x)")).toSatisfy(isFailure); + expect(p("(let x x)")).toSatisfy(isFailure); + expect(p("(let (x y) x)")).toSatisfy(isFailure); + expect(p("(let ((1 y)) x)")).toSatisfy(isFailure); }); }); }); @@ -125,65 +124,65 @@ describe('L4 Unparse', () => { it("doesn't change concrete values", () => { const concretes = ["1", "#t", "x", '"a"', ">", "=", "string=?", "eq?", "cons"]; concretes.forEach(concrete => { - expect(roundTrip(concrete)).to.deep.equal(makeOk(concrete)); + expect(roundTrip(concrete)).toEqual(makeOk(concrete)); }); }); it('unparses programs', () => { const program = "(L4 (define x 1) (> (+ x 1) (* x x)))"; - expect(roundTrip(program)).to.deep.equal(makeOk(program)); + expect(roundTrip(program)).toEqual(makeOk(program)); }); it('unparses "define" expressions', () => { const define = "(define x 1)"; - expect(roundTrip(define)).to.deep.equal(makeOk(define)); + expect(roundTrip(define)).toEqual(makeOk(define)); }); it('unparses applications', () => { const app1 = "(> x 1)"; const app2 = "(> (+ x x) (* x x))"; - expect(roundTrip(app1)).to.deep.equal(makeOk(app1)); - expect(roundTrip(app2)).to.deep.equal(makeOk(app2)); + expect(roundTrip(app1)).toEqual(makeOk(app1)); + expect(roundTrip(app2)).toEqual(makeOk(app2)); }); it('unparses "if" expressions', () => { const if1 = "(if #t 1 2)"; const if2 = "(if (< x 2) x 2)"; - expect(roundTrip(if1)).to.deep.equal(makeOk(if1)); - expect(roundTrip(if2)).to.deep.equal(makeOk(if2)); + expect(roundTrip(if1)).toEqual(makeOk(if1)); + expect(roundTrip(if2)).toEqual(makeOk(if2)); }); it('unparses procedures', () => { const proc1 = "(lambda () 1)"; const proc2 = "(lambda (x) x x)"; - expect(roundTrip(proc1)).to.deep.equal(makeOk(proc1)); - expect(roundTrip(proc2)).to.deep.equal(makeOk(proc2)); + expect(roundTrip(proc1)).toEqual(makeOk(proc1)); + expect(roundTrip(proc2)).toEqual(makeOk(proc2)); }); it('unparses "let" expressions', () => { const let1 = "(let ((a 1) (b #t)) (if b a (+ a 1)))"; - expect(roundTrip(let1)).to.deep.equal(makeOk(let1)); + expect(roundTrip(let1)).toEqual(makeOk(let1)); }); it('unparses literal expressions', () => { const lits = ["'a", "'()", "'(1)", "'(1 . 2)", "'(1 2 . 3)"]; lits.forEach(lit => { - expect(roundTrip(lit)).to.deep.equal(makeOk(lit)); + expect(roundTrip(lit)).toEqual(makeOk(lit)); }); }); it('normalizes dotted pairs', () => { const dp1 = "'(1 . (2 . 3))"; - expect(roundTrip(dp1)).to.deep.equal(makeOk("'(1 2 . 3)")); + expect(roundTrip(dp1)).toEqual(makeOk("'(1 2 . 3)")); }); it('unparses "letrec" expressions', () => { const letrec1 = "(letrec ((f (lambda (x) x))) (f 2))"; - expect(roundTrip(letrec1)).to.deep.equal(makeOk(letrec1)); + expect(roundTrip(letrec1)).toEqual(makeOk(letrec1)); }); it('unparses "set!" expressions', () => { const set1 = "(set! x (+ 1 2))"; - expect(roundTrip(set1)).to.deep.equal(makeOk(set1)); + expect(roundTrip(set1)).toEqual(makeOk(set1)); }); }); \ No newline at end of file diff --git a/test/L4/L4-eval-box.test.ts b/test/L4/L4-eval-box.test.ts index 1c2ed81..0c51593 100644 --- a/test/L4/L4-eval-box.test.ts +++ b/test/L4/L4-eval-box.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { makeVarDecl, makeVarRef, parseL4 } from '../../src/L4/L4-ast'; import { isEnv, makeExtEnv, applyEnv, theGlobalEnv, globalEnvAddBinding } from '../../src/L4/L4-env-box'; import { makeClosure, makeCompoundSExp, makeEmptySExp, makeSymbolSExp } from '../../src/L4/L4-value-box'; @@ -10,156 +9,158 @@ describe('L4 Box Environment', () => { const env2 = makeExtEnv(["a"], [3], env1); it('identifies the environment', () => { - expect(isEnv(theGlobalEnv)).to.be.true; - expect(isEnv(env1)).to.be.true; + expect(isEnv(theGlobalEnv)).toBe(true); + expect(isEnv(env1)).toBe(true); }); it('applies the environment', () => { - expect(applyEnv(env1, "a")).to.deep.equal(makeOk(1)); - expect(applyEnv(env2, "a")).to.deep.equal(makeOk(3)); - expect(applyEnv(env2, "b")).to.deep.equal(makeOk(2)); + expect(applyEnv(env1, "a")).toEqual(makeOk(1)); + expect(applyEnv(env2, "a")).toEqual(makeOk(3)); + expect(applyEnv(env2, "b")).toEqual(makeOk(2)); }); }); describe('L4 Box Eval', () => { it('mutates the global environment', () => { globalEnvAddBinding("m", 1); - expect(applyEnv(theGlobalEnv, "m")).to.deep.equal(makeOk(1)); + expect(applyEnv(theGlobalEnv, "m")).toEqual(makeOk(1)); }); it('evaluates data type literals', () => { - expect(evalParse("1")).to.deep.equal(makeOk(1)); - expect(evalParse("#t")).to.deep.equal(makeOk(true)); - expect(evalParse("#f")).to.deep.equal(makeOk(false)); - expect(evalParse("'a")).to.deep.equal(makeOk(makeSymbolSExp("a"))); - expect(evalParse('"a"')).to.deep.equal(makeOk("a")); - expect(evalParse("'()")).to.deep.equal(makeOk(makeEmptySExp())); - expect(evalParse("'(1 2)")).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); - expect(evalParse("'(1 (2))")).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(makeCompoundSExp(2, makeEmptySExp()), makeEmptySExp())))); + expect(evalParse("1")).toEqual(makeOk(1)); + expect(evalParse("#t")).toEqual(makeOk(true)); + expect(evalParse("#f")).toEqual(makeOk(false)); + expect(evalParse("'a")).toEqual(makeOk(makeSymbolSExp("a"))); + expect(evalParse('"a"')).toEqual(makeOk("a")); + expect(evalParse("'()")).toEqual(makeOk(makeEmptySExp())); + expect(evalParse("'(1 2)")).toEqual(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); + expect(evalParse("'(1 (2))")).toEqual( + makeOk(makeCompoundSExp(1, makeCompoundSExp(makeCompoundSExp(2, makeEmptySExp()), makeEmptySExp()))) + ); }); describe('Primitive Procedures', () => { it('evaluates "+"', () => { - expect(evalParse("(+ 1 2)")).to.deep.equal(makeOk(3)); + expect(evalParse("(+ 1 2)")).toEqual(makeOk(3)); }); it('evaluates "-"', () => { - expect(evalParse("(- 2 1)")).to.deep.equal(makeOk(1)); + expect(evalParse("(- 2 1)")).toEqual(makeOk(1)); }); it('evaluates "*"', () => { - expect(evalParse("(* 2 3)")).to.deep.equal(makeOk(6)); + expect(evalParse("(* 2 3)")).toEqual(makeOk(6)); }); it('evaluates "/"', () => { - expect(evalParse("(/ 4 2)")).to.deep.equal(makeOk(2)); + expect(evalParse("(/ 4 2)")).toEqual(makeOk(2)); }); it('evaluates "<"', () => { - expect(evalParse("(< 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(< 4 2)")).toEqual(makeOk(false)); }); it('evaluates ">"', () => { - expect(evalParse("(> 4 2)")).to.deep.equal(makeOk(true)); + expect(evalParse("(> 4 2)")).toEqual(makeOk(true)); }); it('evaluates "="', () => { - expect(evalParse("(= 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(= 4 2)")).toEqual(makeOk(false)); }); it('evaluates "not"', () => { - expect(evalParse("(not #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(not #t)")).toEqual(makeOk(false)); }); it('evaluates "eq?"', () => { - expect(evalParse("(eq? 'a 'a)")).to.deep.equal(makeOk(true)); + expect(evalParse("(eq? 'a 'a)")).toEqual(makeOk(true)); }); it('evaluates "string=?"', () => { - expect(evalParse('(string=? "a" "a")')).to.deep.equal(makeOk(true)); + expect(evalParse('(string=? "a" "a")')).toEqual(makeOk(true)); }); it('evaluates "cons"', () => { - expect(evalParse("(cons 1 '())")).to.deep.equal(makeOk(makeCompoundSExp(1, makeEmptySExp()))); - expect(evalParse("(cons 1 '(2))")).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); + expect(evalParse("(cons 1 '())")).toEqual(makeOk(makeCompoundSExp(1, makeEmptySExp()))); + expect(evalParse("(cons 1 '(2))")).toEqual(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); }); it('evaluates "car"', () => { - expect(evalParse("(car '(1 2))")).to.deep.equal(makeOk(1)); + expect(evalParse("(car '(1 2))")).toEqual(makeOk(1)); }); it('evaluates "cdr"', () => { - expect(evalParse("(cdr '(1 2))")).to.deep.equal(makeOk(makeCompoundSExp(2, makeEmptySExp()))); - expect(evalParse("(cdr '(1))")).to.deep.equal(makeOk(makeEmptySExp())); + expect(evalParse("(cdr '(1 2))")).toEqual(makeOk(makeCompoundSExp(2, makeEmptySExp()))); + expect(evalParse("(cdr '(1))")).toEqual(makeOk(makeEmptySExp())); }); it('evaluates "list?"', () => { - expect(evalParse("(list? '(1))")).to.deep.equal(makeOk(true)); - expect(evalParse("(list? '())")).to.deep.equal(makeOk(true)); + expect(evalParse("(list? '(1))")).toEqual(makeOk(true)); + expect(evalParse("(list? '())")).toEqual(makeOk(true)); }); it('evaluates "number?"', () => { - expect(evalParse("(number? 1)")).to.deep.equal(makeOk(true)); - expect(evalParse("(number? #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(number? 1)")).toEqual(makeOk(true)); + expect(evalParse("(number? #t)")).toEqual(makeOk(false)); }); it('evaluates "boolean?"', () => { - expect(evalParse("(boolean? #t)")).to.deep.equal(makeOk(true)); - expect(evalParse("(boolean? 0)")).to.deep.equal(makeOk(false)); + expect(evalParse("(boolean? #t)")).toEqual(makeOk(true)); + expect(evalParse("(boolean? 0)")).toEqual(makeOk(false)); }); it('evaluates "symbol?"', () => { - expect(evalParse("(symbol? 'a)")).to.deep.equal(makeOk(true)); - expect(evalParse('(symbol? "a")')).to.deep.equal(makeOk(false)); + expect(evalParse("(symbol? 'a)")).toEqual(makeOk(true)); + expect(evalParse('(symbol? "a")')).toEqual(makeOk(false)); }); it('evaluates "string?"', () => { - expect(evalParse('(string? "a")')).to.deep.equal(makeOk(true)); - expect(evalParse("(string? 'a)")).to.deep.equal(makeOk(false)); + expect(evalParse('(string? "a")')).toEqual(makeOk(true)); + expect(evalParse("(string? 'a)")).toEqual(makeOk(false)); }); it('evaluates "pair?"', () => { - expect(evalParse('(pair? "a")')).to.deep.equal(makeOk(false)); - expect(evalParse('(pair? (cons 1 2))')).to.deep.equal(makeOk(true)); - expect(evalParse("(pair? '(1))")).to.deep.equal(makeOk(true)); + expect(evalParse('(pair? "a")')).toEqual(makeOk(false)); + expect(evalParse('(pair? (cons 1 2))')).toEqual(makeOk(true)); + expect(evalParse("(pair? '(1))")).toEqual(makeOk(true)); }); }); it('evaluates "define" expressions', () => { - expect(bind(parseL4("(L4 (define x 1) (+ x x))"), evalProgram)).to.deep.equal(makeOk(2)); - expect(bind(parseL4("(L4 (define x 1) (define y (+ x x)) (* y y))"), evalProgram)).to.deep.equal(makeOk(4)); + expect(bind(parseL4("(L4 (define x 1) (+ x x))"), evalProgram)).toEqual(makeOk(2)); + expect(bind(parseL4("(L4 (define x 1) (define y (+ x x)) (* y y))"), evalProgram)).toEqual(makeOk(4)); }); it('evaluates "if" expressions', () => { - expect(evalParse('(if (string? "a") 1 2)')).to.deep.equal(makeOk(1)); - expect(evalParse('(if (not (string? "a")) 1 2)')).to.deep.equal(makeOk(2)); + expect(evalParse('(if (string? "a") 1 2)')).toEqual(makeOk(1)); + expect(evalParse('(if (not (string? "a")) 1 2)')).toEqual(makeOk(2)); }); it('evaluates procedures', () => { - expect(evalParse("(lambda (x) x)")).to.deep.equal(makeOk(makeClosure([makeVarDecl("x")], [makeVarRef("x")], theGlobalEnv))); + expect(evalParse("(lambda (x) x)")).toEqual(makeOk(makeClosure([makeVarDecl("x")], [makeVarRef("x")], theGlobalEnv))); }); it('evaluates "letrec" expressions', () => { const letrec = "(letrec ((a 1) (b #t)) (if b a (+ a 1)))"; - expect(evalParse(letrec)).to.deep.equal(makeOk(1)); + expect(evalParse(letrec)).toEqual(makeOk(1)); }); it('applies procedures', () => { - expect(evalParse("((lambda (x) (* x x)) 2)")).to.deep.equal(makeOk(4)); - expect(bind(parseL4("(L4 (define square (lambda (x) (* x x))) (square 3))"), evalProgram)).to.deep.equal(makeOk(9)); - expect(bind(parseL4("(L4 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))"), evalProgram)).to.deep.equal(makeOk(3)); + expect(evalParse("((lambda (x) (* x x)) 2)")).toEqual(makeOk(4)); + expect(bind(parseL4("(L4 (define square (lambda (x) (* x x))) (square 3))"), evalProgram)).toEqual(makeOk(9)); + expect(bind(parseL4("(L4 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))"), evalProgram)).toEqual(makeOk(3)); }); it('evaluates recursive procedures without "letrec"', () => { - expect(bind(parseL4("(L4 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))"), evalProgram)).to.deep.equal(makeOk(6)); + expect(bind(parseL4("(L4 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))"), evalProgram)).toEqual(makeOk(6)); }); it('returns a Failure in "letrec" if a binding is invalid', () => { - expect(evalParse(`(letrec ((a (1 2))) a)`)).to.satisfy(isFailure); + expect(evalParse(`(letrec ((a (1 2))) a)`)).toSatisfy(isFailure); }); it('evaluates recursive procedures with "letrec"', () => { - expect(evalParse(`(letrec ((f (lambda (n) (if (= n 0) 1 (* n (f (- n 1))))))) (f 5))`)).to.deep.equal(makeOk(120)); + expect(evalParse(`(letrec ((f (lambda (n) (if (= n 0) 1 (* n (f (- n 1))))))) (f 5))`)).toEqual(makeOk(120)); }); it('evaluates the examples', () => { @@ -171,12 +172,12 @@ describe('L4 Box Eval', () => { 1 (* n (f (- n 1))))))) f)) - (fact 5))`), evalProgram)).to.deep.equal(makeOk(120)); + (fact 5))`), evalProgram)).toEqual(makeOk(120)); // Accidental capture of the z variable if no renaming - works without renaming in env eval. expect(bind(parseL4(` (L4 (define z (lambda (x) (* x x))) - (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalProgram)).to.deep.equal(makeOk(4)); + (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalProgram)).toEqual(makeOk(4)); // Y-combinator expect(bind(parseL4(` @@ -185,7 +186,7 @@ describe('L4 Box Eval', () => { (lambda (n) (if (= n 0) 1 - (* n ((fact fact) (- n 1))))))) 6))`), evalProgram)).to.deep.equal(makeOk(720)); + (* n ((fact fact) (- n 1))))))) 6))`), evalProgram)).toEqual(makeOk(720)); }); it('evaluates higher-order functions', () => { @@ -195,7 +196,7 @@ describe('L4 Box Eval', () => { (if (eq? l '()) l (cons (f (car l)) (map f (cdr l)))))) - (map (lambda (x) (* x x)) '(1 2 3)))`), evalProgram)).to.deep.equal(evalParse("'(1 4 9)")); + (map (lambda (x) (* x x)) '(1 2 3)))`), evalProgram)).toEqual(evalParse("'(1 4 9)")); expect(bind(parseL4(` (L4 (define empty? (lambda (x) (eq? x '()))) @@ -205,11 +206,11 @@ describe('L4 Box Eval', () => { (if (pred (car l)) (cons (car l) (filter pred (cdr l))) (filter pred (cdr l)))))) - (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalProgram)).to.deep.equal(evalParse("'(1 3)")) + (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalProgram)).toEqual(evalParse("'(1 3)")) expect(bind(parseL4(` (L4 (define compose (lambda (f g) (lambda (x) (f (g x))))) - ((compose not number?) 2))`), evalProgram)).to.deep.equal(makeOk(false)); + ((compose not number?) 2))`), evalProgram)).toEqual(makeOk(false)); }); it('properly captures variables in closures', () => { @@ -217,19 +218,19 @@ describe('L4 Box Eval', () => { (L4 (define makeAdder (lambda (n) (lambda (y) (+ y n)))) (define a6 (makeAdder 6)) (define a7 (makeAdder 7)) - (+ (a6 1) (a7 1)))`), evalProgram)).to.deep.equal(makeOk(15)); + (+ (a6 1) (a7 1)))`), evalProgram)).toEqual(makeOk(15)); expect(bind(parseL4(` (L4 (define makeCounter (lambda () (let ((c 0)) (lambda () (set! c (+ c 1)) c)))) (define c1 (makeCounter)) (define c2 (makeCounter)) - (+ (+ (c1) (c1)) (+ (c2) (c2))))`), evalProgram)).to.deep.equal(makeOk(6)); + (+ (+ (c1) (c1)) (+ (c2) (c2))))`), evalProgram)).toEqual(makeOk(6)); }); it('evaluates mutual recursion', () => { expect(bind(parseL4(` (L4 (define odd? (lambda (n) (if (= n 0) #f (even? (- n 1))))) (define even? (lambda (n) (if (= n 0) #t (odd? (- n 1))))) - (and (odd? 5) (even? 6)))`), evalProgram)).to.deep.equal(makeOk(true)); + (and (odd? 5) (even? 6)))`), evalProgram)).toEqual(makeOk(true)); }); }); diff --git a/test/L4/L4-eval.test.ts b/test/L4/L4-eval.test.ts index 23c2920..4f10e38 100644 --- a/test/L4/L4-eval.test.ts +++ b/test/L4/L4-eval.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { makeVarDecl, makeVarRef, parseL4 } from '../../src/L4/L4-ast'; import { isEnv, makeEmptyEnv, makeExtEnv, applyEnv } from '../../src/L4/L4-env'; import { makeClosure, makeCompoundSExp, makeEmptySExp, makeSymbolSExp } from '../../src/L4/L4-value'; @@ -12,136 +11,138 @@ describe('L4 Environment', () => { const env2 = makeExtEnv(["a"], [3], env1); it('identifies the environment', () => { - expect(isEnv(emptyEnv)).to.be.true; - expect(isEnv(env1)).to.be.true; + expect(isEnv(emptyEnv)).toBe(true); + expect(isEnv(env1)).toBe(true); }); it('applies the environment', () => { - expect(applyEnv(env1, "a")).to.deep.equal(makeOk(1)); - expect(applyEnv(env2, "a")).to.deep.equal(makeOk(3)); - expect(applyEnv(env2, "b")).to.deep.equal(makeOk(2)); + expect(applyEnv(env1, "a")).toEqual(makeOk(1)); + expect(applyEnv(env2, "a")).toEqual(makeOk(3)); + expect(applyEnv(env2, "b")).toEqual(makeOk(2)); }); }); describe('L4 Eval', () => { it('evaluates data type literals', () => { - expect(evalParse("1")).to.deep.equal(makeOk(1)); - expect(evalParse("#t")).to.deep.equal(makeOk(true)); - expect(evalParse("#f")).to.deep.equal(makeOk(false)); - expect(evalParse("'a")).to.deep.equal(makeOk(makeSymbolSExp("a"))); - expect(evalParse('"a"')).to.deep.equal(makeOk("a")); - expect(evalParse("'()")).to.deep.equal(makeOk(makeEmptySExp())); - expect(evalParse("'(1 2)")).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); - expect(evalParse("'(1 (2))")).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(makeCompoundSExp(2, makeEmptySExp()), makeEmptySExp())))); + expect(evalParse("1")).toEqual(makeOk(1)); + expect(evalParse("#t")).toEqual(makeOk(true)); + expect(evalParse("#f")).toEqual(makeOk(false)); + expect(evalParse("'a")).toEqual(makeOk(makeSymbolSExp("a"))); + expect(evalParse('"a"')).toEqual(makeOk("a")); + expect(evalParse("'()")).toEqual(makeOk(makeEmptySExp())); + expect(evalParse("'(1 2)")).toEqual(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); + expect(evalParse("'(1 (2))")).toEqual( + makeOk(makeCompoundSExp(1, makeCompoundSExp(makeCompoundSExp(2, makeEmptySExp()), makeEmptySExp()))) + ); }); describe('Primitive Procedures', () => { it('evaluates "+"', () => { - expect(evalParse("(+ 1 2)")).to.deep.equal(makeOk(3)); + expect(evalParse("(+ 1 2)")).toEqual(makeOk(3)); }); it('evaluates "-"', () => { - expect(evalParse("(- 2 1)")).to.deep.equal(makeOk(1)); + expect(evalParse("(- 2 1)")).toEqual(makeOk(1)); }); it('evaluates "*"', () => { - expect(evalParse("(* 2 3)")).to.deep.equal(makeOk(6)); + expect(evalParse("(* 2 3)")).toEqual(makeOk(6)); }); it('evaluates "/"', () => { - expect(evalParse("(/ 4 2)")).to.deep.equal(makeOk(2)); + expect(evalParse("(/ 4 2)")).toEqual(makeOk(2)); }); it('evaluates "<"', () => { - expect(evalParse("(< 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(< 4 2)")).toEqual(makeOk(false)); }); it('evaluates ">"', () => { - expect(evalParse("(> 4 2)")).to.deep.equal(makeOk(true)); + expect(evalParse("(> 4 2)")).toEqual(makeOk(true)); }); it('evaluates "="', () => { - expect(evalParse("(= 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(= 4 2)")).toEqual(makeOk(false)); }); it('evaluates "not"', () => { - expect(evalParse("(not #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(not #t)")).toEqual(makeOk(false)); }); it('evaluates "eq?"', () => { - expect(evalParse("(eq? 'a 'a)")).to.deep.equal(makeOk(true)); + expect(evalParse("(eq? 'a 'a)")).toEqual(makeOk(true)); }); it('evaluates "string=?"', () => { - expect(evalParse('(string=? "a" "a")')).to.deep.equal(makeOk(true)); + expect(evalParse('(string=? "a" "a")')).toEqual(makeOk(true)); }); it('evaluates "cons"', () => { - expect(evalParse("(cons 1 '())")).to.deep.equal(makeOk(makeCompoundSExp(1, makeEmptySExp()))); - expect(evalParse("(cons 1 '(2))")).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); + expect(evalParse("(cons 1 '())")).toEqual(makeOk(makeCompoundSExp(1, makeEmptySExp()))); + expect(evalParse("(cons 1 '(2))")).toEqual(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); }); it('evaluates "car"', () => { - expect(evalParse("(car '(1 2))")).to.deep.equal(makeOk(1)); + expect(evalParse("(car '(1 2))")).toEqual(makeOk(1)); }); it('evaluates "cdr"', () => { - expect(evalParse("(cdr '(1 2))")).to.deep.equal(makeOk(makeCompoundSExp(2, makeEmptySExp()))); - expect(evalParse("(cdr '(1))")).to.deep.equal(makeOk(makeEmptySExp())); + expect(evalParse("(cdr '(1 2))")).toEqual(makeOk(makeCompoundSExp(2, makeEmptySExp()))); + expect(evalParse("(cdr '(1))")).toEqual(makeOk(makeEmptySExp())); }); it('evaluates "list?"', () => { - expect(evalParse("(list? '(1))")).to.deep.equal(makeOk(true)); - expect(evalParse("(list? '())")).to.deep.equal(makeOk(true)); + expect(evalParse("(list? '(1))")).toEqual(makeOk(true)); + expect(evalParse("(list? '())")).toEqual(makeOk(true)); }); it('evaluates "number?"', () => { - expect(evalParse("(number? 1)")).to.deep.equal(makeOk(true)); - expect(evalParse("(number? #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(number? 1)")).toEqual(makeOk(true)); + expect(evalParse("(number? #t)")).toEqual(makeOk(false)); }); it('evaluates "boolean?"', () => { - expect(evalParse("(boolean? #t)")).to.deep.equal(makeOk(true)); - expect(evalParse("(boolean? 0)")).to.deep.equal(makeOk(false)); + expect(evalParse("(boolean? #t)")).toEqual(makeOk(true)); + expect(evalParse("(boolean? 0)")).toEqual(makeOk(false)); }); it('evaluates "symbol?"', () => { - expect(evalParse("(symbol? 'a)")).to.deep.equal(makeOk(true)); - expect(evalParse('(symbol? "a")')).to.deep.equal(makeOk(false)); + expect(evalParse("(symbol? 'a)")).toEqual(makeOk(true)); + expect(evalParse('(symbol? "a")')).toEqual(makeOk(false)); }); it('evaluates "string?"', () => { - expect(evalParse('(string? "a")')).to.deep.equal(makeOk(true)); - expect(evalParse("(string? 'a)")).to.deep.equal(makeOk(false)); + expect(evalParse('(string? "a")')).toEqual(makeOk(true)); + expect(evalParse("(string? 'a)")).toEqual(makeOk(false)); }); }); it('evaluates "define" expressions', () => { - expect(bind(parseL4("(L4 (define x 1) (+ x x))"), evalProgram)).to.deep.equal(makeOk(2)); - expect(bind(parseL4("(L4 (define x 1) (define y (+ x x)) (* y y))"), evalProgram)).to.deep.equal(makeOk(4)); + expect(bind(parseL4("(L4 (define x 1) (+ x x))"), evalProgram)).toEqual(makeOk(2)); + expect(bind(parseL4("(L4 (define x 1) (define y (+ x x)) (* y y))"), evalProgram)).toEqual(makeOk(4)); }); it('evaluates "if" expressions', () => { - expect(evalParse('(if (string? "a") 1 2)')).to.deep.equal(makeOk(1)); - expect(evalParse('(if (not (string? "a")) 1 2)')).to.deep.equal(makeOk(2)); + expect(evalParse('(if (string? "a") 1 2)')).toEqual(makeOk(1)); + expect(evalParse('(if (not (string? "a")) 1 2)')).toEqual(makeOk(2)); }); it('evaluates procedures', () => { - expect(evalParse("(lambda (x) x)")).to.deep.equal(makeOk(makeClosure([makeVarDecl("x")], [makeVarRef("x")], makeEmptyEnv()))); + expect(evalParse("(lambda (x) x)")).toEqual(makeOk(makeClosure([makeVarDecl("x")], [makeVarRef("x")], makeEmptyEnv()))); }); it('applies procedures', () => { - expect(evalParse("((lambda (x) (* x x)) 2)")).to.deep.equal(makeOk(4)); - expect(bind(parseL4("(L4 (define square (lambda (x) (* x x))) (square 3))"), evalProgram)).to.deep.equal(makeOk(9)); - expect(bind(parseL4("(L4 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))"), evalProgram)).to.deep.equal(makeOk(3)); + expect(evalParse("((lambda (x) (* x x)) 2)")).toEqual(makeOk(4)); + expect(bind(parseL4("(L4 (define square (lambda (x) (* x x))) (square 3))"), evalProgram)).toEqual(makeOk(9)); + expect(bind(parseL4("(L4 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))"), evalProgram)).toEqual(makeOk(3)); }); it('returns an error for recursive procedures', () => { - expect(bind(parseL4("(L4 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))"), evalProgram)).to.satisfy(isFailure); + expect(bind(parseL4("(L4 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))"), evalProgram)).toSatisfy(isFailure); }); it('evaluates recursion with "letrec"', () => { - expect(evalParse(`(letrec ((f (lambda (n) (if (= n 0) 1 (* n (f (- n 1))))))) (f 5))`)).to.deep.equal(makeOk(120)); + expect(evalParse(`(letrec ((f (lambda (n) (if (= n 0) 1 (* n (f (- n 1))))))) (f 5))`)).toEqual(makeOk(120)); expect(bind(parseL4(` (L4 (define equal? (letrec ((equal? (lambda (e1 e2) @@ -152,7 +153,7 @@ describe('L4 Eval', () => { (equal? (cdr e1) (cdr e2))) #f))))) equal?)) - (and (equal? '(1 . (2 . 3)) '(1 2 . 3)) (equal? '(1 . (2)) '(1 2))))`), evalProgram)).to.deep.equal(makeOk(true)); + (and (equal? '(1 . (2 . 3)) '(1 2 . 3)) (equal? '(1 . (2)) '(1 2))))`), evalProgram)).toEqual(makeOk(true)); }); it('evaluates the examples', () => { @@ -164,12 +165,12 @@ describe('L4 Eval', () => { 1 (* n (f (- n 1))))))) f)) - (fact 5))`), evalProgram)).to.deep.equal(makeOk(120)); + (fact 5))`), evalProgram)).toEqual(makeOk(120)); // Accidental capture of the z variable if no renaming - works without renaming in env eval. expect(bind(parseL4(` (L4 (define z (lambda (x) (* x x))) - (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalProgram)).to.deep.equal(makeOk(4)); + (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalProgram)).toEqual(makeOk(4)); // Y-combinator expect(bind(parseL4(` @@ -178,7 +179,7 @@ describe('L4 Eval', () => { (lambda (n) (if (= n 0) 1 - (* n ((fact fact) (- n 1))))))) 6))`), evalProgram)).to.deep.equal(makeOk(720)); + (* n ((fact fact) (- n 1))))))) 6))`), evalProgram)).toEqual(makeOk(720)); }); it('evaluates higher-order functions', () => { @@ -189,7 +190,7 @@ describe('L4 Eval', () => { l (cons (f (car l)) (map f (cdr l))))))) map)) - (map (lambda (x) (* x x)) '(1 2 3)))`), evalProgram)).to.deep.equal(evalParse("'(1 4 9)")); + (map (lambda (x) (* x x)) '(1 2 3)))`), evalProgram)).toEqual(evalParse("'(1 4 9)")); expect(bind(parseL4(` (L4 (define empty? (lambda (x) (eq? x '()))) @@ -201,11 +202,11 @@ describe('L4 Eval', () => { (cons (car l) (filter pred (cdr l))) (filter pred (cdr l))))))) filter)) - (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalProgram)).to.deep.equal(evalParse("'(1 3)")); + (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalProgram)).toEqual(evalParse("'(1 3)")); expect(bind(parseL4(` (L4 (define compose (lambda (f g) (lambda (x) (f (g x))))) - ((compose not number?) 2))`), evalProgram)).to.deep.equal(makeOk(false)); + ((compose not number?) 2))`), evalProgram)).toEqual(makeOk(false)); }); it('properly captures variables in closures', () => { @@ -213,6 +214,6 @@ describe('L4 Eval', () => { (L4 (define makeAdder (lambda (n) (lambda (y) (+ y n)))) (define a6 (makeAdder 6)) (define a7 (makeAdder 7)) - (+ (a6 1) (a7 1)))`), evalProgram)).to.deep.equal(makeOk(15)); + (+ (a6 1) (a7 1)))`), evalProgram)).toEqual(makeOk(15)); }); }); diff --git a/test/L5/L5-ast.test.ts b/test/L5/L5-ast.test.ts index 7f0197e..6ff183d 100644 --- a/test/L5/L5-ast.test.ts +++ b/test/L5/L5-ast.test.ts @@ -1,4 +1,3 @@ -import { expect } from "chai"; import { isNumExp, isBoolExp, isVarRef, isPrimOp, isProgram, isDefineExp, isVarDecl, isAppExp, isStrExp, isIfExp, isProcExp, isLetExp, isLitExp, isLetrecExp, isSetExp, parseL5Exp, unparse, Exp, parseL5 } from "../../src/L5/L5-ast"; @@ -9,78 +8,78 @@ const p = (x: string): Result => bind(parseSexp(x), parseL5Exp); describe('L5 Parser', () => { it('parses atomic expressions', () => { - expect(p("1")).to.satisfy(isOkT(isNumExp)); - expect(p("#t")).to.satisfy(isOkT(isBoolExp)); - expect(p("x")).to.satisfy(isOkT(isVarRef)); - expect(p('"a"')).to.satisfy(isOkT(isStrExp)); - expect(p(">")).to.satisfy(isOkT(isPrimOp)); - expect(p("=")).to.satisfy(isOkT(isPrimOp)); - expect(p("string=?")).to.satisfy(isOkT(isPrimOp)); - expect(p("eq?")).to.satisfy(isOkT(isPrimOp)); - expect(p("cons")).to.satisfy(isOkT(isPrimOp)); + expect(p("1")).toSatisfy(isOkT(isNumExp)); + expect(p("#t")).toSatisfy(isOkT(isBoolExp)); + expect(p("x")).toSatisfy(isOkT(isVarRef)); + expect(p('"a"')).toSatisfy(isOkT(isStrExp)); + expect(p(">")).toSatisfy(isOkT(isPrimOp)); + expect(p("=")).toSatisfy(isOkT(isPrimOp)); + expect(p("string=?")).toSatisfy(isOkT(isPrimOp)); + expect(p("eq?")).toSatisfy(isOkT(isPrimOp)); + expect(p("cons")).toSatisfy(isOkT(isPrimOp)); }); it('parses programs', () => { - expect(parseL5("(L5 (define x 1) (> (+ x 1) (* x x)))")).to.satisfy(isOkT(isProgram)); + expect(parseL5("(L5 (define x 1) (> (+ x 1) (* x x)))")).toSatisfy(isOkT(isProgram)); }); it('parses "define" expressions', () => { const def = p("(define x 1)"); - expect(def).to.satisfy(isOkT(isDefineExp)); + expect(def).toSatisfy(isOkT(isDefineExp)); if (isOkT(isDefineExp)(def)) { - expect(def.value.var).to.satisfy(isVarDecl); - expect(def.value.val).to.satisfy(isNumExp); + expect(def.value.var).toSatisfy(isVarDecl); + expect(def.value.val).toSatisfy(isNumExp); } }); it('parses "define" expressions with type annotations', () => { const define = "(define (a : number) 1)"; - expect(p(define)).to.satisfy(isOkT(isDefineExp)); + expect(p(define)).toSatisfy(isOkT(isDefineExp)); }); it('parses applications', () => { - expect(p("(> x 1)")).to.satisfy(isOkT(isAppExp)); - expect(p("(> (+ x x) (* x x))")).to.satisfy(isOkT(isAppExp)); + expect(p("(> x 1)")).toSatisfy(isOkT(isAppExp)); + expect(p("(> (+ x x) (* x x))")).toSatisfy(isOkT(isAppExp)); }); it('parses "if" expressions', () => { - expect(p("(if #t 1 2)")).to.satisfy(isOkT(isIfExp)); - expect(p("(if (< x 2) x 2)")).to.satisfy(isOkT(isIfExp)); + expect(p("(if #t 1 2)")).toSatisfy(isOkT(isIfExp)); + expect(p("(if (< x 2) x 2)")).toSatisfy(isOkT(isIfExp)); }); it('parses procedures', () => { - expect(p("(lambda () 1)")).to.satisfy(isOkT(isProcExp)); - expect(p("(lambda (x) x x)")).to.satisfy(isOkT(isProcExp)); + expect(p("(lambda () 1)")).toSatisfy(isOkT(isProcExp)); + expect(p("(lambda (x) x x)")).toSatisfy(isOkT(isProcExp)); }); it('parses procedures with type annotations', () => { - expect(p("(lambda ((x : number)) : number (* x x))")).to.satisfy(isOkT(isProcExp)); + expect(p("(lambda ((x : number)) : number (* x x))")).toSatisfy(isOkT(isProcExp)); }); it('parses "let" expressions', () => { - expect(p("(let ((a 1) (b #t)) (if b a (+ a 1)))")).to.satisfy(isOkT(isLetExp)); + expect(p("(let ((a 1) (b #t)) (if b a (+ a 1)))")).toSatisfy(isOkT(isLetExp)); }); it('parses "let" expressions with type annotations', () => { - expect(p("(let (((a : boolean) #t) ((b : number) 2)) (if a b (+ b b)))")).to.satisfy(isOkT(isLetExp)); + expect(p("(let (((a : boolean) #t) ((b : number) 2)) (if a b (+ b b)))")).toSatisfy(isOkT(isLetExp)); }); it('parses literal expressions', () => { - expect(p("'a")).to.satisfy(isOkT(isLitExp)); - expect(p("'()")).to.satisfy(isOkT(isLitExp)); - expect(p("'(1)")).to.satisfy(isOkT(isLitExp)); + expect(p("'a")).toSatisfy(isOkT(isLitExp)); + expect(p("'()")).toSatisfy(isOkT(isLitExp)); + expect(p("'(1)")).toSatisfy(isOkT(isLitExp)); }); it('parses "letrec" expressions', () => { - expect(p("(letrec ((e (lambda (x) x))) (e 2))")).to.satisfy(isOkT(isLetrecExp)); + expect(p("(letrec ((e (lambda (x) x))) (e 2))")).toSatisfy(isOkT(isLetrecExp)); }); it('parses "letrec" expressions with type annotations', () => { - expect(p("(letrec (((p : (number * number -> number)) (lambda ((x : number) (y : number)) (+ x y)))) (p 1 2))")).to.satisfy(isOkT(isLetrecExp)); + expect(p("(letrec (((p : (number * number -> number)) (lambda ((x : number) (y : number)) (+ x y)))) (p 1 2))")).toSatisfy(isOkT(isLetrecExp)); }); it('parses "set!" expressions', () => { - expect(p("(set! x 1)")).to.satisfy(isOkT(isSetExp)); + expect(p("(set! x 1)")).toSatisfy(isOkT(isSetExp)); }); }); @@ -89,21 +88,21 @@ describe('L5 Unparse', () => { it('unparses "define" expressions with type annotations', () => { const define = "(define (a : number) 1)"; - expect(roundTrip(define)).to.deep.equal(makeOk(define)); + expect(roundTrip(define)).toEqual(makeOk(define)); }); it('unparses procedures with type annotations', () => { const lambda = "(lambda ((x : number)) : number (* x x))"; - expect(roundTrip(lambda)).to.deep.equal(makeOk(lambda)); + expect(roundTrip(lambda)).toEqual(makeOk(lambda)); }); it('unparses "let" expressions with type annotations', () => { const let1 = "(let (((a : boolean) #t) ((b : number) 2)) (if a b (+ b b)))"; - expect(roundTrip(let1)).to.deep.equal(makeOk(let1)); + expect(roundTrip(let1)).toEqual(makeOk(let1)); }); it('unparses "letrec" expressions', () => { const letrec = "(letrec (((p : (number * number -> number)) (lambda ((x : number) (y : number)) (+ x y)))) (p 1 2))"; - expect(roundTrip(letrec)).to.deep.equal(makeOk(letrec)); + expect(roundTrip(letrec)).toEqual(makeOk(letrec)); }); }); diff --git a/test/L5/L5-eval.test.ts b/test/L5/L5-eval.test.ts index dddb9ad..5a61f04 100644 --- a/test/L5/L5-eval.test.ts +++ b/test/L5/L5-eval.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { isVarDecl, isVarRef, parseL5 } from '../../src/L5/L5-ast'; import { evalParse, evalProgram } from '../../src/L5/L5-eval'; import { makeEmptySExp, makeSymbolSExp } from '../../src/L5/L5-value'; @@ -7,132 +6,134 @@ import { makeOk, bind, isOkT, isFailure } from '../../src/shared/result'; describe('L5 Eval', () => { it('evaluates data type literals', () => { - expect(evalParse("1")).to.deep.equal(makeOk(1)); - expect(evalParse("#t")).to.deep.equal(makeOk(true)); - expect(evalParse("#f")).to.deep.equal(makeOk(false)); - expect(evalParse("'a")).to.deep.equal(makeOk(makeSymbolSExp("a"))); - expect(evalParse('"a"')).to.deep.equal(makeOk("a")); - expect(evalParse("'()")).to.deep.equal(makeOk(makeEmptySExp())); - expect(evalParse("'(1 2)")).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); - expect(evalParse("'(1 (2))")).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(makeCompoundSExp(2, makeEmptySExp()), makeEmptySExp())))); + expect(evalParse("1")).toEqual(makeOk(1)); + expect(evalParse("#t")).toEqual(makeOk(true)); + expect(evalParse("#f")).toEqual(makeOk(false)); + expect(evalParse("'a")).toEqual(makeOk(makeSymbolSExp("a"))); + expect(evalParse('"a"')).toEqual(makeOk("a")); + expect(evalParse("'()")).toEqual(makeOk(makeEmptySExp())); + expect(evalParse("'(1 2)")).toEqual(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); + expect(evalParse("'(1 (2))")).toEqual( + makeOk(makeCompoundSExp(1, makeCompoundSExp(makeCompoundSExp(2, makeEmptySExp()), makeEmptySExp()))) + ); }); describe('Primitive Procedures', () => { it('evaluates "+"', () => { - expect(evalParse("(+ 1 2)")).to.deep.equal(makeOk(3)); + expect(evalParse("(+ 1 2)")).toEqual(makeOk(3)); }); it('evaluates "-"', () => { - expect(evalParse("(- 2 1)")).to.deep.equal(makeOk(1)); + expect(evalParse("(- 2 1)")).toEqual(makeOk(1)); }); it('evaluates "*"', () => { - expect(evalParse("(* 2 3)")).to.deep.equal(makeOk(6)); + expect(evalParse("(* 2 3)")).toEqual(makeOk(6)); }); it('evaluates "/"', () => { - expect(evalParse("(/ 4 2)")).to.deep.equal(makeOk(2)); + expect(evalParse("(/ 4 2)")).toEqual(makeOk(2)); }); it('evaluates "<"', () => { - expect(evalParse("(< 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(< 4 2)")).toEqual(makeOk(false)); }); it('evaluates ">"', () => { - expect(evalParse("(> 4 2)")).to.deep.equal(makeOk(true)); + expect(evalParse("(> 4 2)")).toEqual(makeOk(true)); }); it('evaluates "="', () => { - expect(evalParse("(= 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(= 4 2)")).toEqual(makeOk(false)); }); it('evaluates "not"', () => { - expect(evalParse("(not #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(not #t)")).toEqual(makeOk(false)); }); it('evaluates "eq?"', () => { - expect(evalParse("(eq? 'a 'a)")).to.deep.equal(makeOk(true)); + expect(evalParse("(eq? 'a 'a)")).toEqual(makeOk(true)); }); it('evaluates "string=?"', () => { - expect(evalParse('(string=? "a" "a")')).to.deep.equal(makeOk(true)); + expect(evalParse('(string=? "a" "a")')).toEqual(makeOk(true)); }); it('evaluates "cons"', () => { - expect(evalParse("(cons 1 '())")).to.deep.equal(makeOk(makeCompoundSExp(1, makeEmptySExp()))); - expect(evalParse("(cons 1 '(2))")).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); + expect(evalParse("(cons 1 '())")).toEqual(makeOk(makeCompoundSExp(1, makeEmptySExp()))); + expect(evalParse("(cons 1 '(2))")).toEqual(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); }); it('evaluates "car"', () => { - expect(evalParse("(car '(1 2))")).to.deep.equal(makeOk(1)); + expect(evalParse("(car '(1 2))")).toEqual(makeOk(1)); }); it('evaluates "cdr"', () => { - expect(evalParse("(cdr '(1 2))")).to.deep.equal(makeOk(makeCompoundSExp(2, makeEmptySExp()))); - expect(evalParse("(cdr '(1))")).to.deep.equal(makeOk(makeEmptySExp())); + expect(evalParse("(cdr '(1 2))")).toEqual(makeOk(makeCompoundSExp(2, makeEmptySExp()))); + expect(evalParse("(cdr '(1))")).toEqual(makeOk(makeEmptySExp())); }); it('evaluates "list?"', () => { - expect(evalParse("(list? '(1))")).to.deep.equal(makeOk(true)); - expect(evalParse("(list? '())")).to.deep.equal(makeOk(true)); + expect(evalParse("(list? '(1))")).toEqual(makeOk(true)); + expect(evalParse("(list? '())")).toEqual(makeOk(true)); }); it('evaluates "number?"', () => { - expect(evalParse("(number? 1)")).to.deep.equal(makeOk(true)); - expect(evalParse("(number? #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(number? 1)")).toEqual(makeOk(true)); + expect(evalParse("(number? #t)")).toEqual(makeOk(false)); }); it('evaluates "boolean?"', () => { - expect(evalParse("(boolean? #t)")).to.deep.equal(makeOk(true)); - expect(evalParse("(boolean? 0)")).to.deep.equal(makeOk(false)); + expect(evalParse("(boolean? #t)")).toEqual(makeOk(true)); + expect(evalParse("(boolean? 0)")).toEqual(makeOk(false)); }); it('evaluates "symbol?"', () => { - expect(evalParse("(symbol? 'a)")).to.deep.equal(makeOk(true)); - expect(evalParse('(symbol? "a")')).to.deep.equal(makeOk(false)); + expect(evalParse("(symbol? 'a)")).toEqual(makeOk(true)); + expect(evalParse('(symbol? "a")')).toEqual(makeOk(false)); }); it('evaluates "string?"', () => { - expect(evalParse("(string? 'a)")).to.deep.equal(makeOk(false)); - expect(evalParse('(string? "a")')).to.deep.equal(makeOk(true)); + expect(evalParse("(string? 'a)")).toEqual(makeOk(false)); + expect(evalParse('(string? "a")')).toEqual(makeOk(true)); }); }); it('evaluates "define" expressions', () => { - expect(bind(parseL5("(L5 (define x 1) (+ x x))"), evalProgram)).to.deep.equal(makeOk(2)); - expect(bind(parseL5("(L5 (define x 1) (define y (+ x x)) (* y y))"), evalProgram)).to.deep.equal(makeOk(4)); + expect(bind(parseL5("(L5 (define x 1) (+ x x))"), evalProgram)).toEqual(makeOk(2)); + expect(bind(parseL5("(L5 (define x 1) (define y (+ x x)) (* y y))"), evalProgram)).toEqual(makeOk(4)); }); it('evaluates "if" expressions', () => { - expect(evalParse('(if (string? "a") 1 2)')).to.deep.equal(makeOk(1)); - expect(evalParse('(if (not (string? "a")) 1 2)')).to.deep.equal(makeOk(2)); + expect(evalParse('(if (string? "a") 1 2)')).toEqual(makeOk(1)); + expect(evalParse('(if (not (string? "a")) 1 2)')).toEqual(makeOk(2)); }); it('evaluates procedures', () => { const closure = evalParse("(lambda (x) x)"); - expect(closure).to.satisfy(isOkT(isClosure)); + expect(closure).toSatisfy(isOkT(isClosure)); if (isOkT(isClosure)(closure)) { - expect(closure.value.params[0]).to.satisfy(isVarDecl); - expect(closure.value.body[0]).to.satisfy(isVarRef); + expect(closure.value.params[0]).toSatisfy(isVarDecl); + expect(closure.value.body[0]).toSatisfy(isVarRef); } }); it('applies procedures', () => { - expect(evalParse("((lambda (x) (* x x)) 2)")).to.deep.equal(makeOk(4)); - expect(bind(parseL5("(L5 (define square (lambda (x) (* x x))) (square 3))"), evalProgram)).to.deep.equal(makeOk(9)); - expect(bind(parseL5("(L5 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))"), evalProgram)).to.deep.equal(makeOk(3)); + expect(evalParse("((lambda (x) (* x x)) 2)")).toEqual(makeOk(4)); + expect(bind(parseL5("(L5 (define square (lambda (x) (* x x))) (square 3))"), evalProgram)).toEqual(makeOk(9)); + expect(bind(parseL5("(L5 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))"), evalProgram)).toEqual(makeOk(3)); }); it('evaluates recursive procedures', () => { - expect(bind(parseL5("(L5 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))"), evalProgram)).to.deep.equal(makeOk(6)); + expect(bind(parseL5("(L5 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))"), evalProgram)).toEqual(makeOk(6)); }); it('evaluates recursion with "letrec"', () => { - expect(evalParse("(letrec ((f (lambda (n) (if (= n 0) 1 (* n (f (- n 1))))))) (f 5))")).to.deep.equal(makeOk(120)); + expect(evalParse("(letrec ((f (lambda (n) (if (= n 0) 1 (* n (f (- n 1))))))) (f 5))")).toEqual(makeOk(120)); }); it('returns a Failure in "letrec" if a binding is invalid', () => { - expect(evalParse(`(letrec ((a (1 2))) a)`)).to.satisfy(isFailure); + expect(evalParse(`(letrec ((a (1 2))) a)`)).toSatisfy(isFailure); }); it('evaluates the examples', () => { @@ -144,12 +145,12 @@ describe('L5 Eval', () => { 1 (* n (f (- n 1))))))) f)) - (fact 5))`), evalProgram)).to.deep.equal(makeOk(120)); + (fact 5))`), evalProgram)).toEqual(makeOk(120)); // Accidental capture of the z variable if no renaming - works without renaming in env eval. expect(bind(parseL5(` (L5 (define z (lambda (x) (* x x))) - (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalProgram)).to.deep.equal(makeOk(4)); + (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalProgram)).toEqual(makeOk(4)); // Y-combinator expect(bind(parseL5(` @@ -158,7 +159,7 @@ describe('L5 Eval', () => { (lambda (n) (if (= n 0) 1 - (* n ((fact fact) (- n 1))))))) 6))`), evalProgram)).to.deep.equal(makeOk(720)); + (* n ((fact fact) (- n 1))))))) 6))`), evalProgram)).toEqual(makeOk(720)); }); it('evaluates higher-order functions', () => { @@ -168,7 +169,7 @@ describe('L5 Eval', () => { (if (eq? l '()) l (cons (f (car l)) (map f (cdr l)))))) - (map (lambda (x) (* x x)) '(1 2)))`), evalProgram)).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(4, makeEmptySExp())))); + (map (lambda (x) (* x x)) '(1 2)))`), evalProgram)).toEqual(makeOk(makeCompoundSExp(1, makeCompoundSExp(4, makeEmptySExp())))); expect(bind(parseL5(` (L5 (define empty? (lambda (x) (eq? x '()))) @@ -179,11 +180,11 @@ describe('L5 Eval', () => { (if (pred (car l)) (cons (car l) (filter pred (cdr l))) (filter pred (cdr l)))))) - (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalProgram)).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(3, makeEmptySExp())))); + (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalProgram)).toEqual(makeOk(makeCompoundSExp(1, makeCompoundSExp(3, makeEmptySExp())))); expect(bind(parseL5(` (L5 (define compose (lambda (f g) (lambda (x) (f (g x))))) - ((compose not number?) 2))`), evalProgram)).to.deep.equal(makeOk(false)); + ((compose not number?) 2))`), evalProgram)).toEqual(makeOk(false)); }); it('properly captures variables in closures', () => { @@ -191,21 +192,21 @@ describe('L5 Eval', () => { (L5 (define makeAdder (lambda (n) (lambda (y) (+ y n)))) (define a6 (makeAdder 6)) (define a7 (makeAdder 7)) - (+ (a6 1) (a7 1)))`), evalProgram)).to.deep.equal(makeOk(15)); + (+ (a6 1) (a7 1)))`), evalProgram)).toEqual(makeOk(15)); expect(bind(parseL5(` (L5 (define makeCounter (lambda () (let ((c 0)) (lambda () (set! c (+ c 1)) c)))) (define c1 (makeCounter)) (define c2 (makeCounter)) - (+ (+ (c1) (c1)) (+ (c2) (c2))))`), evalProgram)).to.deep.equal(makeOk(6)); + (+ (+ (c1) (c1)) (+ (c2) (c2))))`), evalProgram)).toEqual(makeOk(6)); }); it('evaluates type-annotated expressions', () => { - expect(bind(parseL5("(L5 (define (a : number) 1) a)"), evalProgram)).to.deep.equal(makeOk(1)); - expect(evalParse("((lambda ((x : T)) : T x) #t)")).to.deep.equal(makeOk(true)); - expect(evalParse("(let (((a : boolean) #t) ((b : number) 2)) (if a b (+ b b)))")).to.deep.equal(makeOk(2)); + expect(bind(parseL5("(L5 (define (a : number) 1) a)"), evalProgram)).toEqual(makeOk(1)); + expect(evalParse("((lambda ((x : T)) : T x) #t)")).toEqual(makeOk(true)); + expect(evalParse("(let (((a : boolean) #t) ((b : number) 2)) (if a b (+ b b)))")).toEqual(makeOk(2)); expect(evalParse(` (letrec (((p : (number * number -> number)) (lambda ((x : number) (y : number)) (+ x y)))) - (p 1 2))`)).to.deep.equal(makeOk(3)); + (p 1 2))`)).toEqual(makeOk(3)); }); }); diff --git a/test/L5/L5-substitution-adt.test.ts b/test/L5/L5-substitution-adt.test.ts index 6b4dc94..0c02cc9 100644 --- a/test/L5/L5-substitution-adt.test.ts +++ b/test/L5/L5-substitution-adt.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import * as S from "../../src/L5/L5-substitution-adt"; import { makeTVar, parseTE, unparseTExp, TExp } from "../../src/L5/TExp"; import { bind, isFailure, safe2, makeOk, safe3 } from '../../src/shared/result'; @@ -9,7 +8,7 @@ describe('L5 Substitution ADT', () => { it('returns an error for circular dependencies', () => { const te1 = parseTE("(number -> T1)"); const sub1 = bind(te1, (te: TExp) => S.makeSub([makeTVar("T1")], [te])); - expect(sub1).to.satisfy(isFailure); + expect(sub1).toSatisfy(isFailure); }); }); @@ -18,7 +17,7 @@ describe('L5 Substitution ADT', () => { const sub1 = sub(["T1", "T2"], ["number", "boolean"]); const te1 = parseTE("(T1 * T2 -> T1)"); const unparsed = safe2((sub: S.Sub, te: TExp) => unparseTExp(S.applySub(sub, te)))(sub1, te1); - expect(unparsed).to.deep.equal(makeOk("(number * boolean -> number)")); + expect(unparsed).toEqual(makeOk("(number * boolean -> number)")); }); }); @@ -30,7 +29,7 @@ describe('L5 Substitution ADT', () => { const sub12 = sub(["T3"], ["(number -> S2)"]); const expected1 = bind(sub(["T1", "T2", "T3"], ["(number -> S1)", "(number -> S4)", "(number -> S2)"]), subToStr); const res1 = bind(safe2(S.combineSub)(sub11, sub12), subToStr); - expect(res1).to.deep.equal(expected1); + expect(res1).toEqual(expected1); // {T1:(number -> S1), T2:(number -> T5)} o {T3:(number -> S2), T4:(number -> S1), T5:boolean} => // {T1:(number -> S1), T2:(number -> boolean), T3:(number -> S2), T4:(number -> S1), T5:boolean} @@ -38,7 +37,7 @@ describe('L5 Substitution ADT', () => { const sub22 = sub(["T3", "T4", "T5"], ["(number -> S2)", "(number -> S1)", "boolean"]); const expected2 = bind(sub(["T1", "T2", "T3", "T4", "T5"], ["(number -> S1)", "(number -> boolean)", "(number -> S2)", "(number -> S1)", "boolean"]), subToStr); const res2 = bind(safe2(S.combineSub)(sub21, sub22), subToStr); - expect(res2).to.deep.equal(expected2); + expect(res2).toEqual(expected2); // {T1:(number -> S1), T2:(T5 -> T4)} o {S1:boolean, T3:(number -> S2), T5:(number -> S1), T4:boolean} => // {T1:{number -> boolean}, T2:((number -> S1) -> boolean), T3:(number -> S2), T4:boolean, T5:(number -> S1), S1:boolean} @@ -46,7 +45,7 @@ describe('L5 Substitution ADT', () => { const sub32 = sub(["S1", "T3", "T4", "T5"], ["boolean", "(number -> S2)", "boolean", "(number -> S1)"]); const expected3 = bind(sub(["T1", "T2", "T3", "T4", "T5", "S1"], ["(number -> boolean)", "((number -> S1) -> boolean)", "(number -> S2)", "boolean", "(number -> S1)", "boolean"]), subToStr); const res3 = bind(safe2(S.combineSub)(sub31, sub32), subToStr); - expect(res3).to.deep.equal(expected3); + expect(res3).toEqual(expected3); // {T1:S1, T2:(S2 -> number), T3:boolean} o {S1:(T5 -> (number * T2 -> T2)), S2:T3} => @@ -55,7 +54,7 @@ describe('L5 Substitution ADT', () => { const sub42 = sub(["S1", "S2"], ["(T5 -> (number * T2 -> T2))", "T3"]); const expected4 = bind(sub(["T1", "T2", "T3", "S1", "S2"], ["(T5 -> (number * T2 -> T2))", "(T3 -> number)", "boolean", "(T5 -> (number * T2 -> T2))", "T3"]), subToStr); const res4 = bind(safe2(S.combineSub)(sub41, sub42), subToStr); - expect(res4).to.deep.equal(expected4); + expect(res4).toEqual(expected4); // {T1:S1, T2:(S2 -> number), T3:boolean} o {S1:(T5 -> (number * T2 -> T2)), S2:T3} => // {T1:(T5 -> (number * T2 -> T2)), T2:(T3 -> number), T3:boolean, S1:(T5 -> (number * T2 -> T2)), S2:T3} @@ -63,7 +62,7 @@ describe('L5 Substitution ADT', () => { const sub52 = sub(["S1", "S2"], ["(T5 -> (number * T2 -> T2))", "T3"]); const expected5 = bind(sub(["T1", "T2", "T3", "S1", "S2"], ["(T5 -> (number * T2 -> T2))", "(T3 -> number)", "boolean", "(T5 -> (number * T2 -> T2))", "T3"]), subToStr); const res5 = bind(safe2(S.combineSub)(sub51, sub52), subToStr); - expect(res5).to.deep.equal(expected5); + expect(res5).toEqual(expected5); // {T1:number, T2:(T4 -> number), T3:T9} o {T4:(T1 -> number), T5:boolean, T6:T7} => // {T1:number, T2:((T1 -> number) -> number), T3:T9, T4:(T1 -> number), T5:boolean, T6:T7} @@ -71,7 +70,7 @@ describe('L5 Substitution ADT', () => { const sub62 = sub(["T4", "T5", "T6"], ["(T1 -> number)", "boolean", "T7"]); const expected6 = bind(sub(["T1", "T2", "T3", "T4", "T5", "T6"], ["number", "((T1 -> number) -> number)", "T9", "(T1 -> number)", "boolean", "T7"]), subToStr); const res6 = bind(safe2(S.combineSub)(sub61, sub62), subToStr); - expect(res6).to.deep.equal(expected6); + expect(res6).toEqual(expected6); }); it('returns an error for circular substitutions', () => { @@ -79,7 +78,7 @@ describe('L5 Substitution ADT', () => { const sub1 = sub(["T3", "T4", "T5", "S1"], ["boolean", "(number -> S1)", "boolean", "(number -> T2)"]); const sub2 = sub(["T1", "T2"], ["(number -> S1)", "(T3 -> S1)"]); const res = safe2(S.combineSub)(sub1, sub2); - expect(res).to.satisfy(isFailure); + expect(res).toSatisfy(isFailure); }); it('combines substitutions with overlapping variables', () => { @@ -88,7 +87,7 @@ describe('L5 Substitution ADT', () => { const sub2 = sub(["T5", "T8"], ["T7", "boolean"]); const expected = bind(sub(["T5", "T7", "T8"], ["T7", "number", "(T7 * number -> T3)"]), subToStr); const res = bind(safe2(S.combineSub)(sub1, sub2), subToStr); - expect(res).to.deep.equal(expected); + expect(res).toEqual(expected); }); }); @@ -100,7 +99,7 @@ describe('L5 Substitution ADT', () => { const t2 = parseTE("(T21 -> (number * T23 -> T22))"); const expected = bind(sub(["T1", "T2", "T3", "S1"], ["(T21 -> (number * T23 -> T22))", "((T21 -> (number * T23 -> T22)) -> number)", "boolean", "(T21 -> (number * T23 -> T22))"]), subToStr); const res = bind(safe3(S.extendSub)(sub1, makeOk(v2), t2), subToStr); - expect(res).to.deep.equal(expected); + expect(res).toEqual(expected); }); }); }); diff --git a/test/L5/L5-type-equations.test.ts b/test/L5/L5-type-equations.test.ts index b927a74..a1571b2 100644 --- a/test/L5/L5-type-equations.test.ts +++ b/test/L5/L5-type-equations.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { makeTVar } from '../../src/L5/TExp'; import { makeSub } from '../../src/L5/L5-substitution-adt'; import { solveEquations, makeEquation } from '../../src/L5/L5-type-equations'; @@ -7,91 +6,91 @@ import { makeOk, isFailure } from '../../src/shared/result'; describe('L5 Type Equations', () => { it('solves equations', () => { - expect(solveEquations([makeEquation(makeTVar("T1"), makeTVar("T2"))])).to.deep.equal(makeSub([makeTVar("T1")], [makeTVar("T2")])); + expect(solveEquations([makeEquation(makeTVar("T1"), makeTVar("T2"))])).toEqual(makeSub([makeTVar("T1")], [makeTVar("T2")])); }); it('infers the types of atoms', () => { - expect(verifyTeOfExprWithEquations("3", "number")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("3", "number")).toEqual(makeOk(true)); }); it('infers the type of applications', () => { - expect(verifyTeOfExprWithEquations("(+ 1 2)", "number")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(+ (+ 1 2) 3)", "number")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(> 1 2)", "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(> (+ 1 2) 2)", "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("((lambda (x) (+ x 1)) 3)", "number")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(+ 1 2)", "number")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(+ (+ 1 2) 3)", "number")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(> 1 2)", "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(> (+ 1 2) 2)", "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("((lambda (x) (+ x 1)) 3)", "number")).toEqual(makeOk(true)); }); it('infers the type of primitive procedures', () => { - expect(verifyTeOfExprWithEquations("+", "(number * number -> number)")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations(">", "(number * number -> boolean)")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("+", "(number * number -> number)")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations(">", "(number * number -> boolean)")).toEqual(makeOk(true)); }); it("infers the type of primitive op applications", () => { - expect(verifyTeOfExprWithEquations("(+ 1 2)", "number")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(- 1 2)", "number")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(* 1 2)", "number")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(/ 1 2)", "number")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(+ 1 2)", "number")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(- 1 2)", "number")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(* 1 2)", "number")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(/ 1 2)", "number")).toEqual(makeOk(true)); - expect(verifyTeOfExprWithEquations("(= 1 2)", "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(< 1 2)", "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(> 1 2)", "boolean")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(= 1 2)", "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(< 1 2)", "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(> 1 2)", "boolean")).toEqual(makeOk(true)); - expect(verifyTeOfExprWithEquations("(not (< 1 2))", "boolean")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(not (< 1 2))", "boolean")).toEqual(makeOk(true)); }); it('infers the type of generic primitive op application', () => { - expect(verifyTeOfExprWithEquations("(eq? 1 2)", "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations('(string=? "a" "b")', "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations('(number? 1)', "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations('(boolean? "a")', "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations('(string? "a")', "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations('(symbol? "a")', "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations('(list? "a")', "boolean")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations('(pair? "a")', "boolean")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(eq? 1 2)", "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations('(string=? "a" "b")', "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations('(number? 1)', "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations('(boolean? "a")', "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations('(string? "a")', "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations('(symbol? "a")', "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations('(list? "a")', "boolean")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations('(pair? "a")', "boolean")).toEqual(makeOk(true)); }); it('infers the type of procedures', () => { - expect(verifyTeOfExprWithEquations("(lambda (x) (+ x 1))", "(number -> number)")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(lambda (x) (x 1))", "((number -> T) -> T)")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(lambda (x) (+ (+ x 1) (+ x 1)))", "(number -> number)")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(lambda (x) (+ x 1))", "(number -> number)")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(lambda (x) (x 1))", "((number -> T) -> T)")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(lambda (x) (+ (+ x 1) (+ x 1)))", "(number -> number)")).toEqual(makeOk(true)); // f: [N->N] // ==> (lambda(x) (- (f 3) (f x))) : [N->N] // ==> (lambda(f) (lambda(x) (- (f 3) (f x)))) : [[N->N]->[N->N]] expect(verifyTeOfExprWithEquations("(lambda (f) (lambda (x) (- (f 3) (f x))))", - "((number -> number) -> (number -> number))")).to.deep.equal(makeOk(true)); + "((number -> number) -> (number -> number))")).toEqual(makeOk(true)); }); it('cannot infer the type of a circular type', () => { - expect(verifyTeOfExprWithEquations("(lambda (x) (x x))", "T")).to.satisfy(isFailure); + expect(verifyTeOfExprWithEquations("(lambda (x) (x x))", "T")).toSatisfy(isFailure); }); it('cannot infer the type of a free variable without context', () => { - expect(verifyTeOfExprWithEquations("x", "T")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("x", "T")).toEqual(makeOk(true)); }); it('infers the type of a free variable in context', () => { - expect(verifyTeOfExprWithEquations("(+ x 1)", "number")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(+ x 1)", "number")).toEqual(makeOk(true)); }); it('cannot infer the type with insufficient context', () => { - expect(verifyTeOfExprWithEquations("(f 1)", "T")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(f 1)", "T")).toEqual(makeOk(true)); }); it('infers the types of primitive procedure applications with free variables', () => { - expect(verifyTeOfExprWithEquations("(> (f 1) 0)", "boolean")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(> (f 1) 0)", "boolean")).toEqual(makeOk(true)); }); it('infers the types of unused parameters in procedures', () => { - expect(verifyTeOfExprWithEquations("(lambda (x) 1)", "(T -> number)")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("(lambda (x y) x)", "(T1 * T2 -> T1)")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("((lambda (x) 1) 2)", "number")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(lambda (x) 1)", "(T -> number)")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("(lambda (x y) x)", "(T1 * T2 -> T1)")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("((lambda (x) 1) 2)", "number")).toEqual(makeOk(true)); }); it('returns an error for an incorrect number of parameters passed to procedure', () => { - expect(verifyTeOfExprWithEquations("((lambda () 1) 2)", "Error")).to.satisfy(isFailure); - expect(verifyTeOfExprWithEquations("((lambda (x) 1))", "Error")).to.satisfy(isFailure); + expect(verifyTeOfExprWithEquations("((lambda () 1) 2)", "Error")).toSatisfy(isFailure); + expect(verifyTeOfExprWithEquations("((lambda (x) 1))", "Error")).toSatisfy(isFailure); }); it('infers the type of "compose"', () => { @@ -100,15 +99,15 @@ describe('L5 Type Equations', () => { // ==> (lambda(n) (f (g n))) : [T1->T3] // ==> (lambda(f g) (lambda(n) (f (g n)))) : [[T2-T3]*[T1->T2]->[T1->T3]] expect(verifyTeOfExprWithEquations("(lambda (f g) (lambda (n) (f (g n))))", - "((T2 -> T3) * (T1 -> T2) -> (T1 -> T3))")).to.deep.equal(makeOk(true)); + "((T2 -> T3) * (T1 -> T2) -> (T1 -> T3))")).toEqual(makeOk(true)); }); it('infers the type of higher-order functions', () => { - expect(verifyTeOfExprWithEquations("((lambda (x) (x 1 2)) +)", "number")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithEquations("((lambda (x) (x 1)) (lambda (y) y))", "number")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("((lambda (x) (x 1 2)) +)", "number")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithEquations("((lambda (x) (x 1)) (lambda (y) y))", "number")).toEqual(makeOk(true)); }); it('infers the type of thunks', () => { - expect(verifyTeOfExprWithEquations("(lambda () (lambda (x) (+ (+ x 1) (+ x 1))))", "(Empty -> (number -> number))")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithEquations("(lambda () (lambda (x) (+ (+ x 1) (+ x 1))))", "(Empty -> (number -> number))")).toEqual(makeOk(true)); }); }); diff --git a/test/L5/L5-typecheck.test.ts b/test/L5/L5-typecheck.test.ts index 6ea35fe..513edc4 100644 --- a/test/L5/L5-typecheck.test.ts +++ b/test/L5/L5-typecheck.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { parseL5Exp, Exp } from '../../src/L5/L5-ast'; import { typeofExp, L5typeof } from '../../src/L5/L5-typecheck'; import { makeEmptyTEnv, makeExtendTEnv } from '../../src/L5/TEnv'; @@ -9,171 +8,177 @@ import { parse as p } from "../../src/shared/parser"; describe('L5 Type Checker', () => { describe('parseTE', () => { it('parses atoms', () => { - expect(parseTE("number")).to.deep.equal(makeOk(makeNumTExp())); - expect(parseTE("boolean")).to.deep.equal(makeOk(makeBoolTExp())); + expect(parseTE("number")).toEqual(makeOk(makeNumTExp())); + expect(parseTE("boolean")).toEqual(makeOk(makeBoolTExp())); }); it('parses type variables', () => { - expect(parseTE("T1")).to.deep.equal(makeOk(makeTVar("T1"))); + expect(parseTE("T1")).toEqual(makeOk(makeTVar("T1"))); }); it('parses procedures', () => { - expect(parseTE("(T * T -> boolean)")).to.deep.equal(makeOk(makeProcTExp([makeTVar("T"), makeTVar("T")], makeBoolTExp()))); - expect(parseTE("(number -> (number -> number))")).to.deep.equal(makeOk(makeProcTExp([makeNumTExp()], makeProcTExp([makeNumTExp()], makeNumTExp())))); + expect(parseTE("(T * T -> boolean)")).toEqual(makeOk(makeProcTExp([makeTVar("T"), makeTVar("T")], makeBoolTExp()))); + expect(parseTE("(number -> (number -> number))")).toEqual( + makeOk(makeProcTExp([makeNumTExp()], makeProcTExp([makeNumTExp()], makeNumTExp()))) + ); }); it('parses "void" and "Empty"', () => { - expect(parseTE("void")).to.deep.equal(makeOk(makeVoidTExp())); - expect(parseTE("(Empty -> void)")).to.deep.equal(makeOk(makeProcTExp([], makeVoidTExp()))); + expect(parseTE("void")).toEqual(makeOk(makeVoidTExp())); + expect(parseTE("(Empty -> void)")).toEqual(makeOk(makeProcTExp([], makeVoidTExp()))); }); }); describe('unparseTExp', () => { it('unparses atoms', () => { - expect(unparseTExp(makeNumTExp())).to.deep.equal(makeOk("number")); - expect(unparseTExp(makeBoolTExp())).to.deep.equal(makeOk("boolean")); + expect(unparseTExp(makeNumTExp())).toEqual(makeOk("number")); + expect(unparseTExp(makeBoolTExp())).toEqual(makeOk("boolean")); }); it('unparses type variables', () => { - expect(unparseTExp(makeTVar("T1"))).to.deep.equal(makeOk("T1")); + expect(unparseTExp(makeTVar("T1"))).toEqual(makeOk("T1")); }); it('unparses procedures', () => { - expect(unparseTExp(makeProcTExp([makeTVar("T"), makeTVar("T")], makeBoolTExp()))).to.deep.equal(makeOk("(T * T -> boolean)")); - expect(unparseTExp(makeProcTExp([makeNumTExp()], makeProcTExp([makeNumTExp()], makeNumTExp())))).to.deep.equal(makeOk("(number -> (number -> number))")); + expect(unparseTExp(makeProcTExp([makeTVar("T"), makeTVar("T")], makeBoolTExp()))).toEqual(makeOk("(T * T -> boolean)")); + expect(unparseTExp(makeProcTExp([makeNumTExp()], makeProcTExp([makeNumTExp()], makeNumTExp())))).toEqual(makeOk("(number -> (number -> number))")); }); }); describe('L5typeof', () => { it('returns the types of atoms', () => { - expect(L5typeof("5")).to.deep.equal(makeOk("number")); - expect(L5typeof("#t")).to.deep.equal(makeOk("boolean")); + expect(L5typeof("5")).toEqual(makeOk("number")); + expect(L5typeof("#t")).toEqual(makeOk("boolean")); }); it('returns the type of primitive procedures', () => { - expect(L5typeof("+")).to.deep.equal(makeOk("(number * number -> number)")); - expect(L5typeof("-")).to.deep.equal(makeOk("(number * number -> number)")); - expect(L5typeof("*")).to.deep.equal(makeOk("(number * number -> number)")); - expect(L5typeof("/")).to.deep.equal(makeOk("(number * number -> number)")); - expect(L5typeof("=")).to.deep.equal(makeOk("(number * number -> boolean)")); - expect(L5typeof("<")).to.deep.equal(makeOk("(number * number -> boolean)")); - expect(L5typeof(">")).to.deep.equal(makeOk("(number * number -> boolean)")); - expect(L5typeof("not")).to.deep.equal(makeOk("(boolean -> boolean)")); + expect(L5typeof("+")).toEqual(makeOk("(number * number -> number)")); + expect(L5typeof("-")).toEqual(makeOk("(number * number -> number)")); + expect(L5typeof("*")).toEqual(makeOk("(number * number -> number)")); + expect(L5typeof("/")).toEqual(makeOk("(number * number -> number)")); + expect(L5typeof("=")).toEqual(makeOk("(number * number -> boolean)")); + expect(L5typeof("<")).toEqual(makeOk("(number * number -> boolean)")); + expect(L5typeof(">")).toEqual(makeOk("(number * number -> boolean)")); + expect(L5typeof("not")).toEqual(makeOk("(boolean -> boolean)")); }); it("returns the type of primitive op applications", () => { - expect(L5typeof("(+ 1 2)")).to.deep.equal(makeOk("number")); - expect(L5typeof("(- 1 2)")).to.deep.equal(makeOk("number")); - expect(L5typeof("(* 1 2)")).to.deep.equal(makeOk("number")); - expect(L5typeof("(/ 1 2)")).to.deep.equal(makeOk("number")); + expect(L5typeof("(+ 1 2)")).toEqual(makeOk("number")); + expect(L5typeof("(- 1 2)")).toEqual(makeOk("number")); + expect(L5typeof("(* 1 2)")).toEqual(makeOk("number")); + expect(L5typeof("(/ 1 2)")).toEqual(makeOk("number")); - expect(L5typeof("(= 1 2)")).to.deep.equal(makeOk("boolean")); - expect(L5typeof("(< 1 2)")).to.deep.equal(makeOk("boolean")); - expect(L5typeof("(> 1 2)")).to.deep.equal(makeOk("boolean")); + expect(L5typeof("(= 1 2)")).toEqual(makeOk("boolean")); + expect(L5typeof("(< 1 2)")).toEqual(makeOk("boolean")); + expect(L5typeof("(> 1 2)")).toEqual(makeOk("boolean")); - expect(L5typeof("(not (< 1 2))")).to.deep.equal(makeOk("boolean")); + expect(L5typeof("(not (< 1 2))")).toEqual(makeOk("boolean")); }); it.skip('type checking of generic functions is not supported', () => { // All of these fail in TypeCheck because we do not support generic functions // They do work in Type Inference. - expect(L5typeof("(eq? 1 2)")).to.deep.equal(makeOk("boolean")); - expect(L5typeof('(string=? "a" "b")')).to.deep.equal(makeOk("boolean")); - expect(L5typeof('(number? 1)')).to.deep.equal(makeOk("boolean")); - expect(L5typeof('(boolean? "a")')).to.deep.equal(makeOk("boolean")); - expect(L5typeof('(string? "a")')).to.deep.equal(makeOk("boolean")); - expect(L5typeof('(symbol? "a")')).to.deep.equal(makeOk("boolean")); - expect(L5typeof('(list? "a")')).to.deep.equal(makeOk("boolean")); - expect(L5typeof('(pair? "a")')).to.deep.equal(makeOk("boolean")); + expect(L5typeof("(eq? 1 2)")).toEqual(makeOk("boolean")); + expect(L5typeof('(string=? "a" "b")')).toEqual(makeOk("boolean")); + expect(L5typeof('(number? 1)')).toEqual(makeOk("boolean")); + expect(L5typeof('(boolean? "a")')).toEqual(makeOk("boolean")); + expect(L5typeof('(string? "a")')).toEqual(makeOk("boolean")); + expect(L5typeof('(symbol? "a")')).toEqual(makeOk("boolean")); + expect(L5typeof('(list? "a")')).toEqual(makeOk("boolean")); + expect(L5typeof('(pair? "a")')).toEqual(makeOk("boolean")); }); it('returns the type of a VarRef in a given TEnv', () => { - expect(bind(bind(p("x"), parseL5Exp), (exp: Exp) => typeofExp(exp, makeExtendTEnv(["x"], [makeNumTExp()], makeEmptyTEnv())))).to.deep.equal(makeOk(makeNumTExp())); + expect(bind(bind(p("x"), parseL5Exp), (exp: Exp) => typeofExp(exp, makeExtendTEnv(["x"], [makeNumTExp()], makeEmptyTEnv())))).toEqual(makeOk(makeNumTExp())); }); it('returns the type of "if" expressions', () => { - expect(L5typeof("(if (> 1 2) 1 2)")).to.deep.equal(makeOk("number")); - expect(L5typeof("(if (= 1 2) #t #f)")).to.deep.equal(makeOk("boolean")); + expect(L5typeof("(if (> 1 2) 1 2)")).toEqual(makeOk("number")); + expect(L5typeof("(if (= 1 2) #t #f)")).toEqual(makeOk("boolean")); }); it('returns the type of procedures', () => { - expect(L5typeof("(lambda ((x : number)) : number x)")).to.deep.equal(makeOk("(number -> number)")); - expect(L5typeof("(lambda ((x : number)) : boolean (> x 1))")).to.deep.equal(makeOk("(number -> boolean)")); - expect(L5typeof("(lambda((x : number)) : (number -> number) (lambda((y : number)) : number (* y x)))")).to.deep.equal(makeOk("(number -> (number -> number))")); - expect(L5typeof("(lambda((f : (number -> number))) : number (f 2))")).to.deep.equal(makeOk("((number -> number) -> number)")); - expect(L5typeof("(lambda((x : number)) : number (let (((y : number) x)) (+ x y)))")).to.deep.equal(makeOk("(number -> number)")); + expect(L5typeof("(lambda ((x : number)) : number x)")).toEqual(makeOk("(number -> number)")); + expect(L5typeof("(lambda ((x : number)) : boolean (> x 1))")).toEqual(makeOk("(number -> boolean)")); + expect(L5typeof("(lambda((x : number)) : (number -> number) (lambda((y : number)) : number (* y x)))")).toEqual(makeOk("(number -> (number -> number))")); + expect(L5typeof("(lambda((f : (number -> number))) : number (f 2))")).toEqual(makeOk("((number -> number) -> number)")); + expect(L5typeof("(lambda((x : number)) : number (let (((y : number) x)) (+ x y)))")).toEqual(makeOk("(number -> number)")); }); it('returns the type of "let" expressions', () => { - expect(L5typeof("(let (((x : number) 1)) (* x 2))")).to.deep.equal(makeOk("number")); - expect(L5typeof("(let (((x : number) 1) ((y : number) 3)) (+ x y))")).to.deep.equal(makeOk("number")); - expect(L5typeof("(let (((x : number) 1) ((y : number) 2)) (lambda((a : number)) : number (+ (* x a) y)))")).to.deep.equal(makeOk("(number -> number)")); + expect(L5typeof("(let (((x : number) 1)) (* x 2))")).toEqual(makeOk("number")); + expect(L5typeof("(let (((x : number) 1) ((y : number) 3)) (+ x y))")).toEqual(makeOk("number")); + expect(L5typeof("(let (((x : number) 1) ((y : number) 2)) (lambda((a : number)) : number (+ (* x a) y)))")).toEqual(makeOk("(number -> number)")); }); it('returns the type of "letrec" expressions', () => { - expect(L5typeof("(letrec (((p1 : (number -> number)) (lambda((x : number)) : number (* x x)))) p1)")).to.deep.equal(makeOk("(number -> number)")); - expect(L5typeof("(letrec (((p1 : (number -> number)) (lambda((x : number)) : number (* x x)))) (p1 2))")).to.deep.equal(makeOk("number")); + expect(L5typeof("(letrec (((p1 : (number -> number)) (lambda((x : number)) : number (* x x)))) p1)")).toEqual(makeOk("(number -> number)")); + expect(L5typeof("(letrec (((p1 : (number -> number)) (lambda((x : number)) : number (* x x)))) (p1 2))")).toEqual(makeOk("number")); expect(L5typeof(` (letrec (((odd? : (number -> boolean)) (lambda((n : number)) : boolean (if (= n 0) #f (even? (- n 1))))) ((even? : (number -> boolean)) (lambda((n : number)) : boolean (if (= n 0) #t (odd? (- n 1)))))) - (odd? 12))`)).to.deep.equal(makeOk("boolean")); + (odd? 12))`)).toEqual(makeOk("boolean")); }); it('returns "void" as the type of "define" expressions', () => { - expect(L5typeof("(define (foo : number) 5)")).to.deep.equal(makeOk("void")); - expect(L5typeof("(define (foo : (number * number -> number)) (lambda((x : number) (y : number)) : number (+ x y)))")).to.deep.equal(makeOk("void")); - expect(L5typeof("(define (x : (Empty -> number)) (lambda () : number 1))")).to.deep.equal(makeOk("void")); + expect(L5typeof("(define (foo : number) 5)")).toEqual(makeOk("void")); + expect(L5typeof("(define (foo : (number * number -> number)) (lambda((x : number) (y : number)) : number (+ x y)))")).toEqual(makeOk("void")); + expect(L5typeof("(define (x : (Empty -> number)) (lambda () : number 1))")).toEqual(makeOk("void")); }); it.skip('returns "literal" as the type for literal expressions', () => { - expect(L5typeof("(quote ())")).to.deep.equal(makeOk("literal")); + expect(L5typeof("(quote ())")).toEqual(makeOk("literal")); }); describe.skip('Pairs', () => { it('returns the pair type for "cons" applications', () => { - expect(L5typeof("(cons 1 '())")).to.deep.equal(makeOk("(Pair number literal)")); - expect(L5typeof("(cons 1 1)")).to.deep.equal(makeOk("(Pair number number)")); + expect(L5typeof("(cons 1 '())")).toEqual(makeOk("(Pair number literal)")); + expect(L5typeof("(cons 1 1)")).toEqual(makeOk("(Pair number number)")); }); it('returns the correct type for applications of "car" and "cdr" on pairs', () => { - expect(L5typeof("(car (cons 1 1))")).to.deep.equal(makeOk("number")); - expect(L5typeof("(cdr (cons 1 #t))")).to.deep.equal(makeOk("boolean")); - expect(L5typeof("(cdr (cons (cons 1 2) (cons 1 2)))")).to.deep.equal(makeOk("(Pair number number)")); - expect(L5typeof("(cdr (cons (cons 1 2) (cons 1 #f)))")).to.deep.equal(makeOk("(Pair number boolean)")); - expect(L5typeof("(car (cons (cons 1 2) (cons 1 #f)))")).to.deep.equal(makeOk("(Pair number number)")); - expect(L5typeof("(car (cons (cons (cons #t #t) 2) (cons 1 #f)))")).to.deep.equal(makeOk("(Pair (Pair boolean boolean) number)")); - expect(L5typeof("(cdr (cons (cons (cons #t #t) 2) (cons 1 #f)))")).to.deep.equal(makeOk("(Pair number boolean)")); + expect(L5typeof("(car (cons 1 1))")).toEqual(makeOk("number")); + expect(L5typeof("(cdr (cons 1 #t))")).toEqual(makeOk("boolean")); + expect(L5typeof("(cdr (cons (cons 1 2) (cons 1 2)))")).toEqual(makeOk("(Pair number number)")); + expect(L5typeof("(cdr (cons (cons 1 2) (cons 1 #f)))")).toEqual(makeOk("(Pair number boolean)")); + expect(L5typeof("(car (cons (cons 1 2) (cons 1 #f)))")).toEqual(makeOk("(Pair number number)")); + expect(L5typeof("(car (cons (cons (cons #t #t) 2) (cons 1 #f)))")).toEqual(makeOk("(Pair (Pair boolean boolean) number)")); + expect(L5typeof("(cdr (cons (cons (cons #t #t) 2) (cons 1 #f)))")).toEqual(makeOk("(Pair number boolean)")); }); it('returns the correct type for procedures that return pairs', () => { - expect(L5typeof("(lambda((a : number) (b : number)) : (Pair number number) (cons a b))")).to.deep.equal(makeOk("(number * number -> (Pair number number))")); + expect(L5typeof("(lambda((a : number) (b : number)) : (Pair number number) (cons a b))")).toEqual(makeOk("(number * number -> (Pair number number))")); }); it('returns the correct type for procedures that take pairs as arguments', () => { - expect(L5typeof("(lambda((a : number) (b : (Pair number boolean))) : (Pair number (Pair number boolean)) (cons a b))")).to.deep.equal(makeOk("(number * (Pair number boolean) -> (Pair number (Pair number boolean)))")); + expect(L5typeof("(lambda((a : number) (b : (Pair number boolean))) : (Pair number (Pair number boolean)) (cons a b))")).toEqual( + makeOk("(number * (Pair number boolean) -> (Pair number (Pair number boolean)))") + ); }); it('returns the correct type for procedures that take and return pairs', () => { expect(L5typeof(`(lambda ((a : (Pair number number)) (b : (Pair number boolean))) : (Pair (Pair number number) (Pair (Pair number number) (Pair number boolean))) - (cons a (cons a b)))`)).to.deep.equal(makeOk("((Pair number number) * (Pair number boolean) -> (Pair (Pair number number) (Pair (Pair number number) (Pair number boolean))))")); + (cons a (cons a b)))`)).toEqual( + makeOk("((Pair number number) * (Pair number boolean) -> (Pair (Pair number number) (Pair (Pair number number) (Pair number boolean))))") + ); }); it('returns "void" when defining pairs', () => { - expect(L5typeof("(define (x : (Pair number boolean)) (cons 1 #t))")).to.deep.equal(makeOk("void")); - expect(L5typeof("(define (x : (Pair (T1 -> T1) number)) (cons (lambda ((y : T1)) : T1 y) 2))")).to.deep.equal(makeOk("void")); + expect(L5typeof("(define (x : (Pair number boolean)) (cons 1 #t))")).toEqual(makeOk("void")); + expect(L5typeof("(define (x : (Pair (T1 -> T1) number)) (cons (lambda ((y : T1)) : T1 y) 2))")).toEqual(makeOk("void")); }); }); it('returns the type of polymorphic procedures', () => { - expect(L5typeof("(lambda((x : T1)) : T1 x)")).to.deep.equal(makeOk("(T1 -> T1)")); + expect(L5typeof("(lambda((x : T1)) : T1 x)")).toEqual(makeOk("(T1 -> T1)")); expect(L5typeof(`(let (((x : number) 1)) (lambda((y : T) (z : T)) : T - (if (> x 2) y z)))`)).to.deep.equal(makeOk("(T * T -> T)")); - expect(L5typeof("(lambda () : number 1)")).to.deep.equal(makeOk("(Empty -> number)")); + (if (> x 2) y z)))`)).toEqual(makeOk("(T * T -> T)")); + expect(L5typeof("(lambda () : number 1)")).toEqual(makeOk("(Empty -> number)")); expect(L5typeof(`(define (x : (T1 -> (T1 -> number))) (lambda ((x : T1)) : (T1 -> number) - (lambda((y : T1)) : number 5)))`)).to.deep.equal(makeOk("void")); + (lambda((y : T1)) : number 5)))`)).toEqual(makeOk("void")); }); }); }); diff --git a/test/L5/L5-typeinference.test.ts b/test/L5/L5-typeinference.test.ts index 9b0c421..734363f 100644 --- a/test/L5/L5-typeinference.test.ts +++ b/test/L5/L5-typeinference.test.ts @@ -1,4 +1,3 @@ -import { expect } from 'chai'; import { inferTypeOf, typeofExp } from "../../src/L5/L5-typeinference"; import { parseL5Exp, Exp } from "../../src/L5/L5-ast"; import { makeExtendTEnv, makeEmptyTEnv } from "../../src/L5/TEnv"; @@ -10,136 +9,136 @@ import { parse as p } from "../../src/shared/parser"; describe('L5 Type Inference', () => { describe('inferTypeOf', () => { it('infers the type of atoms', () => { - expect(inferTypeOf("5")).to.deep.equal(makeOk("number")); - expect(inferTypeOf("#t")).to.deep.equal(makeOk("boolean")); + expect(inferTypeOf("5")).toEqual(makeOk("number")); + expect(inferTypeOf("#t")).toEqual(makeOk("boolean")); }); it('infers the type of primitive procedures', () => { - expect(inferTypeOf("+")).to.deep.equal(makeOk("(number * number -> number)")); - expect(inferTypeOf("-")).to.deep.equal(makeOk("(number * number -> number)")); - expect(inferTypeOf("*")).to.deep.equal(makeOk("(number * number -> number)")); - expect(inferTypeOf("/")).to.deep.equal(makeOk("(number * number -> number)")); - expect(inferTypeOf("=")).to.deep.equal(makeOk("(number * number -> boolean)")); - expect(inferTypeOf("<")).to.deep.equal(makeOk("(number * number -> boolean)")); - expect(inferTypeOf(">")).to.deep.equal(makeOk("(number * number -> boolean)")); - expect(inferTypeOf("not")).to.deep.equal(makeOk("(boolean -> boolean)")); + expect(inferTypeOf("+")).toEqual(makeOk("(number * number -> number)")); + expect(inferTypeOf("-")).toEqual(makeOk("(number * number -> number)")); + expect(inferTypeOf("*")).toEqual(makeOk("(number * number -> number)")); + expect(inferTypeOf("/")).toEqual(makeOk("(number * number -> number)")); + expect(inferTypeOf("=")).toEqual(makeOk("(number * number -> boolean)")); + expect(inferTypeOf("<")).toEqual(makeOk("(number * number -> boolean)")); + expect(inferTypeOf(">")).toEqual(makeOk("(number * number -> boolean)")); + expect(inferTypeOf("not")).toEqual(makeOk("(boolean -> boolean)")); }); it("infers the type of primitive op applications", () => { - expect(inferTypeOf("(+ 1 2)")).to.deep.equal(makeOk("number")); - expect(inferTypeOf("(- 1 2)")).to.deep.equal(makeOk("number")); - expect(inferTypeOf("(* 1 2)")).to.deep.equal(makeOk("number")); - expect(inferTypeOf("(/ 1 2)")).to.deep.equal(makeOk("number")); + expect(inferTypeOf("(+ 1 2)")).toEqual(makeOk("number")); + expect(inferTypeOf("(- 1 2)")).toEqual(makeOk("number")); + expect(inferTypeOf("(* 1 2)")).toEqual(makeOk("number")); + expect(inferTypeOf("(/ 1 2)")).toEqual(makeOk("number")); - expect(inferTypeOf("(= 1 2)")).to.deep.equal(makeOk("boolean")); - expect(inferTypeOf("(< 1 2)")).to.deep.equal(makeOk("boolean")); - expect(inferTypeOf("(> 1 2)")).to.deep.equal(makeOk("boolean")); + expect(inferTypeOf("(= 1 2)")).toEqual(makeOk("boolean")); + expect(inferTypeOf("(< 1 2)")).toEqual(makeOk("boolean")); + expect(inferTypeOf("(> 1 2)")).toEqual(makeOk("boolean")); - expect(inferTypeOf("(not (< 1 2))")).to.deep.equal(makeOk("boolean")); + expect(inferTypeOf("(not (< 1 2))")).toEqual(makeOk("boolean")); }); it('infers the type of generic primitive op application', () => { - expect(inferTypeOf("(eq? 1 2)")).to.deep.equal(makeOk("boolean")); - expect(inferTypeOf('(string=? "a" "b")')).to.deep.equal(makeOk("boolean")); - expect(inferTypeOf('(number? 1)')).to.deep.equal(makeOk("boolean")); - expect(inferTypeOf('(boolean? "a")')).to.deep.equal(makeOk("boolean")); - expect(inferTypeOf('(string? "a")')).to.deep.equal(makeOk("boolean")); - expect(inferTypeOf('(symbol? "a")')).to.deep.equal(makeOk("boolean")); - expect(inferTypeOf('(list? "a")')).to.deep.equal(makeOk("boolean")); - expect(inferTypeOf('(pair? "a")')).to.deep.equal(makeOk("boolean")); + expect(inferTypeOf("(eq? 1 2)")).toEqual(makeOk("boolean")); + expect(inferTypeOf('(string=? "a" "b")')).toEqual(makeOk("boolean")); + expect(inferTypeOf('(number? 1)')).toEqual(makeOk("boolean")); + expect(inferTypeOf('(boolean? "a")')).toEqual(makeOk("boolean")); + expect(inferTypeOf('(string? "a")')).toEqual(makeOk("boolean")); + expect(inferTypeOf('(symbol? "a")')).toEqual(makeOk("boolean")); + expect(inferTypeOf('(list? "a")')).toEqual(makeOk("boolean")); + expect(inferTypeOf('(pair? "a")')).toEqual(makeOk("boolean")); }); it('infers the type of a VarRef in a given TEnv', () => { - expect(bind(bind(p("x"), parseL5Exp), (exp: Exp) => typeofExp(exp, makeExtendTEnv(["x"], [makeNumTExp()], makeEmptyTEnv())))).to.deep.equal(makeOk(makeNumTExp())); + expect(bind(bind(p("x"), parseL5Exp), (exp: Exp) => typeofExp(exp, makeExtendTEnv(["x"], [makeNumTExp()], makeEmptyTEnv())))).toEqual(makeOk(makeNumTExp())); }); it('infers the type of "if" expressions', () => { - expect(inferTypeOf("(if (> 1 2) 1 2)")).to.deep.equal(makeOk("number")); - expect(inferTypeOf("(if (= 1 2) #t #f)")).to.deep.equal(makeOk("boolean")); + expect(inferTypeOf("(if (> 1 2) 1 2)")).toEqual(makeOk("number")); + expect(inferTypeOf("(if (= 1 2) #t #f)")).toEqual(makeOk("boolean")); }); it('infers the type of procedures', () => { - expect(inferTypeOf("(lambda ((x : number)) : number x)")).to.deep.equal(makeOk("(number -> number)")); - expect(inferTypeOf("(lambda ((x : number)) : boolean (> x 1))")).to.deep.equal(makeOk("(number -> boolean)")); - expect(inferTypeOf("(lambda((x : number)) : (number -> number) (lambda((y : number)) : number (* y x)))")).to.deep.equal(makeOk("(number -> (number -> number))")); - expect(inferTypeOf("(lambda((f : (number -> number))) : number (f 2))")).to.deep.equal(makeOk("((number -> number) -> number)")); - expect(inferTypeOf("(lambda((x : number)) : number (let (((y : number) x)) (+ x y)))")).to.deep.equal(makeOk("(number -> number)")); + expect(inferTypeOf("(lambda ((x : number)) : number x)")).toEqual(makeOk("(number -> number)")); + expect(inferTypeOf("(lambda ((x : number)) : boolean (> x 1))")).toEqual(makeOk("(number -> boolean)")); + expect(inferTypeOf("(lambda((x : number)) : (number -> number) (lambda((y : number)) : number (* y x)))")).toEqual(makeOk("(number -> (number -> number))")); + expect(inferTypeOf("(lambda((f : (number -> number))) : number (f 2))")).toEqual(makeOk("((number -> number) -> number)")); + expect(inferTypeOf("(lambda((x : number)) : number (let (((y : number) x)) (+ x y)))")).toEqual(makeOk("(number -> number)")); }); it('infers the type of "let" expressions', () => { - expect(inferTypeOf("(let (((x : number) 1)) (* x 2))")).to.deep.equal(makeOk("number")); + expect(inferTypeOf("(let (((x : number) 1)) (* x 2))")).toEqual(makeOk("number")); expect(inferTypeOf(`(let (((x : number) 1) ((y : number) 2)) - (lambda((a : number)) : number (+ (* x a) y)))`)).to.deep.equal(makeOk("(number -> number)")); + (lambda((a : number)) : number (+ (* x a) y)))`)).toEqual(makeOk("(number -> number)")); }); it('infers the type of "letrec" expressions', () => { - expect(inferTypeOf("(letrec (((p1 : (number -> number)) (lambda((x : number)) : number (* x x)))) p1)")).to.deep.equal(makeOk("(number -> number)")); - expect(inferTypeOf("(letrec (((p1 : (number -> number)) (lambda((x : number)) : number (* x x)))) (p1 2))")).to.deep.equal(makeOk("number")); + expect(inferTypeOf("(letrec (((p1 : (number -> number)) (lambda((x : number)) : number (* x x)))) p1)")).toEqual(makeOk("(number -> number)")); + expect(inferTypeOf("(letrec (((p1 : (number -> number)) (lambda((x : number)) : number (* x x)))) (p1 2))")).toEqual(makeOk("number")); expect(inferTypeOf(`(letrec (((odd? : (number -> boolean)) (lambda((n : number)) : boolean (if (= n 0) #f (even? (- n 1))))) ((even? : (number -> boolean)) (lambda((n : number)) : boolean (if (= n 0) #t (odd? (- n 1)))))) - (odd? 12))`)).to.deep.equal(makeOk("boolean")); + (odd? 12))`)).toEqual(makeOk("boolean")); }); it('infers the type of "define" expressions as "void"', () => { - expect(inferTypeOf("(define (foo : number) 5)")).to.deep.equal(makeOk("void")); - expect(inferTypeOf("(define (foo : (number * number -> number)) (lambda((x : number) (y : number)) : number (+ x y)))")).to.deep.equal(makeOk("void")); - expect(inferTypeOf("(define (x : (Empty -> number)) (lambda () : number 1))")).to.deep.equal(makeOk("void")); - expect(inferTypeOf(`(define (x : (T1 -> (T1 -> number))) (lambda ((x : T1)) : (T1 -> number) (lambda((y : T1)) : number 5)))`)).to.deep.equal(makeOk("void")); + expect(inferTypeOf("(define (foo : number) 5)")).toEqual(makeOk("void")); + expect(inferTypeOf("(define (foo : (number * number -> number)) (lambda((x : number) (y : number)) : number (+ x y)))")).toEqual(makeOk("void")); + expect(inferTypeOf("(define (x : (Empty -> number)) (lambda () : number 1))")).toEqual(makeOk("void")); + expect(inferTypeOf(`(define (x : (T1 -> (T1 -> number))) (lambda ((x : T1)) : (T1 -> number) (lambda((y : T1)) : number 5)))`)).toEqual(makeOk("void")); }); it('infers the type of polymorphic functions', () => { - expect(inferTypeOf("(lambda((x : T1)) : T1 x)")).to.deep.equal(makeOk("(T1 -> T1)")); + expect(inferTypeOf("(lambda((x : T1)) : T1 x)")).toEqual(makeOk("(T1 -> T1)")); expect(inferTypeOf(`(let (((x : number) 1)) (lambda((y : T) (z : T)) : T - (if (> x 2) y z)))`)).to.deep.equal(makeOk("(T * T -> T)")); + (if (> x 2) y z)))`)).toEqual(makeOk("(T * T -> T)")); }); it('infers the type of parameter-less procedures', () => { - expect(inferTypeOf("(lambda () : number 1)")).to.deep.equal(makeOk("(Empty -> number)")); + expect(inferTypeOf("(lambda () : number 1)")).toEqual(makeOk("(Empty -> number)")); }); }); describe('typeOfExp', () => { it('infers return type', () => { - expect(verifyTeOfExprWithInference("(lambda ((x : number)) x)", "(number -> number)")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithInference("(lambda ((x : number)) x)", "(number -> number)")).toEqual(makeOk(true)); }); it('infers parameter type', () => { - expect(verifyTeOfExprWithInference('(lambda (x) : number x)', "(number -> number)")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithInference('(lambda (x) : number x)', "(number -> number)")).toEqual(makeOk(true)); }); it('infers both parameter and return types', () => { - expect(verifyTeOfExprWithInference('(lambda (x) (> x 1))', "(number -> boolean)")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithInference('(lambda (x) (lambda (y) (* x y)))', "(number -> (number -> number))")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithInference('(let ((x 1)) (* x 2))', "number")).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithInference('(lambda (x) (> x 1))', "(number -> boolean)")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithInference('(lambda (x) (lambda (y) (* x y)))', "(number -> (number -> number))")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithInference('(let ((x 1)) (* x 2))', "number")).toEqual(makeOk(true)); expect(verifyTeOfExprWithInference(` (let ((x 1) (y 2)) - (lambda (a) (+ (* x a) y)))`, "(number -> number)")).to.deep.equal(makeOk(true)); + (lambda (a) (+ (* x a) y)))`, "(number -> number)")).toEqual(makeOk(true)); expect(verifyTeOfExprWithInference(` (lambda (x) - (let ((y x)) (+ x y)))`, "(number -> number)")).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithInference('(letrec ((p1 (lambda (x) (* x x)))) p1)', '(number -> number)')).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithInference('(letrec ((p1 (lambda (x) (* x x)))) (p1 2))', 'number')).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithInference('(lambda () 1)', "(Empty -> number)")).to.deep.equal(makeOk(true)); + (let ((y x)) (+ x y)))`, "(number -> number)")).toEqual(makeOk(true)); + expect(verifyTeOfExprWithInference('(letrec ((p1 (lambda (x) (* x x)))) p1)', '(number -> number)')).toEqual(makeOk(true)); + expect(verifyTeOfExprWithInference('(letrec ((p1 (lambda (x) (* x x)))) (p1 2))', 'number')).toEqual(makeOk(true)); + expect(verifyTeOfExprWithInference('(lambda () 1)', "(Empty -> number)")).toEqual(makeOk(true)); expect(verifyTeOfExprWithInference(` (letrec ((odd? (lambda (n) (if (= n 0) #f (even? (- n 1))))) (even? (lambda (n) (if (= n 0) #t (odd? (- n 1)))))) - (odd? 12))`, 'boolean')).to.deep.equal(makeOk(true)); + (odd? 12))`, 'boolean')).toEqual(makeOk(true)); }); it('infers unannotated polymorphic functions', () => { - expect(verifyTeOfExprWithInference(`(lambda (x) x)`, '(T1 -> T1)')).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithInference(`(lambda (f) (f 2))`, '((number -> T) -> T)')).to.deep.equal(makeOk(true)); - expect(verifyTeOfExprWithInference(`(let ((x 1)) (lambda (y z) (if (> x 2) y z)))`, '(T * T -> T)')).to.deep.equal(makeOk(true)); + expect(verifyTeOfExprWithInference(`(lambda (x) x)`, '(T1 -> T1)')).toEqual(makeOk(true)); + expect(verifyTeOfExprWithInference(`(lambda (f) (f 2))`, '((number -> T) -> T)')).toEqual(makeOk(true)); + expect(verifyTeOfExprWithInference(`(let ((x 1)) (lambda (y z) (if (> x 2) y z)))`, '(T * T -> T)')).toEqual(makeOk(true)); }); it('returns an error when the generic type should take two concrete types', () => { expect(verifyTeOfExprWithInference(` (letrec ((id (lambda (x) x))) - (if (id #t) (id 1) (id 2)))`, "Error")).to.satisfy(isFailure); + (if (id #t) (id 1) (id 2)))`, "Error")).toSatisfy(isFailure); }); }); }); diff --git a/test/cps/L6-eval.test.ts b/test/cps/L6-eval.test.ts index fe9096d..616be2f 100644 --- a/test/cps/L6-eval.test.ts +++ b/test/cps/L6-eval.test.ts @@ -1,4 +1,3 @@ -import { expect } from "chai"; import { isVarDecl, isVarRef, parseL5 } from '../../src/L5/L5-ast'; import { makeEmptySExp, makeSymbolSExp } from '../../src/L5/L5-value'; import { isClosure, makeCompoundSExp } from '../../src/L5/L5-value'; @@ -7,128 +6,128 @@ import { makeOk, bind, isOkT } from "../../src/shared/result"; describe('L6 Eval', () => { it('evaluates data type literals', () => { - expect(evalParse("1")).to.deep.equal(makeOk(1)); - expect(evalParse("#t")).to.deep.equal(makeOk(true)); - expect(evalParse("#f")).to.deep.equal(makeOk(false)); - expect(evalParse("'a")).to.deep.equal(makeOk(makeSymbolSExp("a"))); - expect(evalParse('"a"')).to.deep.equal(makeOk("a")); - expect(evalParse("'()")).to.deep.equal(makeOk(makeEmptySExp())); - expect(evalParse("'(1 2)")).to.deep.equal(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); + expect(evalParse("1")).toEqual(makeOk(1)); + expect(evalParse("#t")).toEqual(makeOk(true)); + expect(evalParse("#f")).toEqual(makeOk(false)); + expect(evalParse("'a")).toEqual(makeOk(makeSymbolSExp("a"))); + expect(evalParse('"a"')).toEqual(makeOk("a")); + expect(evalParse("'()")).toEqual(makeOk(makeEmptySExp())); + expect(evalParse("'(1 2)")).toEqual(makeOk(makeCompoundSExp(1, makeCompoundSExp(2, makeEmptySExp())))); }); describe('Primitive Procedures', () => { it('evaluates "+"', () => { - expect(evalParse("(+ 1 2)")).to.deep.equal(makeOk(3)); + expect(evalParse("(+ 1 2)")).toEqual(makeOk(3)); }); it('evaluates "-"', () => { - expect(evalParse("(- 2 1)")).to.deep.equal(makeOk(1)); + expect(evalParse("(- 2 1)")).toEqual(makeOk(1)); }); it('evaluates "*"', () => { - expect(evalParse("(* 2 3)")).to.deep.equal(makeOk(6)); + expect(evalParse("(* 2 3)")).toEqual(makeOk(6)); }); it('evaluates "/"', () => { - expect(evalParse("(/ 4 2)")).to.deep.equal(makeOk(2)); + expect(evalParse("(/ 4 2)")).toEqual(makeOk(2)); }); it('evaluates "<"', () => { - expect(evalParse("(< 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(< 4 2)")).toEqual(makeOk(false)); }); it('evaluates ">"', () => { - expect(evalParse("(> 4 2)")).to.deep.equal(makeOk(true)); + expect(evalParse("(> 4 2)")).toEqual(makeOk(true)); }); it('evaluates "="', () => { - expect(evalParse("(= 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(= 4 2)")).toEqual(makeOk(false)); }); it('evaluates "not"', () => { - expect(evalParse("(not #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(not #t)")).toEqual(makeOk(false)); }); it('evaluates "eq?"', () => { - expect(evalParse("(eq? 'a 'a)")).to.deep.equal(makeOk(true)); + expect(evalParse("(eq? 'a 'a)")).toEqual(makeOk(true)); }); it('evaluates "string=?"', () => { - expect(evalParse('(string=? "a" "a")')).to.deep.equal(makeOk(true)); + expect(evalParse('(string=? "a" "a")')).toEqual(makeOk(true)); }); it('evaluates "cons"', () => { - expect(evalParse("(cons 1 '())")).to.deep.equal(makeOk(makeCompoundSExp(1, makeEmptySExp()))); + expect(evalParse("(cons 1 '())")).toEqual(makeOk(makeCompoundSExp(1, makeEmptySExp()))); }); it('evaluates "car"', () => { - expect(evalParse("(car '(1 2))")).to.deep.equal(makeOk(1)); + expect(evalParse("(car '(1 2))")).toEqual(makeOk(1)); }); it('evaluates "cdr"', () => { - expect(evalParse("(cdr '(1 2))")).to.deep.equal(makeOk(makeCompoundSExp(2, makeEmptySExp()))); - expect(evalParse("(cdr '(1))")).to.deep.equal(makeOk(makeEmptySExp())); + expect(evalParse("(cdr '(1 2))")).toEqual(makeOk(makeCompoundSExp(2, makeEmptySExp()))); + expect(evalParse("(cdr '(1))")).toEqual(makeOk(makeEmptySExp())); }); it('evaluates "list?"', () => { - expect(evalParse("(list? '(1))")).to.deep.equal(makeOk(true)); - expect(evalParse("(list? '())")).to.deep.equal(makeOk(true)); + expect(evalParse("(list? '(1))")).toEqual(makeOk(true)); + expect(evalParse("(list? '())")).toEqual(makeOk(true)); }); it('evaluates "number?"', () => { - expect(evalParse("(number? 1)")).to.deep.equal(makeOk(true)); - expect(evalParse("(number? #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(number? 1)")).toEqual(makeOk(true)); + expect(evalParse("(number? #t)")).toEqual(makeOk(false)); }); it('evaluates "boolean?"', () => { - expect(evalParse("(boolean? #t)")).to.deep.equal(makeOk(true)); - expect(evalParse("(boolean? 0)")).to.deep.equal(makeOk(false)); + expect(evalParse("(boolean? #t)")).toEqual(makeOk(true)); + expect(evalParse("(boolean? 0)")).toEqual(makeOk(false)); }); it('evaluates "symbol?"', () => { - expect(evalParse("(symbol? 'a)")).to.deep.equal(makeOk(true)); - expect(evalParse('(symbol? "a")')).to.deep.equal(makeOk(false)); + expect(evalParse("(symbol? 'a)")).toEqual(makeOk(true)); + expect(evalParse('(symbol? "a")')).toEqual(makeOk(false)); }); it('evaluates "string?"', () => { - expect(evalParse("(string? 'a)")).to.deep.equal(makeOk(false)); - expect(evalParse('(string? "a")')).to.deep.equal(makeOk(true)); + expect(evalParse("(string? 'a)")).toEqual(makeOk(false)); + expect(evalParse('(string? "a")')).toEqual(makeOk(true)); }); }); it('evalautes "define" expressions', () => { - expect(bind(parseL5("(L5 (define x 1) (+ x x))"), evalProgram)).to.deep.equal(makeOk(2)); - expect(bind(parseL5("(L5 (define x 1) (define y (+ x x)) (* y y))"), evalProgram)).to.deep.equal(makeOk(4)); + expect(bind(parseL5("(L5 (define x 1) (+ x x))"), evalProgram)).toEqual(makeOk(2)); + expect(bind(parseL5("(L5 (define x 1) (define y (+ x x)) (* y y))"), evalProgram)).toEqual(makeOk(4)); }); it('evaluates "if" expressions', () => { - expect(evalParse('(if (string? "a") 1 2)')).to.deep.equal(makeOk(1)); - expect(evalParse('(if (not (string? "a")) 1 2)')).to.deep.equal(makeOk(2)); + expect(evalParse('(if (string? "a") 1 2)')).toEqual(makeOk(1)); + expect(evalParse('(if (not (string? "a")) 1 2)')).toEqual(makeOk(2)); }); it('evaluates procedures', () => { const closure = evalParse("(lambda (x) x)"); - expect(closure).to.satisfy(isOkT(isClosure)); + expect(closure).toSatisfy(isOkT(isClosure)); if (isOkT(isClosure)(closure)) { - expect(closure.value.params[0]).to.satisfy(isVarDecl); - expect(closure.value.body[0]).to.satisfy(isVarRef); + expect(closure.value.params[0]).toSatisfy(isVarDecl); + expect(closure.value.body[0]).toSatisfy(isVarRef); } }); it('applies procedures', () => { - expect(evalParse("((lambda (x) (* x x)) 2)")).to.deep.equal(makeOk(4)); - expect(bind(parseL5("(L5 (define square (lambda (x) (* x x))) (square 3))"), evalProgram)).to.deep.equal(makeOk(9)); - expect(bind(parseL5("(L5 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))"), evalProgram)).to.deep.equal(makeOk(3)); + expect(evalParse("((lambda (x) (* x x)) 2)")).toEqual(makeOk(4)); + expect(bind(parseL5("(L5 (define square (lambda (x) (* x x))) (square 3))"), evalProgram)).toEqual(makeOk(9)); + expect(bind(parseL5("(L5 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))"), evalProgram)).toEqual(makeOk(3)); }); it('evaluates recursive procedures', () => { - expect(bind(parseL5("(L5 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))"), evalProgram)).to.deep.equal(makeOk(6)); + expect(bind(parseL5("(L5 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))"), evalProgram)).toEqual(makeOk(6)); }); it('evaluates recursion with "letrec"', () => { expect(evalParse(` (letrec ((f (lambda (n) (if (= n 0) 1 (* n (f (- n 1))))))) - (f 5))`)).to.deep.equal(makeOk(120)); + (f 5))`)).toEqual(makeOk(120)); }); it('evaluates the examples', () => { @@ -139,12 +138,12 @@ describe('L6 Eval', () => { 1 (* n (f (- n 1))))))) f)) - (fact 5))`), evalProgram)).to.deep.equal(makeOk(120)); + (fact 5))`), evalProgram)).toEqual(makeOk(120)); // Accidental capture of the z variable if no renaming - works without renaming in env eval. expect(bind(parseL5(` (L5 (define z (lambda (x) (* x x))) - (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalProgram)).to.deep.equal(makeOk(4)); + (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`), evalProgram)).toEqual(makeOk(4)); // Y-combinator expect(bind(parseL5(` @@ -153,7 +152,7 @@ describe('L6 Eval', () => { (lambda (n) (if (= n 0) 1 - (* n ((fact fact) (- n 1))))))) 6))`), evalProgram)).to.deep.equal(makeOk(720)); + (* n ((fact fact) (- n 1))))))) 6))`), evalProgram)).toEqual(makeOk(720)); }); it('evaluates higher-order functions', () => { @@ -162,7 +161,7 @@ describe('L6 Eval', () => { (if (eq? l '()) l (cons (f (car l)) (map f (cdr l)))))) - (map (lambda (x) (* x x)) '(1 2 3)))`), evalProgram)).to.deep.equal(evalParse("'(1 4 9)")); + (map (lambda (x) (* x x)) '(1 2 3)))`), evalProgram)).toEqual(evalParse("'(1 4 9)")); expect(bind(parseL5(` (L5 (define empty? (lambda (x) (eq? x '()))) @@ -172,11 +171,11 @@ describe('L6 Eval', () => { (if (pred (car l)) (cons (car l) (filter pred (cdr l))) (filter pred (cdr l)))))) - (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalProgram)).to.deep.equal(evalParse("'(1 3)")); + (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`), evalProgram)).toEqual(evalParse("'(1 3)")); expect(bind(parseL5(` (L5 (define compose (lambda (f g) (lambda (x) (f (g x))))) - ((compose not number?) 2))`), evalProgram)).to.deep.equal(makeOk(false)); + ((compose not number?) 2))`), evalProgram)).toEqual(makeOk(false)); }); it('properly captures variables in closures', () => { @@ -184,21 +183,21 @@ describe('L6 Eval', () => { (L5 (define makeAdder (lambda (n) (lambda (y) (+ y n)))) (define a6 (makeAdder 6)) (define a7 (makeAdder 7)) - (+ (a6 1) (a7 1)))`), evalProgram)).to.deep.equal(makeOk(15)); - expect(bind(parseL5("(L5 (define f (lambda () 1)) (f))"), evalProgram)).to.deep.equal(makeOk(1)); + (+ (a6 1) (a7 1)))`), evalProgram)).toEqual(makeOk(15)); + expect(bind(parseL5("(L5 (define f (lambda () 1)) (f))"), evalProgram)).toEqual(makeOk(1)); expect(bind(parseL5(` (L5 (define makeCounter (lambda () (let ((c 0)) (lambda () (set! c (+ c 1)) c)))) (define c1 (makeCounter)) (define c2 (makeCounter)) - (+ (+ (c1) (c1)) (+ (c2) (c2))))`), evalProgram)).to.deep.equal(makeOk(6)); + (+ (+ (c1) (c1)) (+ (c2) (c2))))`), evalProgram)).toEqual(makeOk(6)); }); it('evaluates type-annotated expressions', () => { - expect(bind(parseL5("(L5 (define (a : number) 1) a)"), evalProgram)).to.deep.equal(makeOk(1)); - expect(evalParse("((lambda ((x : T)) : T x) #t)")).to.deep.equal(makeOk(true)); - expect(evalParse("(let (((a : boolean) #t) ((b : number) 2)) (if a b (+ b b)))")).to.deep.equal(makeOk(2)); + expect(bind(parseL5("(L5 (define (a : number) 1) a)"), evalProgram)).toEqual(makeOk(1)); + expect(evalParse("((lambda ((x : T)) : T x) #t)")).toEqual(makeOk(true)); + expect(evalParse("(let (((a : boolean) #t) ((b : number) 2)) (if a b (+ b b)))")).toEqual(makeOk(2)); expect(evalParse(` (letrec (((p : (number * number -> number)) (lambda ((x : number) (y : number)) (+ x y)))) - (p 1 2))`)).to.deep.equal(makeOk(3)); + (p 1 2))`)).toEqual(makeOk(3)); }); }); diff --git a/test/cps/L7.test.ts b/test/cps/L7.test.ts index 7c35a6f..a999945 100644 --- a/test/cps/L7.test.ts +++ b/test/cps/L7.test.ts @@ -1,4 +1,3 @@ -import { expect } from "chai"; import { parseL5, isVarDecl, isVarRef } from '../../src/L5/L5-ast'; import { makeEmptySExp, makeSymbolSExp, Value } from '../../src/L5/L5-value'; import { isClosure, makeCompoundSExp } from '../../src/L5/L5-value'; @@ -10,128 +9,128 @@ const evalP = (x: string): Result => describe('L7 Eval', () => { it('evaluates data type literals', () => { - expect(evalParse("1")).to.deep.equal(makeOk(1)); - expect(evalParse("#t")).to.deep.equal(makeOk(true)); - expect(evalParse("#f")).to.deep.equal(makeOk(false)); - expect(evalParse("'a")).to.deep.equal(makeOk(makeSymbolSExp("a"))); - expect(evalParse('"a"')).to.deep.equal(makeOk("a")); - expect(evalParse("'()")).to.deep.equal(makeOk(makeEmptySExp())); - expect(evalParse("'(1)")).to.deep.equal(makeOk(makeCompoundSExp(1, makeEmptySExp()))); + expect(evalParse("1")).toEqual(makeOk(1)); + expect(evalParse("#t")).toEqual(makeOk(true)); + expect(evalParse("#f")).toEqual(makeOk(false)); + expect(evalParse("'a")).toEqual(makeOk(makeSymbolSExp("a"))); + expect(evalParse('"a"')).toEqual(makeOk("a")); + expect(evalParse("'()")).toEqual(makeOk(makeEmptySExp())); + expect(evalParse("'(1)")).toEqual(makeOk(makeCompoundSExp(1, makeEmptySExp()))); }); describe('Primitive Procedures', () => { it('evaluates "+"', () => { - expect(evalParse("(+ 1 2)")).to.deep.equal(makeOk(3)); + expect(evalParse("(+ 1 2)")).toEqual(makeOk(3)); }); it('evaluates "-"', () => { - expect(evalParse("(- 2 1)")).to.deep.equal(makeOk(1)); + expect(evalParse("(- 2 1)")).toEqual(makeOk(1)); }); it('evaluates "*"', () => { - expect(evalParse("(* 2 3)")).to.deep.equal(makeOk(6)); + expect(evalParse("(* 2 3)")).toEqual(makeOk(6)); }); it('evaluates "/"', () => { - expect(evalParse("(/ 4 2)")).to.deep.equal(makeOk(2)); + expect(evalParse("(/ 4 2)")).toEqual(makeOk(2)); }); it('evaluates "<"', () => { - expect(evalParse("(< 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(< 4 2)")).toEqual(makeOk(false)); }); it('evaluates ">"', () => { - expect(evalParse("(> 4 2)")).to.deep.equal(makeOk(true)); + expect(evalParse("(> 4 2)")).toEqual(makeOk(true)); }); it('evaluates "="', () => { - expect(evalParse("(= 4 2)")).to.deep.equal(makeOk(false)); + expect(evalParse("(= 4 2)")).toEqual(makeOk(false)); }); it('evaluates "not"', () => { - expect(evalParse("(not #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(not #t)")).toEqual(makeOk(false)); }); it('evaluates "eq?"', () => { - expect(evalParse("(eq? 'a 'a)")).to.deep.equal(makeOk(true)); + expect(evalParse("(eq? 'a 'a)")).toEqual(makeOk(true)); }); it('evaluates "string=?"', () => { - expect(evalParse('(string=? "a" "a")')).to.deep.equal(makeOk(true)); + expect(evalParse('(string=? "a" "a")')).toEqual(makeOk(true)); }); it('evaluates "cons"', () => { - expect(evalParse("(cons 1 '())")).to.deep.equal(makeOk(makeCompoundSExp(1, makeEmptySExp()))); + expect(evalParse("(cons 1 '())")).toEqual(makeOk(makeCompoundSExp(1, makeEmptySExp()))); }); it('evaluates "car"', () => { - expect(evalParse("(car '(1 2))")).to.deep.equal(makeOk(1)); + expect(evalParse("(car '(1 2))")).toEqual(makeOk(1)); }); it('evaluates "cdr"', () => { - expect(evalParse("(cdr '(1 2))")).to.deep.equal(makeOk(makeCompoundSExp(2, makeEmptySExp()))); - expect(evalParse("(cdr '(1))")).to.deep.equal(makeOk(makeEmptySExp())); + expect(evalParse("(cdr '(1 2))")).toEqual(makeOk(makeCompoundSExp(2, makeEmptySExp()))); + expect(evalParse("(cdr '(1))")).toEqual(makeOk(makeEmptySExp())); }); it('evaluates "list?"', () => { - expect(evalParse("(list? '(1))")).to.deep.equal(makeOk(true)); - expect(evalParse("(list? '())")).to.deep.equal(makeOk(true)); + expect(evalParse("(list? '(1))")).toEqual(makeOk(true)); + expect(evalParse("(list? '())")).toEqual(makeOk(true)); }); it('evaluates "number?"', () => { - expect(evalParse("(number? 1)")).to.deep.equal(makeOk(true)); - expect(evalParse("(number? #t)")).to.deep.equal(makeOk(false)); + expect(evalParse("(number? 1)")).toEqual(makeOk(true)); + expect(evalParse("(number? #t)")).toEqual(makeOk(false)); }); it('evaluates "boolean?"', () => { - expect(evalParse("(boolean? #t)")).to.deep.equal(makeOk(true)); - expect(evalParse("(boolean? 0)")).to.deep.equal(makeOk(false)); + expect(evalParse("(boolean? #t)")).toEqual(makeOk(true)); + expect(evalParse("(boolean? 0)")).toEqual(makeOk(false)); }); it('evaluates "symbol?"', () => { - expect(evalParse("(symbol? 'a)")).to.deep.equal(makeOk(true)); - expect(evalParse('(symbol? "a")')).to.deep.equal(makeOk(false)); + expect(evalParse("(symbol? 'a)")).toEqual(makeOk(true)); + expect(evalParse('(symbol? "a")')).toEqual(makeOk(false)); }); it('evaluates "string?"', () => { - expect(evalParse("(string? 'a)")).to.deep.equal(makeOk(false)); - expect(evalParse('(string? "a")')).to.deep.equal(makeOk(true)); + expect(evalParse("(string? 'a)")).toEqual(makeOk(false)); + expect(evalParse('(string? "a")')).toEqual(makeOk(true)); }); }); it('evalautes "define" expressions', () => { - expect(evalP("(L5 (define x 1) (+ x x))")).to.deep.equal(makeOk(2)); - expect(evalP("(L5 (define x 1) (define y (+ x x)) (* y y))")).to.deep.equal(makeOk(4)); + expect(evalP("(L5 (define x 1) (+ x x))")).toEqual(makeOk(2)); + expect(evalP("(L5 (define x 1) (define y (+ x x)) (* y y))")).toEqual(makeOk(4)); }); it('evaluates "if" expressions', () => { - expect(evalParse('(if (string? "a") 1 2)')).to.deep.equal(makeOk(1)); - expect(evalParse('(if (not (string? "a")) 1 2)')).to.deep.equal(makeOk(2)); + expect(evalParse('(if (string? "a") 1 2)')).toEqual(makeOk(1)); + expect(evalParse('(if (not (string? "a")) 1 2)')).toEqual(makeOk(2)); }); it('evaluates procedures', () => { let closure = evalParse("(lambda (x) x)"); - expect(closure).to.satisfy(isOkT(isClosure)); + expect(closure).toSatisfy(isOkT(isClosure)); if (isOkT(isClosure)(closure)) { - expect(closure.value.params[0]).to.satisfy(isVarDecl); - expect(closure.value.body[0]).to.satisfy(isVarRef); + expect(closure.value.params[0]).toSatisfy(isVarDecl); + expect(closure.value.body[0]).toSatisfy(isVarRef); } }); it('applies procedures', () => { - expect(evalParse("((lambda (x) (* x x)) 2)")).to.deep.equal(makeOk(4)); - expect(evalP("(L5 (define square (lambda (x) (* x x))) (square 3))")).to.deep.equal(makeOk(9)); - expect(evalP("(L5 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))")).to.deep.equal(makeOk(3)); + expect(evalParse("((lambda (x) (* x x)) 2)")).toEqual(makeOk(4)); + expect(evalP("(L5 (define square (lambda (x) (* x x))) (square 3))")).toEqual(makeOk(9)); + expect(evalP("(L5 (define f (lambda (x) (if (> x 0) x (- 0 x)))) (f -3))")).toEqual(makeOk(3)); }); it('evaluates recursive procedures', () => { - expect(evalP("(L5 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))")).to.deep.equal(makeOk(6)); + expect(evalP("(L5 (define f (lambda (x) (if (= x 0) 1 (* x (f (- x 1)))))) (f 3))")).toEqual(makeOk(6)); }); it('evaluates recursion with "letrec"', () => { expect(evalParse(` (letrec ((f (lambda (n) (if (= n 0) 1 (* n (f (- n 1))))))) - (f 5))`)).to.deep.equal(makeOk(120)); + (f 5))`)).toEqual(makeOk(120)); }); it('evaluates the examples', () => { @@ -142,12 +141,12 @@ describe('L7 Eval', () => { 1 (* n (f (- n 1))))))) f)) - (fact 5))`)).to.deep.equal(makeOk(120)); + (fact 5))`)).toEqual(makeOk(120)); // Accidental capture of the z variable if no renaming - works without renaming in env eval. expect(evalP(` (L5 (define z (lambda (x) (* x x))) - (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`)).to.deep.equal(makeOk(4)); + (((lambda (x) (lambda (z) (x z))) (lambda (w) (z w))) 2))`)).toEqual(makeOk(4)); // Y-combinator expect(evalP(` @@ -156,7 +155,7 @@ describe('L7 Eval', () => { (lambda (n) (if (= n 0) 1 - (* n ((fact fact) (- n 1))))))) 6))`)).to.deep.equal(makeOk(720)); + (* n ((fact fact) (- n 1))))))) 6))`)).toEqual(makeOk(720)); }); it('evaluates higher-order functions', () => { @@ -165,7 +164,7 @@ describe('L7 Eval', () => { (if (eq? l '()) l (cons (f (car l)) (map f (cdr l)))))) - (map (lambda (x) (* x x)) '(1 2 3)))`)).to.deep.equal(evalParse("'(1 4 9)")); + (map (lambda (x) (* x x)) '(1 2 3)))`)).toEqual(evalParse("'(1 4 9)")); expect(evalP(` (L5 (define empty? (lambda (x) (eq? x '()))) @@ -175,11 +174,11 @@ describe('L7 Eval', () => { (if (pred (car l)) (cons (car l) (filter pred (cdr l))) (filter pred (cdr l)))))) - (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`)).to.deep.equal(evalParse("'(1 3)")); + (filter (lambda (x) (not (= x 2))) '(1 2 3 2)))`)).toEqual(evalParse("'(1 3)")); expect(evalP(` (L5 (define compose (lambda (f g) (lambda (x) (f (g x))))) - ((compose not number?) 2))`)).to.deep.equal(makeOk(false)); + ((compose not number?) 2))`)).toEqual(makeOk(false)); }); it('properly captures variables in closures', () => { @@ -187,22 +186,22 @@ describe('L7 Eval', () => { (L5 (define makeAdder (lambda (n) (lambda (y) (+ y n)))) (define a6 (makeAdder 6)) (define a7 (makeAdder 7)) - (+ (a6 1) (a7 1)))`)).to.deep.equal(makeOk(15)); + (+ (a6 1) (a7 1)))`)).toEqual(makeOk(15)); expect(evalP(` (L5 (define makeCounter (lambda () (let ((c 0)) (lambda () (set! c (+ c 1)) c)))) (define c1 (makeCounter)) (define c2 (makeCounter)) - (+ (+ (c1) (c1)) (+ (c2) (c2))))`)).to.deep.equal(makeOk(6)); + (+ (+ (c1) (c1)) (+ (c2) (c2))))`)).toEqual(makeOk(6)); }); it('evaluates type-annotated expressions', () => { - expect(evalP("(L5 (define (a : number) 1) a)")).to.deep.equal(makeOk(1)); - expect(evalParse("((lambda ((x : T)) : T x) #t)")).to.deep.equal(makeOk(true)); - expect(evalParse("(let (((a : boolean) #t) ((b : number) 2)) (if a b (+ b b)))")).to.deep.equal(makeOk(2)); + expect(evalP("(L5 (define (a : number) 1) a)")).toEqual(makeOk(1)); + expect(evalParse("((lambda ((x : T)) : T x) #t)")).toEqual(makeOk(true)); + expect(evalParse("(let (((a : boolean) #t) ((b : number) 2)) (if a b (+ b b)))")).toEqual(makeOk(2)); expect(evalParse(` (letrec (((p : (number * number -> number)) (lambda ((x : number) (y : number)) (+ x y)))) - (p 1 2))`)).to.deep.equal(makeOk(3)); + (p 1 2))`)).toEqual(makeOk(3)); }); it('evaluates CPS functions iteratively', () => { @@ -212,6 +211,6 @@ describe('L7 Eval', () => { (if (= n 0) (cont 0) (sumCPS (- n 1) (lambda (sn1) (cont (+ n sn1))))))) - (sumCPS 1000 (lambda (x) x)))`)).to.deep.equal(makeOk(500500)); + (sumCPS 1000 (lambda (x) x)))`)).toEqual(makeOk(500500)); }); });