├── .gitignore ├── .mocharc.json ├── .npmignore ├── .prettierrc ├── .travis.yml ├── LICENSE ├── README.md ├── package-lock.json ├── package.json ├── src └── index.ts ├── tests ├── fixtures │ └── specs │ │ ├── attachment.ts │ │ ├── baseTest.ts │ │ ├── description.ts │ │ ├── epic.ts │ │ ├── feature.ts │ │ ├── issueAndTms.ts │ │ ├── missingAllure.ts │ │ ├── owner.ts │ │ ├── severity.ts │ │ ├── step.ts │ │ ├── story.ts │ │ ├── tag.ts │ │ └── testData.ts ├── model │ └── User.ts ├── specs │ ├── attachment.ts │ ├── description.ts │ ├── epic.ts │ ├── feature.ts │ ├── issueAndTms.ts │ ├── missingAllure.ts │ ├── owner.ts │ ├── severity.ts │ ├── step.ts │ ├── story.ts │ ├── tag.ts │ └── testData.ts ├── tsconfig.json ├── tslint.json └── utils │ └── index.ts ├── tsconfig.json └── tslint.json /.gitignore: -------------------------------------------------------------------------------- 1 | .allure-report 2 | allure-results 3 | node_modules 4 | dist 5 | *.js 6 | *.tgz 7 | .DS_Store 8 | .idea 9 | .nyc_output 10 | package 11 | coverage 12 | *.log 13 | *.d.ts 14 | /**/*.tgz 15 | -------------------------------------------------------------------------------- /.mocharc.json: -------------------------------------------------------------------------------- 1 | { 2 | "require": [ 3 | "tsconfig-paths/register", 4 | "ts-node/register" 5 | ], 6 | "timeout": 5000, 7 | "spec": "./tests/specs/*.ts" 8 | } 9 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | .allure-report 2 | allure-results 3 | node_modules/ 4 | tests 5 | src 6 | *.js 7 | *.tgz 8 | .DS_Store 9 | .idea/ 10 | .nyc_output 11 | package 12 | coverage 13 | *.log 14 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "singleQuote": true, 3 | "useTabs": false, 4 | "tabWidth": 2, 5 | "semi": false, 6 | "bracketSpacing": true, 7 | "printWidth": 120 8 | } 9 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - "13" 4 | script: 5 | npm test 6 | after_success: 7 | npm run coverage 8 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Apache License 2 | Version 2.0, January 2004 3 | http://www.apache.org/licenses/ 4 | 5 | TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 6 | 7 | 1. Definitions. 8 | 9 | "License" shall mean the terms and conditions for use, reproduction, 10 | and distribution as defined by Sections 1 through 9 of this document. 11 | 12 | "Licensor" shall mean the copyright owner or entity authorized by 13 | the copyright owner that is granting the License. 14 | 15 | "Legal Entity" shall mean the union of the acting entity and all 16 | other entities that control, are controlled by, or are under common 17 | control with that entity. For the purposes of this definition, 18 | "control" means (i) the power, direct or indirect, to cause the 19 | direction or management of such entity, whether by contract or 20 | otherwise, or (ii) ownership of fifty percent (50%) or more of the 21 | outstanding shares, or (iii) beneficial ownership of such entity. 22 | 23 | "You" (or "Your") shall mean an individual or Legal Entity 24 | exercising permissions granted by this License. 25 | 26 | "Source" form shall mean the preferred form for making modifications, 27 | including but not limited to software source code, documentation 28 | source, and configuration files. 29 | 30 | "Object" form shall mean any form resulting from mechanical 31 | transformation or translation of a Source form, including but 32 | not limited to compiled object code, generated documentation, 33 | and conversions to other media types. 34 | 35 | "Work" shall mean the work of authorship, whether in Source or 36 | Object form, made available under the License, as indicated by a 37 | copyright notice that is included in or attached to the work 38 | (an example is provided in the Appendix below). 39 | 40 | "Derivative Works" shall mean any work, whether in Source or Object 41 | form, that is based on (or derived from) the Work and for which the 42 | editorial revisions, annotations, elaborations, or other modifications 43 | represent, as a whole, an original work of authorship. For the purposes 44 | of this License, Derivative Works shall not include works that remain 45 | separable from, or merely link (or bind by name) to the interfaces of, 46 | the Work and Derivative Works thereof. 47 | 48 | "Contribution" shall mean any work of authorship, including 49 | the original version of the Work and any modifications or additions 50 | to that Work or Derivative Works thereof, that is intentionally 51 | submitted to Licensor for inclusion in the Work by the copyright owner 52 | or by an individual or Legal Entity authorized to submit on behalf of 53 | the copyright owner. For the purposes of this definition, "submitted" 54 | means any form of electronic, verbal, or written communication sent 55 | to the Licensor or its representatives, including but not limited to 56 | communication on electronic mailing lists, source code control systems, 57 | and issue tracking systems that are managed by, or on behalf of, the 58 | Licensor for the purpose of discussing and improving the Work, but 59 | excluding communication that is conspicuously marked or otherwise 60 | designated in writing by the copyright owner as "Not a Contribution." 61 | 62 | "Contributor" shall mean Licensor and any individual or Legal Entity 63 | on behalf of whom a Contribution has been received by Licensor and 64 | subsequently incorporated within the Work. 65 | 66 | 2. Grant of Copyright License. Subject to the terms and conditions of 67 | this License, each Contributor hereby grants to You a perpetual, 68 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 69 | copyright license to reproduce, prepare Derivative Works of, 70 | publicly display, publicly perform, sublicense, and distribute the 71 | Work and such Derivative Works in Source or Object form. 72 | 73 | 3. Grant of Patent License. Subject to the terms and conditions of 74 | this License, each Contributor hereby grants to You a perpetual, 75 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 76 | (except as stated in this section) patent license to make, have made, 77 | use, offer to sell, sell, import, and otherwise transfer the Work, 78 | where such license applies only to those patent claims licensable 79 | by such Contributor that are necessarily infringed by their 80 | Contribution(s) alone or by combination of their Contribution(s) 81 | with the Work to which such Contribution(s) was submitted. If You 82 | institute patent litigation against any entity (including a 83 | cross-claim or counterclaim in a lawsuit) alleging that the Work 84 | or a Contribution incorporated within the Work constitutes direct 85 | or contributory patent infringement, then any patent licenses 86 | granted to You under this License for that Work shall terminate 87 | as of the date such litigation is filed. 88 | 89 | 4. Redistribution. You may reproduce and distribute copies of the 90 | Work or Derivative Works thereof in any medium, with or without 91 | modifications, and in Source or Object form, provided that You 92 | meet the following conditions: 93 | 94 | (a) You must give any other recipients of the Work or 95 | Derivative Works a copy of this License; and 96 | 97 | (b) You must cause any modified files to carry prominent notices 98 | stating that You changed the files; and 99 | 100 | (c) You must retain, in the Source form of any Derivative Works 101 | that You distribute, all copyright, patent, trademark, and 102 | attribution notices from the Source form of the Work, 103 | excluding those notices that do not pertain to any part of 104 | the Derivative Works; and 105 | 106 | (d) If the Work includes a "NOTICE" text file as part of its 107 | distribution, then any Derivative Works that You distribute must 108 | include a readable copy of the attribution notices contained 109 | within such NOTICE file, excluding those notices that do not 110 | pertain to any part of the Derivative Works, in at least one 111 | of the following places: within a NOTICE text file distributed 112 | as part of the Derivative Works; within the Source form or 113 | documentation, if provided along with the Derivative Works; or, 114 | within a display generated by the Derivative Works, if and 115 | wherever such third-party notices normally appear. The contents 116 | of the NOTICE file are for informational purposes only and 117 | do not modify the License. You may add Your own attribution 118 | notices within Derivative Works that You distribute, alongside 119 | or as an addendum to the NOTICE text from the Work, provided 120 | that such additional attribution notices cannot be construed 121 | as modifying the License. 122 | 123 | You may add Your own copyright statement to Your modifications and 124 | may provide additional or different license terms and conditions 125 | for use, reproduction, or distribution of Your modifications, or 126 | for any such Derivative Works as a whole, provided Your use, 127 | reproduction, and distribution of the Work otherwise complies with 128 | the conditions stated in this License. 129 | 130 | 5. Submission of Contributions. Unless You explicitly state otherwise, 131 | any Contribution intentionally submitted for inclusion in the Work 132 | by You to the Licensor shall be under the terms and conditions of 133 | this License, without any additional terms or conditions. 134 | Notwithstanding the above, nothing herein shall supersede or modify 135 | the terms of any separate license agreement you may have executed 136 | with Licensor regarding such Contributions. 137 | 138 | 6. Trademarks. This License does not grant permission to use the trade 139 | names, trademarks, service marks, or product names of the Licensor, 140 | except as required for reasonable and customary use in describing the 141 | origin of the Work and reproducing the content of the NOTICE file. 142 | 143 | 7. Disclaimer of Warranty. Unless required by applicable law or 144 | agreed to in writing, Licensor provides the Work (and each 145 | Contributor provides its Contributions) on an "AS IS" BASIS, 146 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or 147 | implied, including, without limitation, any warranties or conditions 148 | of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A 149 | PARTICULAR PURPOSE. You are solely responsible for determining the 150 | appropriateness of using or redistributing the Work and assume any 151 | risks associated with Your exercise of permissions under this License. 152 | 153 | 8. Limitation of Liability. In no event and under no legal theory, 154 | whether in tort (including negligence), contract, or otherwise, 155 | unless required by applicable law (such as deliberate and grossly 156 | negligent acts) or agreed to in writing, shall any Contributor be 157 | liable to You for damages, including any direct, indirect, special, 158 | incidental, or consequential damages of any character arising as a 159 | result of this License or out of the use or inability to use the 160 | Work (including but not limited to damages for loss of goodwill, 161 | work stoppage, computer failure or malfunction, or any and all 162 | other commercial damages or losses), even if such Contributor 163 | has been advised of the possibility of such damages. 164 | 165 | 9. Accepting Warranty or Additional Liability. While redistributing 166 | the Work or Derivative Works thereof, You may choose to offer, 167 | and charge a fee for, acceptance of support, warranty, indemnity, 168 | or other liability obligations and/or rights consistent with this 169 | License. However, in accepting such obligations, You may act only 170 | on Your own behalf and on Your sole responsibility, not on behalf 171 | of any other Contributor, and only if You agree to indemnify, 172 | defend, and hold each Contributor harmless for any liability 173 | incurred by, or claims asserted against, such Contributor by reason 174 | of your accepting any such warranty or additional liability. 175 | 176 | END OF TERMS AND CONDITIONS 177 | 178 | APPENDIX: How to apply the Apache License to your work. 179 | 180 | To apply the Apache License to your work, attach the following 181 | boilerplate notice, with the fields enclosed by brackets "[]" 182 | replaced with your own identifying information. (Don't include 183 | the brackets!) The text should be enclosed in the appropriate 184 | comment syntax for the file format. We also recommend that a 185 | file or class name and description of purpose be included on the 186 | same "printed page" as the copyright notice for easier 187 | identification within third-party archives. 188 | 189 | Copyright [yyyy] [name of copyright owner] 190 | 191 | Licensed under the Apache License, Version 2.0 (the "License"); 192 | you may not use this file except in compliance with the License. 193 | You may obtain a copy of the License at 194 | 195 | http://www.apache.org/licenses/LICENSE-2.0 196 | 197 | Unless required by applicable law or agreed to in writing, software 198 | distributed under the License is distributed on an "AS IS" BASIS, 199 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 200 | See the License for the specific language governing permissions and 201 | limitations under the License. 202 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Test Decorators 2 | 3 | [![Build Status](https://travis-ci.com/sskorol/ts-test-decorators.svg?branch=master)](https://travis-ci.com/sskorol/ts-test-decorators) 4 | [![codecov](https://codecov.io/gh/sskorol/ts-test-decorators/branch/master/graph/badge.svg)](https://codecov.io/gh/sskorol/ts-test-decorators) 5 | [![npm version](https://badge.fury.io/js/ts-test-decorators.svg)](https://badge.fury.io/js/ts-test-decorators) 6 | 7 | **IMPORTANT NOTE**: this functionality is already included into [allure-js](https://github.com/allure-framework/allure-js) as a separate `allure-decorators` module So feel free to check it out if you already have Allure integration. 8 | 9 | This project will help to smoothly migrate from Java to Javascript automation. 10 | 11 | Let's say we have the following test written in Java: 12 | 13 | ```java 14 | public class AuthorizationTests { 15 | 16 | @Issue("42") 17 | @TmsLink("58") 18 | @Feature("Login") 19 | @Story("58") 20 | @Severity(SeverityLevel.BLOCKER) 21 | @Test(dataProvider = "testData") 22 | public void userShouldBeAbleToSignIn(User user) { 23 | open(LoginPage.class) 24 | .loginWith(user) 25 | .select(ProfilePage.class); 26 | 27 | verifyThat(at(ProfilePage.class)) 28 | .fullNameIs(user.getFullName()) 29 | .usernameIs(user.getUsername()); 30 | } 31 | 32 | @DataSupplier 33 | public StreamEx testData() { 34 | return StreamEx.of( 35 | new User('stranger', '123456', 'Strange Person'), 36 | new User('test', '123456', 'Test User') 37 | ); 38 | } 39 | } 40 | ``` 41 | 42 | Everyone in a Java world get used to strict types, classes and annotations. 43 | You may wonder how to achieve the same in JS? 44 | 45 | The answer is using Typescript and decorators. 46 | 47 | [@testdeck/mocha](https://www.npmjs.com/package/@testdeck/mocha) will help us with core features. 48 | However, it has nothing to do with [Allure](https://github.com/allure-framework/allure-js). 49 | Moreover, there's no flexible [DataProvider](https://github.com/sskorol/test-data-supplier) mechanism available. 50 | 51 | This library fills these gaps, so that you can write your tests the following way: 52 | 53 | ```typescript 54 | import { Severity } from "allure2-js-commons" 55 | import { suite, test } from '@testdeck/mocha' 56 | import { 57 | assignPmsUrl, 58 | assignTmsUrl, 59 | decorate, 60 | data, 61 | description, 62 | feature, 63 | issue, 64 | owner, 65 | severity, 66 | story, 67 | tag, 68 | testCaseId 69 | } from 'ts-test-decorators' 70 | import { allure, MochaAllure } from 'allure-mocha/runtime' 71 | 72 | @suite 73 | class AuthorizationTests { 74 | static testData = () => { 75 | return new User('Test', 'User') 76 | } 77 | 78 | before() { 79 | const gitHubUrl: string = 'https://github.com/sskorol/ts-test-decorators/issues' 80 | assignPmsUrl(gitHubUrl) 81 | assignTmsUrl(gitHubUrl) 82 | decorate(allure) 83 | } 84 | 85 | @issue('42') 86 | @testCaseId('58') 87 | @severity(Severity.BLOCKER) 88 | @feature('Login') 89 | @story('58') 90 | @owner('skorol') 91 | @tag('smoke') 92 | @description('Basic authorization test.') 93 | @data(AuthorizationTests.testData) 94 | @data.naming((user: User) => `${user} should be able to sign`) 95 | @test 96 | userShouldBeAbleToSignIn(user: User) { 97 | open(LoginPage) 98 | .loginWith(user) 99 | .select(ProfilePage) 100 | 101 | verifyThat(atProfilePage) 102 | .fullNameIs(user.fullName) 103 | .usernameIs(user.username) 104 | } 105 | } 106 | ``` 107 | ## Installation 108 | 109 | ```bash 110 | npm i ts-test-decorators --save-dev 111 | ``` 112 | or via yarn: 113 | ```bash 114 | yarn add ts-test-decorators --dev 115 | ``` 116 | 117 | As it's an extension to [allure-js](https://github.com/allure-framework/allure-js) and [testdeck](https://www.npmjs.com/package/@testdeck/mocha), you have to install the following dependencies: 118 | 119 | - mocha 120 | - @testdeck/mocha 121 | - allure-mocha 122 | - allure-js-commons 123 | - source-map-support 124 | - typescript 125 | 126 | ## Configuration 127 | 128 | Either add **allure-mocha** into **.mocharc.json**: 129 | 130 | ```json 131 | { 132 | "require": "source-map-support/register", 133 | "reporter": "allure-mocha" 134 | } 135 | ``` 136 | 137 | Or pass the same value via commandline / scripts: 138 | 139 | ```bash 140 | mocha -R allure-mocha 141 | ``` 142 | 143 | **tsconfig.json** may look like the following: 144 | ```json 145 | { 146 | "compilerOptions": { 147 | "target": "es2017", 148 | "module": "commonjs", 149 | "inlineSourceMap": true, 150 | "inlineSources": true, 151 | "emitDecoratorMetadata": true, 152 | "experimentalDecorators": true, 153 | "declaration": true, 154 | "lib": [ 155 | "es7" 156 | ], 157 | "types": [ 158 | "node", 159 | "mocha", 160 | "chai" 161 | ], 162 | "removeComments": true, 163 | "noImplicitAny": false, 164 | "baseUrl": ".", 165 | "paths": { 166 | "*": [ "./*" ], 167 | "src/*": ["./src/*"] 168 | }, 169 | "typeRoots": [ 170 | "node_modules/@types" 171 | ] 172 | }, 173 | "include": [ 174 | "./src/**/*.ts" 175 | ], 176 | "exclude": [ 177 | "node_modules" 178 | ] 179 | } 180 | ``` 181 | 182 | Now you can use the following decorators: 183 | 184 | - `attachment(name: string, type: ContentType)` 185 | - `issue(idFn: string | ((arg: T) => string))` 186 | - `testCaseId(idFn: string | ((arg: T) => string))` 187 | - `feature(featureFn: string | ((arg: T) => string))` 188 | - `story(storyFn: string | ((arg: T) => string))` 189 | - `severity(severityFn: Severity | string | ((arg: T) => string | Severity))` 190 | - `tag(tagFn: string | ((arg: T) => string))` 191 | - `owner(ownerFn: string | ((arg: T) => string))` 192 | - `epic(epicFn: string | ((arg: T) => string))` 193 | - `description(descriptionFn: string | ((arg: T) => string))` 194 | - `step(nameFn: string | ((arg: T) => string))` 195 | - `data(params: any, name?: string)` 196 | - `data.naming(nameForTests: (parameters: any) => string)` 197 | 198 | To activate decorators you have to provide Allure implementation in runtime. You can do that the following way: 199 | ```typescript 200 | import { decorate } from 'ts-test-decorators'; 201 | import { allure, MochaAllure } from 'allure-mocha/runtime' 202 | // ... 203 | before() { 204 | decorate(allure) 205 | } 206 | ``` 207 | 208 | If you want to set you own trackers' URLs, do the following: 209 | ```typescript 210 | import { assignPmsUrl, assignTmsUrl } from 'ts-test-decorators'; 211 | // ... 212 | before() { 213 | const gitHubUrl: string = 'https://github.com/sskorol/ts-test-decorators/issues' 214 | assignPmsUrl(gitHubUrl) 215 | assignTmsUrl(gitHubUrl) 216 | } 217 | ``` 218 | 219 | **@data** is not related to Allure. It's just a wrapper for testdeck **@params** decorator. 220 | 221 | Also, be aware of **@test** and **@data** order. They should be always put before actual test method signature. 222 | 223 | ## Examples 224 | 225 | See [mocha-allure2-example](https://github.com/sskorol/mocha-allure2-example) project, which is already configured to use latest Allure 2 features with decorators support. 226 | 227 | ## Special Thanks 228 | 229 | [@srg-kostyrko](https://github.com/srg-kostyrko) for help and assistance. 230 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "ts-test-decorators", 3 | "version": "0.0.6", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.8.3", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.8.3.tgz", 10 | "integrity": "sha512-a9gxpmdXtZEInkCSHUJDLHZVBgb1QS0jhss4cPP93EW7s+uC5bikET2twEF3KV+7rDblJcmNvTR7VJejqd2C2g==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.8.3" 14 | } 15 | }, 16 | "@babel/core": { 17 | "version": "7.9.6", 18 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.9.6.tgz", 19 | "integrity": "sha512-nD3deLvbsApbHAHttzIssYqgb883yU/d9roe4RZymBCDaZryMJDbptVpEpeQuRh4BJ+SYI8le9YGxKvFEvl1Wg==", 20 | "dev": true, 21 | "requires": { 22 | "@babel/code-frame": "^7.8.3", 23 | "@babel/generator": "^7.9.6", 24 | "@babel/helper-module-transforms": "^7.9.0", 25 | "@babel/helpers": "^7.9.6", 26 | "@babel/parser": "^7.9.6", 27 | "@babel/template": "^7.8.6", 28 | "@babel/traverse": "^7.9.6", 29 | "@babel/types": "^7.9.6", 30 | "convert-source-map": "^1.7.0", 31 | "debug": "^4.1.0", 32 | "gensync": "^1.0.0-beta.1", 33 | "json5": "^2.1.2", 34 | "lodash": "^4.17.13", 35 | "resolve": "^1.3.2", 36 | "semver": "^5.4.1", 37 | "source-map": "^0.5.0" 38 | } 39 | }, 40 | "@babel/generator": { 41 | "version": "7.9.6", 42 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.9.6.tgz", 43 | "integrity": "sha512-+htwWKJbH2bL72HRluF8zumBxzuX0ZZUFl3JLNyoUjM/Ho8wnVpPXM6aUz8cfKDqQ/h7zHqKt4xzJteUosckqQ==", 44 | "dev": true, 45 | "requires": { 46 | "@babel/types": "^7.9.6", 47 | "jsesc": "^2.5.1", 48 | "lodash": "^4.17.13", 49 | "source-map": "^0.5.0" 50 | } 51 | }, 52 | "@babel/helper-environment-visitor": { 53 | "version": "7.22.20", 54 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", 55 | "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==", 56 | "dev": true 57 | }, 58 | "@babel/helper-hoist-variables": { 59 | "version": "7.22.5", 60 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", 61 | "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", 62 | "dev": true, 63 | "requires": { 64 | "@babel/types": "^7.22.5" 65 | }, 66 | "dependencies": { 67 | "@babel/helper-validator-identifier": { 68 | "version": "7.22.20", 69 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", 70 | "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", 71 | "dev": true 72 | }, 73 | "@babel/types": { 74 | "version": "7.23.0", 75 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.0.tgz", 76 | "integrity": "sha512-0oIyUfKoI3mSqMvsxBdclDwxXKXAUA8v/apZbc+iSyARYou1o8ZGDxbUYyLFoW2arqS2jDGqJuZvv1d/io1axg==", 77 | "dev": true, 78 | "requires": { 79 | "@babel/helper-string-parser": "^7.22.5", 80 | "@babel/helper-validator-identifier": "^7.22.20", 81 | "to-fast-properties": "^2.0.0" 82 | } 83 | } 84 | } 85 | }, 86 | "@babel/helper-member-expression-to-functions": { 87 | "version": "7.8.3", 88 | "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.8.3.tgz", 89 | "integrity": "sha512-fO4Egq88utkQFjbPrSHGmGLFqmrshs11d46WI+WZDESt7Wu7wN2G2Iu+NMMZJFDOVRHAMIkB5SNh30NtwCA7RA==", 90 | "dev": true, 91 | "requires": { 92 | "@babel/types": "^7.8.3" 93 | } 94 | }, 95 | "@babel/helper-module-imports": { 96 | "version": "7.8.3", 97 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.8.3.tgz", 98 | "integrity": "sha512-R0Bx3jippsbAEtzkpZ/6FIiuzOURPcMjHp+Z6xPe6DtApDJx+w7UYyOLanZqO8+wKR9G10s/FmHXvxaMd9s6Kg==", 99 | "dev": true, 100 | "requires": { 101 | "@babel/types": "^7.8.3" 102 | } 103 | }, 104 | "@babel/helper-module-transforms": { 105 | "version": "7.9.0", 106 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.9.0.tgz", 107 | "integrity": "sha512-0FvKyu0gpPfIQ8EkxlrAydOWROdHpBmiCiRwLkUiBGhCUPRRbVD2/tm3sFr/c/GWFrQ/ffutGUAnx7V0FzT2wA==", 108 | "dev": true, 109 | "requires": { 110 | "@babel/helper-module-imports": "^7.8.3", 111 | "@babel/helper-replace-supers": "^7.8.6", 112 | "@babel/helper-simple-access": "^7.8.3", 113 | "@babel/helper-split-export-declaration": "^7.8.3", 114 | "@babel/template": "^7.8.6", 115 | "@babel/types": "^7.9.0", 116 | "lodash": "^4.17.13" 117 | } 118 | }, 119 | "@babel/helper-optimise-call-expression": { 120 | "version": "7.8.3", 121 | "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.8.3.tgz", 122 | "integrity": "sha512-Kag20n86cbO2AvHca6EJsvqAd82gc6VMGule4HwebwMlwkpXuVqrNRj6CkCV2sKxgi9MyAUnZVnZ6lJ1/vKhHQ==", 123 | "dev": true, 124 | "requires": { 125 | "@babel/types": "^7.8.3" 126 | } 127 | }, 128 | "@babel/helper-replace-supers": { 129 | "version": "7.9.6", 130 | "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.9.6.tgz", 131 | "integrity": "sha512-qX+chbxkbArLyCImk3bWV+jB5gTNU/rsze+JlcF6Nf8tVTigPJSI1o1oBow/9Resa1yehUO9lIipsmu9oG4RzA==", 132 | "dev": true, 133 | "requires": { 134 | "@babel/helper-member-expression-to-functions": "^7.8.3", 135 | "@babel/helper-optimise-call-expression": "^7.8.3", 136 | "@babel/traverse": "^7.9.6", 137 | "@babel/types": "^7.9.6" 138 | } 139 | }, 140 | "@babel/helper-simple-access": { 141 | "version": "7.8.3", 142 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.8.3.tgz", 143 | "integrity": "sha512-VNGUDjx5cCWg4vvCTR8qQ7YJYZ+HBjxOgXEl7ounz+4Sn7+LMD3CFrCTEU6/qXKbA2nKg21CwhhBzO0RpRbdCw==", 144 | "dev": true, 145 | "requires": { 146 | "@babel/template": "^7.8.3", 147 | "@babel/types": "^7.8.3" 148 | } 149 | }, 150 | "@babel/helper-split-export-declaration": { 151 | "version": "7.8.3", 152 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.8.3.tgz", 153 | "integrity": "sha512-3x3yOeyBhW851hroze7ElzdkeRXQYQbFIb7gLK1WQYsw2GWDay5gAJNw1sWJ0VFP6z5J1whqeXH/WCdCjZv6dA==", 154 | "dev": true, 155 | "requires": { 156 | "@babel/types": "^7.8.3" 157 | } 158 | }, 159 | "@babel/helper-string-parser": { 160 | "version": "7.22.5", 161 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.22.5.tgz", 162 | "integrity": "sha512-mM4COjgZox8U+JcXQwPijIZLElkgEpO5rsERVDJTc2qfCDfERyob6k5WegS14SX18IIjv+XD+GrqNumY5JRCDw==", 163 | "dev": true 164 | }, 165 | "@babel/helper-validator-identifier": { 166 | "version": "7.9.5", 167 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.9.5.tgz", 168 | "integrity": "sha512-/8arLKUFq882w4tWGj9JYzRpAlZgiWUJ+dtteNTDqrRBz9Iguck9Rn3ykuBDoUwh2TO4tSAJlrxDUOXWklJe4g==", 169 | "dev": true 170 | }, 171 | "@babel/helpers": { 172 | "version": "7.9.6", 173 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.9.6.tgz", 174 | "integrity": "sha512-tI4bUbldloLcHWoRUMAj4g1bF313M/o6fBKhIsb3QnGVPwRm9JsNf/gqMkQ7zjqReABiffPV6RWj7hEglID5Iw==", 175 | "dev": true, 176 | "requires": { 177 | "@babel/template": "^7.8.3", 178 | "@babel/traverse": "^7.9.6", 179 | "@babel/types": "^7.9.6" 180 | } 181 | }, 182 | "@babel/highlight": { 183 | "version": "7.9.0", 184 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.9.0.tgz", 185 | "integrity": "sha512-lJZPilxX7Op3Nv/2cvFdnlepPXDxi29wxteT57Q965oc5R9v86ztx0jfxVrTcBk8C2kcPkkDa2Z4T3ZsPPVWsQ==", 186 | "dev": true, 187 | "requires": { 188 | "@babel/helper-validator-identifier": "^7.9.0", 189 | "chalk": "^2.0.0", 190 | "js-tokens": "^4.0.0" 191 | }, 192 | "dependencies": { 193 | "ansi-styles": { 194 | "version": "3.2.1", 195 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 196 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 197 | "dev": true, 198 | "requires": { 199 | "color-convert": "^1.9.0" 200 | } 201 | }, 202 | "chalk": { 203 | "version": "2.4.2", 204 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 205 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 206 | "dev": true, 207 | "requires": { 208 | "ansi-styles": "^3.2.1", 209 | "escape-string-regexp": "^1.0.5", 210 | "supports-color": "^5.3.0" 211 | } 212 | }, 213 | "color-convert": { 214 | "version": "1.9.3", 215 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 216 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 217 | "dev": true, 218 | "requires": { 219 | "color-name": "1.1.3" 220 | } 221 | }, 222 | "color-name": { 223 | "version": "1.1.3", 224 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 225 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 226 | "dev": true 227 | }, 228 | "has-flag": { 229 | "version": "3.0.0", 230 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 231 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 232 | "dev": true 233 | }, 234 | "supports-color": { 235 | "version": "5.5.0", 236 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 237 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 238 | "dev": true, 239 | "requires": { 240 | "has-flag": "^3.0.0" 241 | } 242 | } 243 | } 244 | }, 245 | "@babel/parser": { 246 | "version": "7.9.6", 247 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.9.6.tgz", 248 | "integrity": "sha512-AoeIEJn8vt+d/6+PXDRPaksYhnlbMIiejioBZvvMQsOjW/JYK6k/0dKnvvP3EhK5GfMBWDPtrxRtegWdAcdq9Q==", 249 | "dev": true 250 | }, 251 | "@babel/template": { 252 | "version": "7.8.6", 253 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.8.6.tgz", 254 | "integrity": "sha512-zbMsPMy/v0PWFZEhQJ66bqjhH+z0JgMoBWuikXybgG3Gkd/3t5oQ1Rw2WQhnSrsOmsKXnZOx15tkC4qON/+JPg==", 255 | "dev": true, 256 | "requires": { 257 | "@babel/code-frame": "^7.8.3", 258 | "@babel/parser": "^7.8.6", 259 | "@babel/types": "^7.8.6" 260 | } 261 | }, 262 | "@babel/traverse": { 263 | "version": "7.23.2", 264 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.2.tgz", 265 | "integrity": "sha512-azpe59SQ48qG6nu2CzcMLbxUudtN+dOM9kDbUqGq3HXUJRlo7i8fvPoxQUzYgLZ4cMVmuZgm8vvBpNeRhd6XSw==", 266 | "dev": true, 267 | "requires": { 268 | "@babel/code-frame": "^7.22.13", 269 | "@babel/generator": "^7.23.0", 270 | "@babel/helper-environment-visitor": "^7.22.20", 271 | "@babel/helper-function-name": "^7.23.0", 272 | "@babel/helper-hoist-variables": "^7.22.5", 273 | "@babel/helper-split-export-declaration": "^7.22.6", 274 | "@babel/parser": "^7.23.0", 275 | "@babel/types": "^7.23.0", 276 | "debug": "^4.1.0", 277 | "globals": "^11.1.0" 278 | }, 279 | "dependencies": { 280 | "@babel/code-frame": { 281 | "version": "7.22.13", 282 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.13.tgz", 283 | "integrity": "sha512-XktuhWlJ5g+3TJXc5upd9Ks1HutSArik6jf2eAjYFyIOf4ej3RN+184cZbzDvbPnuTJIUhPKKJE3cIsYTiAT3w==", 284 | "dev": true, 285 | "requires": { 286 | "@babel/highlight": "^7.22.13", 287 | "chalk": "^2.4.2" 288 | } 289 | }, 290 | "@babel/generator": { 291 | "version": "7.23.0", 292 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.0.tgz", 293 | "integrity": "sha512-lN85QRR+5IbYrMWM6Y4pE/noaQtg4pNiqeNGX60eqOfo6gtEj6uw/JagelB8vVztSd7R6M5n1+PQkDbHbBRU4g==", 294 | "dev": true, 295 | "requires": { 296 | "@babel/types": "^7.23.0", 297 | "@jridgewell/gen-mapping": "^0.3.2", 298 | "@jridgewell/trace-mapping": "^0.3.17", 299 | "jsesc": "^2.5.1" 300 | } 301 | }, 302 | "@babel/helper-function-name": { 303 | "version": "7.23.0", 304 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", 305 | "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", 306 | "dev": true, 307 | "requires": { 308 | "@babel/template": "^7.22.15", 309 | "@babel/types": "^7.23.0" 310 | } 311 | }, 312 | "@babel/helper-split-export-declaration": { 313 | "version": "7.22.6", 314 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", 315 | "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", 316 | "dev": true, 317 | "requires": { 318 | "@babel/types": "^7.22.5" 319 | } 320 | }, 321 | "@babel/helper-validator-identifier": { 322 | "version": "7.22.20", 323 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", 324 | "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", 325 | "dev": true 326 | }, 327 | "@babel/highlight": { 328 | "version": "7.22.20", 329 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.20.tgz", 330 | "integrity": "sha512-dkdMCN3py0+ksCgYmGG8jKeGA/8Tk+gJwSYYlFGxG5lmhfKNoAy004YpLxpS1W2J8m/EK2Ew+yOs9pVRwO89mg==", 331 | "dev": true, 332 | "requires": { 333 | "@babel/helper-validator-identifier": "^7.22.20", 334 | "chalk": "^2.4.2", 335 | "js-tokens": "^4.0.0" 336 | } 337 | }, 338 | "@babel/parser": { 339 | "version": "7.23.0", 340 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.0.tgz", 341 | "integrity": "sha512-vvPKKdMemU85V9WE/l5wZEmImpCtLqbnTvqDS2U1fJ96KrxoW7KrXhNsNCblQlg8Ck4b85yxdTyelsMUgFUXiw==", 342 | "dev": true 343 | }, 344 | "@babel/template": { 345 | "version": "7.22.15", 346 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz", 347 | "integrity": "sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w==", 348 | "dev": true, 349 | "requires": { 350 | "@babel/code-frame": "^7.22.13", 351 | "@babel/parser": "^7.22.15", 352 | "@babel/types": "^7.22.15" 353 | } 354 | }, 355 | "@babel/types": { 356 | "version": "7.23.0", 357 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.0.tgz", 358 | "integrity": "sha512-0oIyUfKoI3mSqMvsxBdclDwxXKXAUA8v/apZbc+iSyARYou1o8ZGDxbUYyLFoW2arqS2jDGqJuZvv1d/io1axg==", 359 | "dev": true, 360 | "requires": { 361 | "@babel/helper-string-parser": "^7.22.5", 362 | "@babel/helper-validator-identifier": "^7.22.20", 363 | "to-fast-properties": "^2.0.0" 364 | } 365 | }, 366 | "ansi-styles": { 367 | "version": "3.2.1", 368 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 369 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 370 | "dev": true, 371 | "requires": { 372 | "color-convert": "^1.9.0" 373 | } 374 | }, 375 | "chalk": { 376 | "version": "2.4.2", 377 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 378 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 379 | "dev": true, 380 | "requires": { 381 | "ansi-styles": "^3.2.1", 382 | "escape-string-regexp": "^1.0.5", 383 | "supports-color": "^5.3.0" 384 | } 385 | }, 386 | "color-convert": { 387 | "version": "1.9.3", 388 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 389 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 390 | "dev": true, 391 | "requires": { 392 | "color-name": "1.1.3" 393 | } 394 | }, 395 | "color-name": { 396 | "version": "1.1.3", 397 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 398 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 399 | "dev": true 400 | }, 401 | "has-flag": { 402 | "version": "3.0.0", 403 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 404 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 405 | "dev": true 406 | }, 407 | "supports-color": { 408 | "version": "5.5.0", 409 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 410 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 411 | "dev": true, 412 | "requires": { 413 | "has-flag": "^3.0.0" 414 | } 415 | } 416 | } 417 | }, 418 | "@babel/types": { 419 | "version": "7.9.6", 420 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.9.6.tgz", 421 | "integrity": "sha512-qxXzvBO//jO9ZnoasKF1uJzHd2+M6Q2ZPIVfnFps8JJvXy0ZBbwbNOmE6SGIY5XOY6d1Bo5lb9d9RJ8nv3WSeA==", 422 | "dev": true, 423 | "requires": { 424 | "@babel/helper-validator-identifier": "^7.9.5", 425 | "lodash": "^4.17.13", 426 | "to-fast-properties": "^2.0.0" 427 | } 428 | }, 429 | "@istanbuljs/load-nyc-config": { 430 | "version": "1.1.0", 431 | "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", 432 | "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", 433 | "dev": true, 434 | "requires": { 435 | "camelcase": "^5.3.1", 436 | "find-up": "^4.1.0", 437 | "get-package-type": "^0.1.0", 438 | "js-yaml": "^3.13.1", 439 | "resolve-from": "^5.0.0" 440 | }, 441 | "dependencies": { 442 | "resolve-from": { 443 | "version": "5.0.0", 444 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 445 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 446 | "dev": true 447 | } 448 | } 449 | }, 450 | "@istanbuljs/schema": { 451 | "version": "0.1.2", 452 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.2.tgz", 453 | "integrity": "sha512-tsAQNx32a8CoFhjhijUIhI4kccIAgmGhy8LZMZgGfmXcpMbPRUqn5LWmgRttILi6yeGmBJd2xsPkFMs0PzgPCw==", 454 | "dev": true 455 | }, 456 | "@jridgewell/gen-mapping": { 457 | "version": "0.3.3", 458 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", 459 | "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", 460 | "dev": true, 461 | "requires": { 462 | "@jridgewell/set-array": "^1.0.1", 463 | "@jridgewell/sourcemap-codec": "^1.4.10", 464 | "@jridgewell/trace-mapping": "^0.3.9" 465 | } 466 | }, 467 | "@jridgewell/resolve-uri": { 468 | "version": "3.1.1", 469 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", 470 | "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==", 471 | "dev": true 472 | }, 473 | "@jridgewell/set-array": { 474 | "version": "1.1.2", 475 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", 476 | "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", 477 | "dev": true 478 | }, 479 | "@jridgewell/sourcemap-codec": { 480 | "version": "1.4.15", 481 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 482 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 483 | "dev": true 484 | }, 485 | "@jridgewell/trace-mapping": { 486 | "version": "0.3.19", 487 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.19.tgz", 488 | "integrity": "sha512-kf37QtfW+Hwx/buWGMPcR60iF9ziHa6r/CZJIHbmcm4+0qrXiVdxegAH0F6yddEVQ7zdkjcGCgCzUu+BcbhQxw==", 489 | "dev": true, 490 | "requires": { 491 | "@jridgewell/resolve-uri": "^3.1.0", 492 | "@jridgewell/sourcemap-codec": "^1.4.14" 493 | } 494 | }, 495 | "@samverschueren/stream-to-observable": { 496 | "version": "0.3.0", 497 | "resolved": "https://registry.npmjs.org/@samverschueren/stream-to-observable/-/stream-to-observable-0.3.0.tgz", 498 | "integrity": "sha512-MI4Xx6LHs4Webyvi6EbspgyAb4D2Q2VtnCQ1blOJcoLS6mVa8lNN2rkIy1CVxfTUpoyIbCTkXES1rLXztFD1lg==", 499 | "dev": true, 500 | "requires": { 501 | "any-observable": "^0.3.0" 502 | } 503 | }, 504 | "@testdeck/core": { 505 | "version": "0.1.0", 506 | "resolved": "https://registry.npmjs.org/@testdeck/core/-/core-0.1.0.tgz", 507 | "integrity": "sha512-gJj/HQoNUtyb5B/KC1UcirYAn8bv6XLzlFIIIFfoR7Ew5OQcU7UNbjwJUKNtJ27YtVTw1a1dNadk6RQts/1TCw==", 508 | "dev": true 509 | }, 510 | "@testdeck/mocha": { 511 | "version": "0.1.0", 512 | "resolved": "https://registry.npmjs.org/@testdeck/mocha/-/mocha-0.1.0.tgz", 513 | "integrity": "sha512-1kE5AlkfDCgIrwjCRLtPam4YSo0MUf3Wj95mcVkRtRdExnQOvX3ravFrEYBRsfcmlsFPX7WsQFi0sje2cSzvnQ==", 514 | "dev": true, 515 | "requires": { 516 | "@testdeck/core": "^0.1.0" 517 | } 518 | }, 519 | "@tootallnate/once": { 520 | "version": "1.1.2", 521 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 522 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 523 | "dev": true 524 | }, 525 | "@types/chai": { 526 | "version": "4.2.11", 527 | "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.2.11.tgz", 528 | "integrity": "sha512-t7uW6eFafjO+qJ3BIV2gGUyZs27egcNRkUdalkud+Qa3+kg//f129iuOFivHDXQ+vnU3fDXuwgv0cqMCbcE8sw==", 529 | "dev": true 530 | }, 531 | "@types/color-name": { 532 | "version": "1.1.1", 533 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 534 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 535 | "dev": true 536 | }, 537 | "@types/mocha": { 538 | "version": "7.0.2", 539 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-7.0.2.tgz", 540 | "integrity": "sha512-ZvO2tAcjmMi8V/5Z3JsyofMe3hasRcaw88cto5etSVMwVQfeivGAlEYmaQgceUSVYFofVjT+ioHsATjdWcFt1w==", 541 | "dev": true 542 | }, 543 | "@types/node": { 544 | "version": "13.13.9", 545 | "resolved": "https://registry.npmjs.org/@types/node/-/node-13.13.9.tgz", 546 | "integrity": "sha512-EPZBIGed5gNnfWCiwEIwTE2Jdg4813odnG8iNPMQGrqVxrI+wL68SPtPeCX+ZxGBaA6pKAVc6jaKgP/Q0QzfdQ==", 547 | "dev": true 548 | }, 549 | "@types/parse-json": { 550 | "version": "4.0.0", 551 | "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz", 552 | "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==", 553 | "dev": true 554 | }, 555 | "agent-base": { 556 | "version": "6.0.1", 557 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.1.tgz", 558 | "integrity": "sha512-01q25QQDwLSsyfhrKbn8yuur+JNw0H+0Y4JiGIKd3z9aYk/w/2kxD/Upc+t2ZBBSUNff50VjPsSW2YxM8QYKVg==", 559 | "dev": true, 560 | "requires": { 561 | "debug": "4" 562 | } 563 | }, 564 | "aggregate-error": { 565 | "version": "3.0.1", 566 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.0.1.tgz", 567 | "integrity": "sha512-quoaXsZ9/BLNae5yiNoUz+Nhkwz83GhWwtYFglcjEQB2NDHCIpApbqXxIFnm4Pq/Nvhrsq5sYJFyohrrxnTGAA==", 568 | "dev": true, 569 | "requires": { 570 | "clean-stack": "^2.0.0", 571 | "indent-string": "^4.0.0" 572 | } 573 | }, 574 | "allure-commandline": { 575 | "version": "2.13.0", 576 | "resolved": "https://registry.npmjs.org/allure-commandline/-/allure-commandline-2.13.0.tgz", 577 | "integrity": "sha512-KUByc0nT+vVVsnW/p36R92+FS2o3xVX27p+AW/8T4dlXVh7jx6V0v6+rRBCpK7AhBKD9/T3jsSq14hS0sxp64Q==", 578 | "dev": true 579 | }, 580 | "allure-js-commons": { 581 | "version": "2.0.0-beta.7", 582 | "resolved": "https://registry.npmjs.org/allure-js-commons/-/allure-js-commons-2.0.0-beta.7.tgz", 583 | "integrity": "sha512-mTHr1RntyvxXXaqdj94DqtanVUozKXQVNOhuKwqOvbPHKRUd6DIeW0WjPXCTag4NE/jx/FO/MVPErYutbGwOUA==", 584 | "requires": { 585 | "mkdirp": "^0.5.1", 586 | "properties": "^1.2.1", 587 | "uuid": "^7.0.2" 588 | } 589 | }, 590 | "allure-mocha": { 591 | "version": "2.0.0-beta.7", 592 | "resolved": "https://registry.npmjs.org/allure-mocha/-/allure-mocha-2.0.0-beta.7.tgz", 593 | "integrity": "sha512-ZMr0BWfqeptXMLyPOePWApQqCcFwoEzeeAUddfe9lsOK47IAY5BzzaQLHvWzjwsJv3W04+qeOjUW1yiQ9XzPyA==", 594 | "dev": true, 595 | "requires": { 596 | "allure-js-commons": "^2.0.0-beta.7" 597 | } 598 | }, 599 | "ansi-colors": { 600 | "version": "3.2.4", 601 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.4.tgz", 602 | "integrity": "sha512-hHUXGagefjN2iRrID63xckIvotOXOojhQKWIPUZ4mNUZ9nLZW+7FMNoE1lOkEhNWYsx/7ysGIuJYCiMAA9FnrA==", 603 | "dev": true 604 | }, 605 | "ansi-escapes": { 606 | "version": "4.3.1", 607 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz", 608 | "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==", 609 | "dev": true, 610 | "requires": { 611 | "type-fest": "^0.11.0" 612 | } 613 | }, 614 | "ansi-regex": { 615 | "version": "5.0.1", 616 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 617 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 618 | "dev": true 619 | }, 620 | "ansi-styles": { 621 | "version": "4.2.1", 622 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 623 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 624 | "dev": true, 625 | "requires": { 626 | "@types/color-name": "^1.1.1", 627 | "color-convert": "^2.0.1" 628 | } 629 | }, 630 | "any-observable": { 631 | "version": "0.3.0", 632 | "resolved": "https://registry.npmjs.org/any-observable/-/any-observable-0.3.0.tgz", 633 | "integrity": "sha512-/FQM1EDkTsf63Ub2C6O7GuYFDsSXUwsaZDurV0np41ocwq0jthUAYCmhBX9f+KwlaCgIuWyr/4WlUQUBfKfZog==", 634 | "dev": true 635 | }, 636 | "anymatch": { 637 | "version": "3.1.1", 638 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", 639 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", 640 | "dev": true, 641 | "requires": { 642 | "normalize-path": "^3.0.0", 643 | "picomatch": "^2.0.4" 644 | } 645 | }, 646 | "append-transform": { 647 | "version": "2.0.0", 648 | "resolved": "https://registry.npmjs.org/append-transform/-/append-transform-2.0.0.tgz", 649 | "integrity": "sha512-7yeyCEurROLQJFv5Xj4lEGTy0borxepjFv1g22oAdqFu//SrAlDl1O1Nxx15SH1RoliUml6p8dwJW9jvZughhg==", 650 | "dev": true, 651 | "requires": { 652 | "default-require-extensions": "^3.0.0" 653 | } 654 | }, 655 | "archy": { 656 | "version": "1.0.0", 657 | "resolved": "https://registry.npmjs.org/archy/-/archy-1.0.0.tgz", 658 | "integrity": "sha1-+cjBN1fMHde8N5rHeyxipcKGjEA=", 659 | "dev": true 660 | }, 661 | "arg": { 662 | "version": "4.1.3", 663 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 664 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 665 | "dev": true 666 | }, 667 | "argparse": { 668 | "version": "1.0.10", 669 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 670 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 671 | "dev": true, 672 | "requires": { 673 | "sprintf-js": "~1.0.2" 674 | } 675 | }, 676 | "argv": { 677 | "version": "0.0.2", 678 | "resolved": "https://registry.npmjs.org/argv/-/argv-0.0.2.tgz", 679 | "integrity": "sha1-7L0W+JSbFXGDcRsb2jNPN4QBhas=", 680 | "dev": true 681 | }, 682 | "assertion-error": { 683 | "version": "1.1.0", 684 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 685 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 686 | "dev": true 687 | }, 688 | "astral-regex": { 689 | "version": "2.0.0", 690 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 691 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 692 | "dev": true 693 | }, 694 | "balanced-match": { 695 | "version": "1.0.0", 696 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 697 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 698 | "dev": true 699 | }, 700 | "binary-extensions": { 701 | "version": "2.0.0", 702 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.0.0.tgz", 703 | "integrity": "sha512-Phlt0plgpIIBOGTT/ehfFnbNlfsDEiqmzE2KRXoX1bLIlir4X/MR+zSyBEkL05ffWgnRSf/DXv+WrUAVr93/ow==", 704 | "dev": true 705 | }, 706 | "brace-expansion": { 707 | "version": "1.1.11", 708 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 709 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 710 | "dev": true, 711 | "requires": { 712 | "balanced-match": "^1.0.0", 713 | "concat-map": "0.0.1" 714 | } 715 | }, 716 | "braces": { 717 | "version": "3.0.2", 718 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 719 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 720 | "dev": true, 721 | "requires": { 722 | "fill-range": "^7.0.1" 723 | } 724 | }, 725 | "browser-stdout": { 726 | "version": "1.3.1", 727 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 728 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 729 | "dev": true 730 | }, 731 | "buffer-from": { 732 | "version": "1.1.1", 733 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 734 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 735 | "dev": true 736 | }, 737 | "builtin-modules": { 738 | "version": "1.1.1", 739 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 740 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 741 | "dev": true 742 | }, 743 | "caching-transform": { 744 | "version": "4.0.0", 745 | "resolved": "https://registry.npmjs.org/caching-transform/-/caching-transform-4.0.0.tgz", 746 | "integrity": "sha512-kpqOvwXnjjN44D89K5ccQC+RUrsy7jB/XLlRrx0D7/2HNcTPqzsb6XgYoErwko6QsV184CA2YgS1fxDiiDZMWA==", 747 | "dev": true, 748 | "requires": { 749 | "hasha": "^5.0.0", 750 | "make-dir": "^3.0.0", 751 | "package-hash": "^4.0.0", 752 | "write-file-atomic": "^3.0.0" 753 | } 754 | }, 755 | "callsites": { 756 | "version": "3.1.0", 757 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 758 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 759 | "dev": true 760 | }, 761 | "camelcase": { 762 | "version": "5.3.1", 763 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 764 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 765 | "dev": true 766 | }, 767 | "chai": { 768 | "version": "4.2.0", 769 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz", 770 | "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==", 771 | "dev": true, 772 | "requires": { 773 | "assertion-error": "^1.1.0", 774 | "check-error": "^1.0.2", 775 | "deep-eql": "^3.0.1", 776 | "get-func-name": "^2.0.0", 777 | "pathval": "^1.1.0", 778 | "type-detect": "^4.0.5" 779 | } 780 | }, 781 | "chalk": { 782 | "version": "4.0.0", 783 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.0.0.tgz", 784 | "integrity": "sha512-N9oWFcegS0sFr9oh1oz2d7Npos6vNoWW9HvtCg5N1KRFpUhaAhvTv5Y58g880fZaEYSNm3qDz8SU1UrGvp+n7A==", 785 | "dev": true, 786 | "requires": { 787 | "ansi-styles": "^4.1.0", 788 | "supports-color": "^7.1.0" 789 | } 790 | }, 791 | "check-error": { 792 | "version": "1.0.2", 793 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 794 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 795 | "dev": true 796 | }, 797 | "chokidar": { 798 | "version": "3.3.0", 799 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.3.0.tgz", 800 | "integrity": "sha512-dGmKLDdT3Gdl7fBUe8XK+gAtGmzy5Fn0XkkWQuYxGIgWVPPse2CxFA5mtrlD0TOHaHjEUqkWNyP1XdHoJES/4A==", 801 | "dev": true, 802 | "requires": { 803 | "anymatch": "~3.1.1", 804 | "braces": "~3.0.2", 805 | "fsevents": "~2.1.1", 806 | "glob-parent": "~5.1.0", 807 | "is-binary-path": "~2.1.0", 808 | "is-glob": "~4.0.1", 809 | "normalize-path": "~3.0.0", 810 | "readdirp": "~3.2.0" 811 | } 812 | }, 813 | "ci-info": { 814 | "version": "2.0.0", 815 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 816 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", 817 | "dev": true 818 | }, 819 | "clean-stack": { 820 | "version": "2.2.0", 821 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 822 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 823 | "dev": true 824 | }, 825 | "cli-cursor": { 826 | "version": "3.1.0", 827 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 828 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 829 | "dev": true, 830 | "requires": { 831 | "restore-cursor": "^3.1.0" 832 | } 833 | }, 834 | "cli-truncate": { 835 | "version": "2.1.0", 836 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-2.1.0.tgz", 837 | "integrity": "sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg==", 838 | "dev": true, 839 | "requires": { 840 | "slice-ansi": "^3.0.0", 841 | "string-width": "^4.2.0" 842 | } 843 | }, 844 | "cliui": { 845 | "version": "5.0.0", 846 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 847 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 848 | "dev": true, 849 | "requires": { 850 | "string-width": "^3.1.0", 851 | "strip-ansi": "^5.2.0", 852 | "wrap-ansi": "^5.1.0" 853 | }, 854 | "dependencies": { 855 | "ansi-regex": { 856 | "version": "4.1.1", 857 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.1.tgz", 858 | "integrity": "sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g==", 859 | "dev": true 860 | }, 861 | "ansi-styles": { 862 | "version": "3.2.1", 863 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 864 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 865 | "dev": true, 866 | "requires": { 867 | "color-convert": "^1.9.0" 868 | } 869 | }, 870 | "color-convert": { 871 | "version": "1.9.3", 872 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 873 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 874 | "dev": true, 875 | "requires": { 876 | "color-name": "1.1.3" 877 | } 878 | }, 879 | "color-name": { 880 | "version": "1.1.3", 881 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 882 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 883 | "dev": true 884 | }, 885 | "emoji-regex": { 886 | "version": "7.0.3", 887 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 888 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 889 | "dev": true 890 | }, 891 | "is-fullwidth-code-point": { 892 | "version": "2.0.0", 893 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 894 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 895 | "dev": true 896 | }, 897 | "string-width": { 898 | "version": "3.1.0", 899 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 900 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 901 | "dev": true, 902 | "requires": { 903 | "emoji-regex": "^7.0.1", 904 | "is-fullwidth-code-point": "^2.0.0", 905 | "strip-ansi": "^5.1.0" 906 | } 907 | }, 908 | "strip-ansi": { 909 | "version": "5.2.0", 910 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 911 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 912 | "dev": true, 913 | "requires": { 914 | "ansi-regex": "^4.1.0" 915 | } 916 | }, 917 | "wrap-ansi": { 918 | "version": "5.1.0", 919 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 920 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 921 | "dev": true, 922 | "requires": { 923 | "ansi-styles": "^3.2.0", 924 | "string-width": "^3.0.0", 925 | "strip-ansi": "^5.0.0" 926 | } 927 | } 928 | } 929 | }, 930 | "clone": { 931 | "version": "1.0.4", 932 | "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", 933 | "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", 934 | "dev": true 935 | }, 936 | "codecov": { 937 | "version": "3.7.1", 938 | "resolved": "https://registry.npmjs.org/codecov/-/codecov-3.7.1.tgz", 939 | "integrity": "sha512-JHWxyPTkMLLJn9SmKJnwAnvY09kg2Os2+Ux+GG7LwZ9g8gzDDISpIN5wAsH1UBaafA/yGcd3KofMaorE8qd6Lw==", 940 | "dev": true, 941 | "requires": { 942 | "argv": "0.0.2", 943 | "ignore-walk": "3.0.3", 944 | "js-yaml": "3.13.1", 945 | "teeny-request": "6.0.1", 946 | "urlgrey": "0.4.4" 947 | } 948 | }, 949 | "color-convert": { 950 | "version": "2.0.1", 951 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 952 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 953 | "dev": true, 954 | "requires": { 955 | "color-name": "~1.1.4" 956 | } 957 | }, 958 | "color-name": { 959 | "version": "1.1.4", 960 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 961 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 962 | "dev": true 963 | }, 964 | "commander": { 965 | "version": "5.1.0", 966 | "resolved": "https://registry.npmjs.org/commander/-/commander-5.1.0.tgz", 967 | "integrity": "sha512-P0CysNDQ7rtVw4QIQtm+MRxV66vKFSvlsQvGYXZWR3qFU0jlMKHZZZgw8e+8DSah4UDKMqnknRDQz+xuQXQ/Zg==", 968 | "dev": true 969 | }, 970 | "commondir": { 971 | "version": "1.0.1", 972 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 973 | "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", 974 | "dev": true 975 | }, 976 | "compare-versions": { 977 | "version": "3.6.0", 978 | "resolved": "https://registry.npmjs.org/compare-versions/-/compare-versions-3.6.0.tgz", 979 | "integrity": "sha512-W6Af2Iw1z4CB7q4uU4hv646dW9GQuBM+YpC0UvUCWSD8w90SJjp+ujJuXaEMtAXBtSqGfMPuFOVn4/+FlaqfBA==", 980 | "dev": true 981 | }, 982 | "concat-map": { 983 | "version": "0.0.1", 984 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 985 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 986 | "dev": true 987 | }, 988 | "convert-source-map": { 989 | "version": "1.7.0", 990 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", 991 | "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==", 992 | "dev": true, 993 | "requires": { 994 | "safe-buffer": "~5.1.1" 995 | } 996 | }, 997 | "cosmiconfig": { 998 | "version": "6.0.0", 999 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-6.0.0.tgz", 1000 | "integrity": "sha512-xb3ZL6+L8b9JLLCx3ZdoZy4+2ECphCMo2PwqgP1tlfVq6M6YReyzBJtvWWtbDSpNr9hn96pkCiZqUcFEc+54Qg==", 1001 | "dev": true, 1002 | "requires": { 1003 | "@types/parse-json": "^4.0.0", 1004 | "import-fresh": "^3.1.0", 1005 | "parse-json": "^5.0.0", 1006 | "path-type": "^4.0.0", 1007 | "yaml": "^1.7.2" 1008 | } 1009 | }, 1010 | "cross-spawn": { 1011 | "version": "7.0.2", 1012 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.2.tgz", 1013 | "integrity": "sha512-PD6G8QG3S4FK/XCGFbEQrDqO2AnMMsy0meR7lerlIOHAAbkuavGU/pOqprrlvfTNjvowivTeBsjebAL0NSoMxw==", 1014 | "dev": true, 1015 | "requires": { 1016 | "path-key": "^3.1.0", 1017 | "shebang-command": "^2.0.0", 1018 | "which": "^2.0.1" 1019 | } 1020 | }, 1021 | "debug": { 1022 | "version": "4.1.1", 1023 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 1024 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 1025 | "dev": true, 1026 | "requires": { 1027 | "ms": "^2.1.1" 1028 | } 1029 | }, 1030 | "decamelize": { 1031 | "version": "1.2.0", 1032 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 1033 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 1034 | "dev": true 1035 | }, 1036 | "dedent": { 1037 | "version": "0.7.0", 1038 | "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", 1039 | "integrity": "sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw=", 1040 | "dev": true 1041 | }, 1042 | "deep-eql": { 1043 | "version": "3.0.1", 1044 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 1045 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 1046 | "dev": true, 1047 | "requires": { 1048 | "type-detect": "^4.0.0" 1049 | } 1050 | }, 1051 | "default-require-extensions": { 1052 | "version": "3.0.0", 1053 | "resolved": "https://registry.npmjs.org/default-require-extensions/-/default-require-extensions-3.0.0.tgz", 1054 | "integrity": "sha512-ek6DpXq/SCpvjhpFsLFRVtIxJCRw6fUR42lYMVZuUMK7n8eMz4Uh5clckdBjEpLhn/gEBZo7hDJnJcwdKLKQjg==", 1055 | "dev": true, 1056 | "requires": { 1057 | "strip-bom": "^4.0.0" 1058 | }, 1059 | "dependencies": { 1060 | "strip-bom": { 1061 | "version": "4.0.0", 1062 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", 1063 | "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", 1064 | "dev": true 1065 | } 1066 | } 1067 | }, 1068 | "defaults": { 1069 | "version": "1.0.3", 1070 | "resolved": "https://registry.npmjs.org/defaults/-/defaults-1.0.3.tgz", 1071 | "integrity": "sha1-xlYFHpgX2f8I7YgUd/P+QBnz730=", 1072 | "dev": true, 1073 | "requires": { 1074 | "clone": "^1.0.2" 1075 | } 1076 | }, 1077 | "define-properties": { 1078 | "version": "1.1.3", 1079 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 1080 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 1081 | "dev": true, 1082 | "requires": { 1083 | "object-keys": "^1.0.12" 1084 | } 1085 | }, 1086 | "diff": { 1087 | "version": "3.5.0", 1088 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 1089 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 1090 | "dev": true 1091 | }, 1092 | "doctrine": { 1093 | "version": "0.7.2", 1094 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-0.7.2.tgz", 1095 | "integrity": "sha1-fLhgNZujvpDgQLJrcpzkv6ZUxSM=", 1096 | "dev": true, 1097 | "requires": { 1098 | "esutils": "^1.1.6", 1099 | "isarray": "0.0.1" 1100 | } 1101 | }, 1102 | "dotenv": { 1103 | "version": "8.2.0", 1104 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", 1105 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==", 1106 | "dev": true 1107 | }, 1108 | "elegant-spinner": { 1109 | "version": "2.0.0", 1110 | "resolved": "https://registry.npmjs.org/elegant-spinner/-/elegant-spinner-2.0.0.tgz", 1111 | "integrity": "sha512-5YRYHhvhYzV/FC4AiMdeSIg3jAYGq9xFvbhZMpPlJoBsfYgrw2DSCYeXfat6tYBu45PWiyRr3+flaCPPmviPaA==", 1112 | "dev": true 1113 | }, 1114 | "emoji-regex": { 1115 | "version": "8.0.0", 1116 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1117 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1118 | "dev": true 1119 | }, 1120 | "end-of-stream": { 1121 | "version": "1.4.4", 1122 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 1123 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 1124 | "dev": true, 1125 | "requires": { 1126 | "once": "^1.4.0" 1127 | } 1128 | }, 1129 | "enquirer": { 1130 | "version": "2.3.5", 1131 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.5.tgz", 1132 | "integrity": "sha512-BNT1C08P9XD0vNg3J475yIUG+mVdp9T6towYFHUv897X0KoHBjB1shyrNmhmtHWKP17iSWgo7Gqh7BBuzLZMSA==", 1133 | "dev": true, 1134 | "requires": { 1135 | "ansi-colors": "^3.2.1" 1136 | } 1137 | }, 1138 | "error-ex": { 1139 | "version": "1.3.2", 1140 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 1141 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 1142 | "dev": true, 1143 | "requires": { 1144 | "is-arrayish": "^0.2.1" 1145 | } 1146 | }, 1147 | "es-abstract": { 1148 | "version": "1.17.5", 1149 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.5.tgz", 1150 | "integrity": "sha512-BR9auzDbySxOcfog0tLECW8l28eRGpDpU3Dm3Hp4q/N+VtLTmyj4EUN088XZWQDW/hzj6sYRDXeOFsaAODKvpg==", 1151 | "dev": true, 1152 | "requires": { 1153 | "es-to-primitive": "^1.2.1", 1154 | "function-bind": "^1.1.1", 1155 | "has": "^1.0.3", 1156 | "has-symbols": "^1.0.1", 1157 | "is-callable": "^1.1.5", 1158 | "is-regex": "^1.0.5", 1159 | "object-inspect": "^1.7.0", 1160 | "object-keys": "^1.1.1", 1161 | "object.assign": "^4.1.0", 1162 | "string.prototype.trimleft": "^2.1.1", 1163 | "string.prototype.trimright": "^2.1.1" 1164 | } 1165 | }, 1166 | "es-to-primitive": { 1167 | "version": "1.2.1", 1168 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 1169 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 1170 | "dev": true, 1171 | "requires": { 1172 | "is-callable": "^1.1.4", 1173 | "is-date-object": "^1.0.1", 1174 | "is-symbol": "^1.0.2" 1175 | } 1176 | }, 1177 | "es6-error": { 1178 | "version": "4.1.1", 1179 | "resolved": "https://registry.npmjs.org/es6-error/-/es6-error-4.1.1.tgz", 1180 | "integrity": "sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==", 1181 | "dev": true 1182 | }, 1183 | "escape-string-regexp": { 1184 | "version": "1.0.5", 1185 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1186 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 1187 | "dev": true 1188 | }, 1189 | "eslint-plugin-prettier": { 1190 | "version": "2.7.0", 1191 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-2.7.0.tgz", 1192 | "integrity": "sha512-CStQYJgALoQBw3FsBzH0VOVDRnJ/ZimUlpLm226U8qgqYJfPOY/CPK6wyRInMxh73HSKg5wyRwdS4BVYYHwokA==", 1193 | "dev": true, 1194 | "requires": { 1195 | "fast-diff": "^1.1.1", 1196 | "jest-docblock": "^21.0.0" 1197 | } 1198 | }, 1199 | "esprima": { 1200 | "version": "4.0.1", 1201 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1202 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1203 | "dev": true 1204 | }, 1205 | "esutils": { 1206 | "version": "1.1.6", 1207 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-1.1.6.tgz", 1208 | "integrity": "sha1-wBzKqa5LiXxtDD4hCuUvPHqEQ3U=", 1209 | "dev": true 1210 | }, 1211 | "execa": { 1212 | "version": "4.0.2", 1213 | "resolved": "https://registry.npmjs.org/execa/-/execa-4.0.2.tgz", 1214 | "integrity": "sha512-QI2zLa6CjGWdiQsmSkZoGtDx2N+cQIGb3yNolGTdjSQzydzLgYYf8LRuagp7S7fPimjcrzUDSUFd/MgzELMi4Q==", 1215 | "dev": true, 1216 | "requires": { 1217 | "cross-spawn": "^7.0.0", 1218 | "get-stream": "^5.0.0", 1219 | "human-signals": "^1.1.1", 1220 | "is-stream": "^2.0.0", 1221 | "merge-stream": "^2.0.0", 1222 | "npm-run-path": "^4.0.0", 1223 | "onetime": "^5.1.0", 1224 | "signal-exit": "^3.0.2", 1225 | "strip-final-newline": "^2.0.0" 1226 | } 1227 | }, 1228 | "fast-diff": { 1229 | "version": "1.2.0", 1230 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 1231 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 1232 | "dev": true 1233 | }, 1234 | "figures": { 1235 | "version": "3.2.0", 1236 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", 1237 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", 1238 | "dev": true, 1239 | "requires": { 1240 | "escape-string-regexp": "^1.0.5" 1241 | } 1242 | }, 1243 | "fill-range": { 1244 | "version": "7.0.1", 1245 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1246 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1247 | "dev": true, 1248 | "requires": { 1249 | "to-regex-range": "^5.0.1" 1250 | } 1251 | }, 1252 | "find-cache-dir": { 1253 | "version": "3.3.1", 1254 | "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.1.tgz", 1255 | "integrity": "sha512-t2GDMt3oGC/v+BMwzmllWDuJF/xcDtE5j/fCGbqDD7OLuJkj0cfh1YSA5VKPvwMeLFLNDBkwOKZ2X85jGLVftQ==", 1256 | "dev": true, 1257 | "requires": { 1258 | "commondir": "^1.0.1", 1259 | "make-dir": "^3.0.2", 1260 | "pkg-dir": "^4.1.0" 1261 | } 1262 | }, 1263 | "find-up": { 1264 | "version": "4.1.0", 1265 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 1266 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 1267 | "dev": true, 1268 | "requires": { 1269 | "locate-path": "^5.0.0", 1270 | "path-exists": "^4.0.0" 1271 | } 1272 | }, 1273 | "find-versions": { 1274 | "version": "3.2.0", 1275 | "resolved": "https://registry.npmjs.org/find-versions/-/find-versions-3.2.0.tgz", 1276 | "integrity": "sha512-P8WRou2S+oe222TOCHitLy8zj+SIsVJh52VP4lvXkaFVnOFFdoWv1H1Jjvel1aI6NCFOAaeAVm8qrI0odiLcww==", 1277 | "dev": true, 1278 | "requires": { 1279 | "semver-regex": "^2.0.0" 1280 | } 1281 | }, 1282 | "flat": { 1283 | "version": "4.1.0", 1284 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 1285 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 1286 | "dev": true, 1287 | "requires": { 1288 | "is-buffer": "~2.0.3" 1289 | } 1290 | }, 1291 | "foreground-child": { 1292 | "version": "2.0.0", 1293 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", 1294 | "integrity": "sha512-dCIq9FpEcyQyXKCkyzmlPTFNgrCzPudOe+mhvJU5zAtlBnGVy2yKxtfsxK2tQBThwq225jcvBjpw1Gr40uzZCA==", 1295 | "dev": true, 1296 | "requires": { 1297 | "cross-spawn": "^7.0.0", 1298 | "signal-exit": "^3.0.2" 1299 | } 1300 | }, 1301 | "fromentries": { 1302 | "version": "1.2.0", 1303 | "resolved": "https://registry.npmjs.org/fromentries/-/fromentries-1.2.0.tgz", 1304 | "integrity": "sha512-33X7H/wdfO99GdRLLgkjUrD4geAFdq/Uv0kl3HD4da6HDixd2GUg8Mw7dahLCV9r/EARkmtYBB6Tch4EEokFTQ==", 1305 | "dev": true 1306 | }, 1307 | "fs-jetpack": { 1308 | "version": "2.4.0", 1309 | "resolved": "https://registry.npmjs.org/fs-jetpack/-/fs-jetpack-2.4.0.tgz", 1310 | "integrity": "sha512-S/o9Dd7K9A7gicVU32eT8G0kHcmSu0rCVdP79P0MWInKFb8XpTc8Syhoo66k9no+HDshtlh4pUJTws8X+8fdFQ==", 1311 | "dev": true, 1312 | "requires": { 1313 | "minimatch": "^3.0.2", 1314 | "rimraf": "^2.6.3" 1315 | }, 1316 | "dependencies": { 1317 | "rimraf": { 1318 | "version": "2.7.1", 1319 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1320 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1321 | "dev": true, 1322 | "requires": { 1323 | "glob": "^7.1.3" 1324 | } 1325 | } 1326 | } 1327 | }, 1328 | "fs.realpath": { 1329 | "version": "1.0.0", 1330 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1331 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1332 | "dev": true 1333 | }, 1334 | "fsevents": { 1335 | "version": "2.1.3", 1336 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", 1337 | "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", 1338 | "dev": true, 1339 | "optional": true 1340 | }, 1341 | "function-bind": { 1342 | "version": "1.1.1", 1343 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1344 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1345 | "dev": true 1346 | }, 1347 | "gensync": { 1348 | "version": "1.0.0-beta.1", 1349 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.1.tgz", 1350 | "integrity": "sha512-r8EC6NO1sngH/zdD9fiRDLdcgnbayXah+mLgManTaIZJqEC1MZstmnox8KpnI2/fxQwrp5OpCOYWLp4rBl4Jcg==", 1351 | "dev": true 1352 | }, 1353 | "get-caller-file": { 1354 | "version": "2.0.5", 1355 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1356 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1357 | "dev": true 1358 | }, 1359 | "get-func-name": { 1360 | "version": "2.0.2", 1361 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.2.tgz", 1362 | "integrity": "sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ==", 1363 | "dev": true 1364 | }, 1365 | "get-own-enumerable-property-symbols": { 1366 | "version": "3.0.2", 1367 | "resolved": "https://registry.npmjs.org/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz", 1368 | "integrity": "sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g==", 1369 | "dev": true 1370 | }, 1371 | "get-package-type": { 1372 | "version": "0.1.0", 1373 | "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", 1374 | "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", 1375 | "dev": true 1376 | }, 1377 | "get-stream": { 1378 | "version": "5.1.0", 1379 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.1.0.tgz", 1380 | "integrity": "sha512-EXr1FOzrzTfGeL0gQdeFEvOMm2mzMOglyiOXSTpPC+iAjAKftbr3jpCMWynogwYnM+eSj9sHGc6wjIcDvYiygw==", 1381 | "dev": true, 1382 | "requires": { 1383 | "pump": "^3.0.0" 1384 | } 1385 | }, 1386 | "glob": { 1387 | "version": "7.1.6", 1388 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1389 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1390 | "dev": true, 1391 | "requires": { 1392 | "fs.realpath": "^1.0.0", 1393 | "inflight": "^1.0.4", 1394 | "inherits": "2", 1395 | "minimatch": "^3.0.4", 1396 | "once": "^1.3.0", 1397 | "path-is-absolute": "^1.0.0" 1398 | } 1399 | }, 1400 | "glob-parent": { 1401 | "version": "5.1.2", 1402 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1403 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1404 | "dev": true, 1405 | "requires": { 1406 | "is-glob": "^4.0.1" 1407 | } 1408 | }, 1409 | "globals": { 1410 | "version": "11.12.0", 1411 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1412 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 1413 | "dev": true 1414 | }, 1415 | "graceful-fs": { 1416 | "version": "4.2.4", 1417 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 1418 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 1419 | "dev": true 1420 | }, 1421 | "growl": { 1422 | "version": "1.10.5", 1423 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 1424 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 1425 | "dev": true 1426 | }, 1427 | "has": { 1428 | "version": "1.0.3", 1429 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1430 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1431 | "dev": true, 1432 | "requires": { 1433 | "function-bind": "^1.1.1" 1434 | } 1435 | }, 1436 | "has-flag": { 1437 | "version": "4.0.0", 1438 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1439 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1440 | "dev": true 1441 | }, 1442 | "has-symbols": { 1443 | "version": "1.0.1", 1444 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 1445 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 1446 | "dev": true 1447 | }, 1448 | "hasha": { 1449 | "version": "5.2.0", 1450 | "resolved": "https://registry.npmjs.org/hasha/-/hasha-5.2.0.tgz", 1451 | "integrity": "sha512-2W+jKdQbAdSIrggA8Q35Br8qKadTrqCTC8+XZvBWepKDK6m9XkX6Iz1a2yh2KP01kzAR/dpuMeUnocoLYDcskw==", 1452 | "dev": true, 1453 | "requires": { 1454 | "is-stream": "^2.0.0", 1455 | "type-fest": "^0.8.0" 1456 | }, 1457 | "dependencies": { 1458 | "type-fest": { 1459 | "version": "0.8.1", 1460 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1461 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1462 | "dev": true 1463 | } 1464 | } 1465 | }, 1466 | "he": { 1467 | "version": "1.2.0", 1468 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1469 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1470 | "dev": true 1471 | }, 1472 | "hosted-git-info": { 1473 | "version": "2.8.9", 1474 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", 1475 | "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", 1476 | "dev": true 1477 | }, 1478 | "html-escaper": { 1479 | "version": "2.0.2", 1480 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 1481 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 1482 | "dev": true 1483 | }, 1484 | "http-proxy-agent": { 1485 | "version": "4.0.1", 1486 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 1487 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 1488 | "dev": true, 1489 | "requires": { 1490 | "@tootallnate/once": "1", 1491 | "agent-base": "6", 1492 | "debug": "4" 1493 | } 1494 | }, 1495 | "https-proxy-agent": { 1496 | "version": "4.0.0", 1497 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-4.0.0.tgz", 1498 | "integrity": "sha512-zoDhWrkR3of1l9QAL8/scJZyLu8j/gBkcwcaQOZh7Gyh/+uJQzGVETdgT30akuwkpL8HTRfssqI3BZuV18teDg==", 1499 | "dev": true, 1500 | "requires": { 1501 | "agent-base": "5", 1502 | "debug": "4" 1503 | }, 1504 | "dependencies": { 1505 | "agent-base": { 1506 | "version": "5.1.1", 1507 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-5.1.1.tgz", 1508 | "integrity": "sha512-TMeqbNl2fMW0nMjTEPOwe3J/PRFP4vqeoNuQMG0HlMrtm5QxKqdvAkZ1pRBQ/ulIyDD5Yq0nJ7YbdD8ey0TO3g==", 1509 | "dev": true 1510 | } 1511 | } 1512 | }, 1513 | "human-signals": { 1514 | "version": "1.1.1", 1515 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-1.1.1.tgz", 1516 | "integrity": "sha512-SEQu7vl8KjNL2eoGBLF3+wAjpsNfA9XMlXAYj/3EdaNfAlxKthD1xjEQfGOUhllCGGJVNY34bRr6lPINhNjyZw==", 1517 | "dev": true 1518 | }, 1519 | "husky": { 1520 | "version": "4.2.5", 1521 | "resolved": "https://registry.npmjs.org/husky/-/husky-4.2.5.tgz", 1522 | "integrity": "sha512-SYZ95AjKcX7goYVZtVZF2i6XiZcHknw50iXvY7b0MiGoj5RwdgRQNEHdb+gPDPCXKlzwrybjFjkL6FOj8uRhZQ==", 1523 | "dev": true, 1524 | "requires": { 1525 | "chalk": "^4.0.0", 1526 | "ci-info": "^2.0.0", 1527 | "compare-versions": "^3.6.0", 1528 | "cosmiconfig": "^6.0.0", 1529 | "find-versions": "^3.2.0", 1530 | "opencollective-postinstall": "^2.0.2", 1531 | "pkg-dir": "^4.2.0", 1532 | "please-upgrade-node": "^3.2.0", 1533 | "slash": "^3.0.0", 1534 | "which-pm-runs": "^1.0.0" 1535 | } 1536 | }, 1537 | "ignore-walk": { 1538 | "version": "3.0.3", 1539 | "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.3.tgz", 1540 | "integrity": "sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw==", 1541 | "dev": true, 1542 | "requires": { 1543 | "minimatch": "^3.0.4" 1544 | } 1545 | }, 1546 | "import-fresh": { 1547 | "version": "3.2.1", 1548 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 1549 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 1550 | "dev": true, 1551 | "requires": { 1552 | "parent-module": "^1.0.0", 1553 | "resolve-from": "^4.0.0" 1554 | } 1555 | }, 1556 | "imurmurhash": { 1557 | "version": "0.1.4", 1558 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1559 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1560 | "dev": true 1561 | }, 1562 | "indent-string": { 1563 | "version": "4.0.0", 1564 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 1565 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 1566 | "dev": true 1567 | }, 1568 | "inflight": { 1569 | "version": "1.0.6", 1570 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1571 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1572 | "dev": true, 1573 | "requires": { 1574 | "once": "^1.3.0", 1575 | "wrappy": "1" 1576 | } 1577 | }, 1578 | "inherits": { 1579 | "version": "2.0.4", 1580 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1581 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1582 | "dev": true 1583 | }, 1584 | "is-arrayish": { 1585 | "version": "0.2.1", 1586 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1587 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1588 | "dev": true 1589 | }, 1590 | "is-binary-path": { 1591 | "version": "2.1.0", 1592 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1593 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1594 | "dev": true, 1595 | "requires": { 1596 | "binary-extensions": "^2.0.0" 1597 | } 1598 | }, 1599 | "is-buffer": { 1600 | "version": "2.0.4", 1601 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.4.tgz", 1602 | "integrity": "sha512-Kq1rokWXOPXWuaMAqZiJW4XxsmD9zGx9q4aePabbn3qCRGedtH7Cm+zV8WETitMfu1wdh+Rvd6w5egwSngUX2A==", 1603 | "dev": true 1604 | }, 1605 | "is-callable": { 1606 | "version": "1.1.5", 1607 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.5.tgz", 1608 | "integrity": "sha512-ESKv5sMCJB2jnHTWZ3O5itG+O128Hsus4K4Qh1h2/cgn2vbgnLSVqfV46AeJA9D5EeeLa9w81KUXMtn34zhX+Q==", 1609 | "dev": true 1610 | }, 1611 | "is-date-object": { 1612 | "version": "1.0.2", 1613 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 1614 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 1615 | "dev": true 1616 | }, 1617 | "is-extglob": { 1618 | "version": "2.1.1", 1619 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1620 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1621 | "dev": true 1622 | }, 1623 | "is-fullwidth-code-point": { 1624 | "version": "3.0.0", 1625 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1626 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1627 | "dev": true 1628 | }, 1629 | "is-glob": { 1630 | "version": "4.0.1", 1631 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1632 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1633 | "dev": true, 1634 | "requires": { 1635 | "is-extglob": "^2.1.1" 1636 | } 1637 | }, 1638 | "is-number": { 1639 | "version": "7.0.0", 1640 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1641 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1642 | "dev": true 1643 | }, 1644 | "is-obj": { 1645 | "version": "1.0.1", 1646 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 1647 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", 1648 | "dev": true 1649 | }, 1650 | "is-regex": { 1651 | "version": "1.0.5", 1652 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.5.tgz", 1653 | "integrity": "sha512-vlKW17SNq44owv5AQR3Cq0bQPEb8+kF3UKZ2fiZNOWtztYE5i0CzCZxFDwO58qAOWtxdBRVO/V5Qin1wjCqFYQ==", 1654 | "dev": true, 1655 | "requires": { 1656 | "has": "^1.0.3" 1657 | } 1658 | }, 1659 | "is-regexp": { 1660 | "version": "1.0.0", 1661 | "resolved": "https://registry.npmjs.org/is-regexp/-/is-regexp-1.0.0.tgz", 1662 | "integrity": "sha1-/S2INUXEa6xaYz57mgnof6LLUGk=", 1663 | "dev": true 1664 | }, 1665 | "is-stream": { 1666 | "version": "2.0.0", 1667 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 1668 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", 1669 | "dev": true 1670 | }, 1671 | "is-string": { 1672 | "version": "1.0.5", 1673 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz", 1674 | "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==", 1675 | "dev": true 1676 | }, 1677 | "is-symbol": { 1678 | "version": "1.0.3", 1679 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 1680 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 1681 | "dev": true, 1682 | "requires": { 1683 | "has-symbols": "^1.0.1" 1684 | } 1685 | }, 1686 | "is-typedarray": { 1687 | "version": "1.0.0", 1688 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1689 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1690 | "dev": true 1691 | }, 1692 | "is-windows": { 1693 | "version": "1.0.2", 1694 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1695 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", 1696 | "dev": true 1697 | }, 1698 | "isarray": { 1699 | "version": "0.0.1", 1700 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 1701 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 1702 | "dev": true 1703 | }, 1704 | "isexe": { 1705 | "version": "2.0.0", 1706 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1707 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1708 | "dev": true 1709 | }, 1710 | "istanbul-lib-coverage": { 1711 | "version": "3.0.0", 1712 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.0.0.tgz", 1713 | "integrity": "sha512-UiUIqxMgRDET6eR+o5HbfRYP1l0hqkWOs7vNxC/mggutCMUIhWMm8gAHb8tHlyfD3/l6rlgNA5cKdDzEAf6hEg==", 1714 | "dev": true 1715 | }, 1716 | "istanbul-lib-hook": { 1717 | "version": "3.0.0", 1718 | "resolved": "https://registry.npmjs.org/istanbul-lib-hook/-/istanbul-lib-hook-3.0.0.tgz", 1719 | "integrity": "sha512-Pt/uge1Q9s+5VAZ+pCo16TYMWPBIl+oaNIjgLQxcX0itS6ueeaA+pEfThZpH8WxhFgCiEb8sAJY6MdUKgiIWaQ==", 1720 | "dev": true, 1721 | "requires": { 1722 | "append-transform": "^2.0.0" 1723 | } 1724 | }, 1725 | "istanbul-lib-instrument": { 1726 | "version": "4.0.3", 1727 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-4.0.3.tgz", 1728 | "integrity": "sha512-BXgQl9kf4WTCPCCpmFGoJkz/+uhvm7h7PFKUYxh7qarQd3ER33vHG//qaE8eN25l07YqZPpHXU9I09l/RD5aGQ==", 1729 | "dev": true, 1730 | "requires": { 1731 | "@babel/core": "^7.7.5", 1732 | "@istanbuljs/schema": "^0.1.2", 1733 | "istanbul-lib-coverage": "^3.0.0", 1734 | "semver": "^6.3.0" 1735 | }, 1736 | "dependencies": { 1737 | "semver": { 1738 | "version": "6.3.1", 1739 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 1740 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 1741 | "dev": true 1742 | } 1743 | } 1744 | }, 1745 | "istanbul-lib-processinfo": { 1746 | "version": "2.0.2", 1747 | "resolved": "https://registry.npmjs.org/istanbul-lib-processinfo/-/istanbul-lib-processinfo-2.0.2.tgz", 1748 | "integrity": "sha512-kOwpa7z9hme+IBPZMzQ5vdQj8srYgAtaRqeI48NGmAQ+/5yKiHLV0QbYqQpxsdEF0+w14SoB8YbnHKcXE2KnYw==", 1749 | "dev": true, 1750 | "requires": { 1751 | "archy": "^1.0.0", 1752 | "cross-spawn": "^7.0.0", 1753 | "istanbul-lib-coverage": "^3.0.0-alpha.1", 1754 | "make-dir": "^3.0.0", 1755 | "p-map": "^3.0.0", 1756 | "rimraf": "^3.0.0", 1757 | "uuid": "^3.3.3" 1758 | }, 1759 | "dependencies": { 1760 | "p-map": { 1761 | "version": "3.0.0", 1762 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-3.0.0.tgz", 1763 | "integrity": "sha512-d3qXVTF/s+W+CdJ5A29wywV2n8CQQYahlgz2bFiA+4eVNJbHJodPZ+/gXwPGh0bOqA+j8S+6+ckmvLGPk1QpxQ==", 1764 | "dev": true, 1765 | "requires": { 1766 | "aggregate-error": "^3.0.0" 1767 | } 1768 | }, 1769 | "uuid": { 1770 | "version": "3.4.0", 1771 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 1772 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 1773 | "dev": true 1774 | } 1775 | } 1776 | }, 1777 | "istanbul-lib-report": { 1778 | "version": "3.0.0", 1779 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 1780 | "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", 1781 | "dev": true, 1782 | "requires": { 1783 | "istanbul-lib-coverage": "^3.0.0", 1784 | "make-dir": "^3.0.0", 1785 | "supports-color": "^7.1.0" 1786 | } 1787 | }, 1788 | "istanbul-lib-source-maps": { 1789 | "version": "4.0.0", 1790 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.0.tgz", 1791 | "integrity": "sha512-c16LpFRkR8vQXyHZ5nLpY35JZtzj1PQY1iZmesUbf1FZHbIupcWfjgOXBY9YHkLEQ6puz1u4Dgj6qmU/DisrZg==", 1792 | "dev": true, 1793 | "requires": { 1794 | "debug": "^4.1.1", 1795 | "istanbul-lib-coverage": "^3.0.0", 1796 | "source-map": "^0.6.1" 1797 | }, 1798 | "dependencies": { 1799 | "source-map": { 1800 | "version": "0.6.1", 1801 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1802 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1803 | "dev": true 1804 | } 1805 | } 1806 | }, 1807 | "istanbul-reports": { 1808 | "version": "3.0.2", 1809 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.0.2.tgz", 1810 | "integrity": "sha512-9tZvz7AiR3PEDNGiV9vIouQ/EAcqMXFmkcA1CDFTwOB98OZVDL0PH9glHotf5Ugp6GCOTypfzGWI/OqjWNCRUw==", 1811 | "dev": true, 1812 | "requires": { 1813 | "html-escaper": "^2.0.0", 1814 | "istanbul-lib-report": "^3.0.0" 1815 | } 1816 | }, 1817 | "jest-docblock": { 1818 | "version": "21.2.0", 1819 | "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-21.2.0.tgz", 1820 | "integrity": "sha512-5IZ7sY9dBAYSV+YjQ0Ovb540Ku7AO9Z5o2Cg789xj167iQuZ2cG+z0f3Uct6WeYLbU6aQiM2pCs7sZ+4dotydw==", 1821 | "dev": true 1822 | }, 1823 | "js-tokens": { 1824 | "version": "4.0.0", 1825 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1826 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1827 | "dev": true 1828 | }, 1829 | "js-yaml": { 1830 | "version": "3.13.1", 1831 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1832 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1833 | "dev": true, 1834 | "requires": { 1835 | "argparse": "^1.0.7", 1836 | "esprima": "^4.0.0" 1837 | } 1838 | }, 1839 | "jsesc": { 1840 | "version": "2.5.2", 1841 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 1842 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 1843 | "dev": true 1844 | }, 1845 | "json-parse-better-errors": { 1846 | "version": "1.0.2", 1847 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1848 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 1849 | "dev": true 1850 | }, 1851 | "json5": { 1852 | "version": "2.2.3", 1853 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 1854 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 1855 | "dev": true 1856 | }, 1857 | "lines-and-columns": { 1858 | "version": "1.1.6", 1859 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.1.6.tgz", 1860 | "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=", 1861 | "dev": true 1862 | }, 1863 | "lint-staged": { 1864 | "version": "10.2.6", 1865 | "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-10.2.6.tgz", 1866 | "integrity": "sha512-2oEBWyPZHkdyjKcIv2U6ay80Q52ZMlZZrUnfsV0WTVcgzPlt3o2t5UFy2v8ETUTsIDZ0xSJVnffWCgD3LF6xTQ==", 1867 | "dev": true, 1868 | "requires": { 1869 | "chalk": "^4.0.0", 1870 | "cli-truncate": "2.1.0", 1871 | "commander": "^5.1.0", 1872 | "cosmiconfig": "^6.0.0", 1873 | "debug": "^4.1.1", 1874 | "dedent": "^0.7.0", 1875 | "execa": "^4.0.1", 1876 | "listr2": "^2.0.2", 1877 | "log-symbols": "^4.0.0", 1878 | "micromatch": "^4.0.2", 1879 | "normalize-path": "^3.0.0", 1880 | "please-upgrade-node": "^3.2.0", 1881 | "string-argv": "0.3.1", 1882 | "stringify-object": "^3.3.0" 1883 | } 1884 | }, 1885 | "listr2": { 1886 | "version": "2.0.4", 1887 | "resolved": "https://registry.npmjs.org/listr2/-/listr2-2.0.4.tgz", 1888 | "integrity": "sha512-oJaAcplPsa72rKW0eg4P4LbEJjhH+UO2I8uqR/I2wzHrVg16ohSfUy0SlcHS21zfYXxtsUpL8YXGHjyfWMR0cg==", 1889 | "dev": true, 1890 | "requires": { 1891 | "@samverschueren/stream-to-observable": "^0.3.0", 1892 | "chalk": "^4.0.0", 1893 | "cli-cursor": "^3.1.0", 1894 | "cli-truncate": "^2.1.0", 1895 | "elegant-spinner": "^2.0.0", 1896 | "enquirer": "^2.3.5", 1897 | "figures": "^3.2.0", 1898 | "indent-string": "^4.0.0", 1899 | "log-update": "^4.0.0", 1900 | "p-map": "^4.0.0", 1901 | "pad": "^3.2.0", 1902 | "rxjs": "^6.5.5", 1903 | "through": "^2.3.8", 1904 | "uuid": "^7.0.2" 1905 | } 1906 | }, 1907 | "load-json-file": { 1908 | "version": "4.0.0", 1909 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 1910 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 1911 | "dev": true, 1912 | "requires": { 1913 | "graceful-fs": "^4.1.2", 1914 | "parse-json": "^4.0.0", 1915 | "pify": "^3.0.0", 1916 | "strip-bom": "^3.0.0" 1917 | }, 1918 | "dependencies": { 1919 | "parse-json": { 1920 | "version": "4.0.0", 1921 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1922 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 1923 | "dev": true, 1924 | "requires": { 1925 | "error-ex": "^1.3.1", 1926 | "json-parse-better-errors": "^1.0.1" 1927 | } 1928 | } 1929 | } 1930 | }, 1931 | "locate-path": { 1932 | "version": "5.0.0", 1933 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 1934 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 1935 | "dev": true, 1936 | "requires": { 1937 | "p-locate": "^4.1.0" 1938 | } 1939 | }, 1940 | "lodash": { 1941 | "version": "4.17.21", 1942 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1943 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 1944 | "dev": true 1945 | }, 1946 | "lodash.flattendeep": { 1947 | "version": "4.4.0", 1948 | "resolved": "https://registry.npmjs.org/lodash.flattendeep/-/lodash.flattendeep-4.4.0.tgz", 1949 | "integrity": "sha1-+wMJF/hqMTTlvJvsDWngAT3f7bI=", 1950 | "dev": true 1951 | }, 1952 | "lodash.once": { 1953 | "version": "4.1.1", 1954 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1955 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=", 1956 | "dev": true 1957 | }, 1958 | "log-symbols": { 1959 | "version": "4.0.0", 1960 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.0.0.tgz", 1961 | "integrity": "sha512-FN8JBzLx6CzeMrB0tg6pqlGU1wCrXW+ZXGH481kfsBqer0hToTIiHdjH4Mq8xJUbvATujKCvaREGWpGUionraA==", 1962 | "dev": true, 1963 | "requires": { 1964 | "chalk": "^4.0.0" 1965 | } 1966 | }, 1967 | "log-update": { 1968 | "version": "4.0.0", 1969 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", 1970 | "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", 1971 | "dev": true, 1972 | "requires": { 1973 | "ansi-escapes": "^4.3.0", 1974 | "cli-cursor": "^3.1.0", 1975 | "slice-ansi": "^4.0.0", 1976 | "wrap-ansi": "^6.2.0" 1977 | }, 1978 | "dependencies": { 1979 | "slice-ansi": { 1980 | "version": "4.0.0", 1981 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1982 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1983 | "dev": true, 1984 | "requires": { 1985 | "ansi-styles": "^4.0.0", 1986 | "astral-regex": "^2.0.0", 1987 | "is-fullwidth-code-point": "^3.0.0" 1988 | } 1989 | } 1990 | } 1991 | }, 1992 | "make-dir": { 1993 | "version": "3.1.0", 1994 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1995 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1996 | "dev": true, 1997 | "requires": { 1998 | "semver": "^6.0.0" 1999 | }, 2000 | "dependencies": { 2001 | "semver": { 2002 | "version": "6.3.1", 2003 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 2004 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 2005 | "dev": true 2006 | } 2007 | } 2008 | }, 2009 | "make-error": { 2010 | "version": "1.3.6", 2011 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 2012 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 2013 | "dev": true 2014 | }, 2015 | "memorystream": { 2016 | "version": "0.3.1", 2017 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 2018 | "integrity": "sha1-htcJCzDORV1j+64S3aUaR93K+bI=", 2019 | "dev": true 2020 | }, 2021 | "merge-stream": { 2022 | "version": "2.0.0", 2023 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 2024 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 2025 | "dev": true 2026 | }, 2027 | "micromatch": { 2028 | "version": "4.0.2", 2029 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.2.tgz", 2030 | "integrity": "sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q==", 2031 | "dev": true, 2032 | "requires": { 2033 | "braces": "^3.0.1", 2034 | "picomatch": "^2.0.5" 2035 | } 2036 | }, 2037 | "mimic-fn": { 2038 | "version": "2.1.0", 2039 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 2040 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 2041 | "dev": true 2042 | }, 2043 | "minimatch": { 2044 | "version": "3.0.4", 2045 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2046 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2047 | "dev": true, 2048 | "requires": { 2049 | "brace-expansion": "^1.1.7" 2050 | } 2051 | }, 2052 | "minimist": { 2053 | "version": "1.2.6", 2054 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 2055 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==" 2056 | }, 2057 | "mkdirp": { 2058 | "version": "0.5.5", 2059 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 2060 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 2061 | "requires": { 2062 | "minimist": "^1.2.5" 2063 | } 2064 | }, 2065 | "mocha": { 2066 | "version": "7.2.0", 2067 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-7.2.0.tgz", 2068 | "integrity": "sha512-O9CIypScywTVpNaRrCAgoUnJgozpIofjKUYmJhiCIJMiuYnLI6otcb1/kpW9/n/tJODHGZ7i8aLQoDVsMtOKQQ==", 2069 | "dev": true, 2070 | "requires": { 2071 | "ansi-colors": "3.2.3", 2072 | "browser-stdout": "1.3.1", 2073 | "chokidar": "3.3.0", 2074 | "debug": "3.2.6", 2075 | "diff": "3.5.0", 2076 | "escape-string-regexp": "1.0.5", 2077 | "find-up": "3.0.0", 2078 | "glob": "7.1.3", 2079 | "growl": "1.10.5", 2080 | "he": "1.2.0", 2081 | "js-yaml": "3.13.1", 2082 | "log-symbols": "3.0.0", 2083 | "minimatch": "3.0.4", 2084 | "mkdirp": "0.5.5", 2085 | "ms": "2.1.1", 2086 | "node-environment-flags": "1.0.6", 2087 | "object.assign": "4.1.0", 2088 | "strip-json-comments": "2.0.1", 2089 | "supports-color": "6.0.0", 2090 | "which": "1.3.1", 2091 | "wide-align": "1.1.3", 2092 | "yargs": "13.3.2", 2093 | "yargs-parser": "13.1.2", 2094 | "yargs-unparser": "1.6.0" 2095 | }, 2096 | "dependencies": { 2097 | "ansi-colors": { 2098 | "version": "3.2.3", 2099 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", 2100 | "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", 2101 | "dev": true 2102 | }, 2103 | "ansi-styles": { 2104 | "version": "3.2.1", 2105 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 2106 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 2107 | "dev": true, 2108 | "requires": { 2109 | "color-convert": "^1.9.0" 2110 | } 2111 | }, 2112 | "chalk": { 2113 | "version": "2.4.2", 2114 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 2115 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 2116 | "dev": true, 2117 | "requires": { 2118 | "ansi-styles": "^3.2.1", 2119 | "escape-string-regexp": "^1.0.5", 2120 | "supports-color": "^5.3.0" 2121 | }, 2122 | "dependencies": { 2123 | "supports-color": { 2124 | "version": "5.5.0", 2125 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2126 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2127 | "dev": true, 2128 | "requires": { 2129 | "has-flag": "^3.0.0" 2130 | } 2131 | } 2132 | } 2133 | }, 2134 | "color-convert": { 2135 | "version": "1.9.3", 2136 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2137 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2138 | "dev": true, 2139 | "requires": { 2140 | "color-name": "1.1.3" 2141 | } 2142 | }, 2143 | "color-name": { 2144 | "version": "1.1.3", 2145 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2146 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 2147 | "dev": true 2148 | }, 2149 | "debug": { 2150 | "version": "3.2.6", 2151 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 2152 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 2153 | "dev": true, 2154 | "requires": { 2155 | "ms": "^2.1.1" 2156 | } 2157 | }, 2158 | "find-up": { 2159 | "version": "3.0.0", 2160 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 2161 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 2162 | "dev": true, 2163 | "requires": { 2164 | "locate-path": "^3.0.0" 2165 | } 2166 | }, 2167 | "glob": { 2168 | "version": "7.1.3", 2169 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 2170 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 2171 | "dev": true, 2172 | "requires": { 2173 | "fs.realpath": "^1.0.0", 2174 | "inflight": "^1.0.4", 2175 | "inherits": "2", 2176 | "minimatch": "^3.0.4", 2177 | "once": "^1.3.0", 2178 | "path-is-absolute": "^1.0.0" 2179 | } 2180 | }, 2181 | "has-flag": { 2182 | "version": "3.0.0", 2183 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2184 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 2185 | "dev": true 2186 | }, 2187 | "locate-path": { 2188 | "version": "3.0.0", 2189 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 2190 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 2191 | "dev": true, 2192 | "requires": { 2193 | "p-locate": "^3.0.0", 2194 | "path-exists": "^3.0.0" 2195 | } 2196 | }, 2197 | "log-symbols": { 2198 | "version": "3.0.0", 2199 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-3.0.0.tgz", 2200 | "integrity": "sha512-dSkNGuI7iG3mfvDzUuYZyvk5dD9ocYCYzNU6CYDE6+Xqd+gwme6Z00NS3dUh8mq/73HaEtT7m6W+yUPtU6BZnQ==", 2201 | "dev": true, 2202 | "requires": { 2203 | "chalk": "^2.4.2" 2204 | } 2205 | }, 2206 | "ms": { 2207 | "version": "2.1.1", 2208 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2209 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 2210 | "dev": true 2211 | }, 2212 | "p-locate": { 2213 | "version": "3.0.0", 2214 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 2215 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 2216 | "dev": true, 2217 | "requires": { 2218 | "p-limit": "^2.0.0" 2219 | } 2220 | }, 2221 | "path-exists": { 2222 | "version": "3.0.0", 2223 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2224 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2225 | "dev": true 2226 | }, 2227 | "supports-color": { 2228 | "version": "6.0.0", 2229 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.0.0.tgz", 2230 | "integrity": "sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg==", 2231 | "dev": true, 2232 | "requires": { 2233 | "has-flag": "^3.0.0" 2234 | } 2235 | }, 2236 | "which": { 2237 | "version": "1.3.1", 2238 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2239 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2240 | "dev": true, 2241 | "requires": { 2242 | "isexe": "^2.0.0" 2243 | } 2244 | } 2245 | } 2246 | }, 2247 | "mocha-multi": { 2248 | "version": "1.1.3", 2249 | "resolved": "https://registry.npmjs.org/mocha-multi/-/mocha-multi-1.1.3.tgz", 2250 | "integrity": "sha512-bgjcxvfsMhNaRuXWiudidT8EREN6DRvHdzXqFLOdsLU9+oFTi4qiychVEQ3+TtwL9PwIqaiIastIF/tnVM7NYg==", 2251 | "dev": true, 2252 | "requires": { 2253 | "debug": "^4.1.1", 2254 | "is-string": "^1.0.4", 2255 | "lodash.once": "^4.1.1", 2256 | "mkdirp": "^0.5.1", 2257 | "object-assign": "^4.1.1" 2258 | } 2259 | }, 2260 | "ms": { 2261 | "version": "2.1.2", 2262 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2263 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2264 | "dev": true 2265 | }, 2266 | "nice-try": { 2267 | "version": "1.0.5", 2268 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 2269 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 2270 | "dev": true 2271 | }, 2272 | "node-environment-flags": { 2273 | "version": "1.0.6", 2274 | "resolved": "https://registry.npmjs.org/node-environment-flags/-/node-environment-flags-1.0.6.tgz", 2275 | "integrity": "sha512-5Evy2epuL+6TM0lCQGpFIj6KwiEsGh1SrHUhTbNX+sLbBtjidPZFAnVK9y5yU1+h//RitLbRHTIMyxQPtxMdHw==", 2276 | "dev": true, 2277 | "requires": { 2278 | "object.getownpropertydescriptors": "^2.0.3", 2279 | "semver": "^5.7.0" 2280 | } 2281 | }, 2282 | "node-fetch": { 2283 | "version": "2.6.7", 2284 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz", 2285 | "integrity": "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==", 2286 | "dev": true, 2287 | "requires": { 2288 | "whatwg-url": "^5.0.0" 2289 | } 2290 | }, 2291 | "node-preload": { 2292 | "version": "0.2.1", 2293 | "resolved": "https://registry.npmjs.org/node-preload/-/node-preload-0.2.1.tgz", 2294 | "integrity": "sha512-RM5oyBy45cLEoHqCeh+MNuFAxO0vTFBLskvQbOKnEE7YTTSN4tbN8QWDIPQ6L+WvKsB/qLEGpYe2ZZ9d4W9OIQ==", 2295 | "dev": true, 2296 | "requires": { 2297 | "process-on-spawn": "^1.0.0" 2298 | } 2299 | }, 2300 | "normalize-package-data": { 2301 | "version": "2.5.0", 2302 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 2303 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 2304 | "dev": true, 2305 | "requires": { 2306 | "hosted-git-info": "^2.1.4", 2307 | "resolve": "^1.10.0", 2308 | "semver": "2 || 3 || 4 || 5", 2309 | "validate-npm-package-license": "^3.0.1" 2310 | } 2311 | }, 2312 | "normalize-path": { 2313 | "version": "3.0.0", 2314 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2315 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2316 | "dev": true 2317 | }, 2318 | "npm-run-all": { 2319 | "version": "4.1.5", 2320 | "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", 2321 | "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", 2322 | "dev": true, 2323 | "requires": { 2324 | "ansi-styles": "^3.2.1", 2325 | "chalk": "^2.4.1", 2326 | "cross-spawn": "^6.0.5", 2327 | "memorystream": "^0.3.1", 2328 | "minimatch": "^3.0.4", 2329 | "pidtree": "^0.3.0", 2330 | "read-pkg": "^3.0.0", 2331 | "shell-quote": "^1.6.1", 2332 | "string.prototype.padend": "^3.0.0" 2333 | }, 2334 | "dependencies": { 2335 | "ansi-styles": { 2336 | "version": "3.2.1", 2337 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 2338 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 2339 | "dev": true, 2340 | "requires": { 2341 | "color-convert": "^1.9.0" 2342 | } 2343 | }, 2344 | "chalk": { 2345 | "version": "2.4.2", 2346 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 2347 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 2348 | "dev": true, 2349 | "requires": { 2350 | "ansi-styles": "^3.2.1", 2351 | "escape-string-regexp": "^1.0.5", 2352 | "supports-color": "^5.3.0" 2353 | } 2354 | }, 2355 | "color-convert": { 2356 | "version": "1.9.3", 2357 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2358 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2359 | "dev": true, 2360 | "requires": { 2361 | "color-name": "1.1.3" 2362 | } 2363 | }, 2364 | "color-name": { 2365 | "version": "1.1.3", 2366 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2367 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 2368 | "dev": true 2369 | }, 2370 | "cross-spawn": { 2371 | "version": "6.0.5", 2372 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 2373 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 2374 | "dev": true, 2375 | "requires": { 2376 | "nice-try": "^1.0.4", 2377 | "path-key": "^2.0.1", 2378 | "semver": "^5.5.0", 2379 | "shebang-command": "^1.2.0", 2380 | "which": "^1.2.9" 2381 | } 2382 | }, 2383 | "has-flag": { 2384 | "version": "3.0.0", 2385 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2386 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 2387 | "dev": true 2388 | }, 2389 | "path-key": { 2390 | "version": "2.0.1", 2391 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2392 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2393 | "dev": true 2394 | }, 2395 | "shebang-command": { 2396 | "version": "1.2.0", 2397 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2398 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2399 | "dev": true, 2400 | "requires": { 2401 | "shebang-regex": "^1.0.0" 2402 | } 2403 | }, 2404 | "shebang-regex": { 2405 | "version": "1.0.0", 2406 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2407 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2408 | "dev": true 2409 | }, 2410 | "supports-color": { 2411 | "version": "5.5.0", 2412 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2413 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2414 | "dev": true, 2415 | "requires": { 2416 | "has-flag": "^3.0.0" 2417 | } 2418 | }, 2419 | "which": { 2420 | "version": "1.3.1", 2421 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2422 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2423 | "dev": true, 2424 | "requires": { 2425 | "isexe": "^2.0.0" 2426 | } 2427 | } 2428 | } 2429 | }, 2430 | "npm-run-path": { 2431 | "version": "4.0.1", 2432 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 2433 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 2434 | "dev": true, 2435 | "requires": { 2436 | "path-key": "^3.0.0" 2437 | } 2438 | }, 2439 | "nyc": { 2440 | "version": "15.0.1", 2441 | "resolved": "https://registry.npmjs.org/nyc/-/nyc-15.0.1.tgz", 2442 | "integrity": "sha512-n0MBXYBYRqa67IVt62qW1r/d9UH/Qtr7SF1w/nQLJ9KxvWF6b2xCHImRAixHN9tnMMYHC2P14uo6KddNGwMgGg==", 2443 | "dev": true, 2444 | "requires": { 2445 | "@istanbuljs/load-nyc-config": "^1.0.0", 2446 | "@istanbuljs/schema": "^0.1.2", 2447 | "caching-transform": "^4.0.0", 2448 | "convert-source-map": "^1.7.0", 2449 | "decamelize": "^1.2.0", 2450 | "find-cache-dir": "^3.2.0", 2451 | "find-up": "^4.1.0", 2452 | "foreground-child": "^2.0.0", 2453 | "glob": "^7.1.6", 2454 | "istanbul-lib-coverage": "^3.0.0", 2455 | "istanbul-lib-hook": "^3.0.0", 2456 | "istanbul-lib-instrument": "^4.0.0", 2457 | "istanbul-lib-processinfo": "^2.0.2", 2458 | "istanbul-lib-report": "^3.0.0", 2459 | "istanbul-lib-source-maps": "^4.0.0", 2460 | "istanbul-reports": "^3.0.2", 2461 | "make-dir": "^3.0.0", 2462 | "node-preload": "^0.2.1", 2463 | "p-map": "^3.0.0", 2464 | "process-on-spawn": "^1.0.0", 2465 | "resolve-from": "^5.0.0", 2466 | "rimraf": "^3.0.0", 2467 | "signal-exit": "^3.0.2", 2468 | "spawn-wrap": "^2.0.0", 2469 | "test-exclude": "^6.0.0", 2470 | "yargs": "^15.0.2" 2471 | }, 2472 | "dependencies": { 2473 | "cliui": { 2474 | "version": "6.0.0", 2475 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", 2476 | "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", 2477 | "dev": true, 2478 | "requires": { 2479 | "string-width": "^4.2.0", 2480 | "strip-ansi": "^6.0.0", 2481 | "wrap-ansi": "^6.2.0" 2482 | } 2483 | }, 2484 | "p-map": { 2485 | "version": "3.0.0", 2486 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-3.0.0.tgz", 2487 | "integrity": "sha512-d3qXVTF/s+W+CdJ5A29wywV2n8CQQYahlgz2bFiA+4eVNJbHJodPZ+/gXwPGh0bOqA+j8S+6+ckmvLGPk1QpxQ==", 2488 | "dev": true, 2489 | "requires": { 2490 | "aggregate-error": "^3.0.0" 2491 | } 2492 | }, 2493 | "resolve-from": { 2494 | "version": "5.0.0", 2495 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 2496 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 2497 | "dev": true 2498 | }, 2499 | "yargs": { 2500 | "version": "15.3.1", 2501 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.3.1.tgz", 2502 | "integrity": "sha512-92O1HWEjw27sBfgmXiixJWT5hRBp2eobqXicLtPBIDBhYB+1HpwZlXmbW2luivBJHBzki+7VyCLRtAkScbTBQA==", 2503 | "dev": true, 2504 | "requires": { 2505 | "cliui": "^6.0.0", 2506 | "decamelize": "^1.2.0", 2507 | "find-up": "^4.1.0", 2508 | "get-caller-file": "^2.0.1", 2509 | "require-directory": "^2.1.1", 2510 | "require-main-filename": "^2.0.0", 2511 | "set-blocking": "^2.0.0", 2512 | "string-width": "^4.2.0", 2513 | "which-module": "^2.0.0", 2514 | "y18n": "^4.0.0", 2515 | "yargs-parser": "^18.1.1" 2516 | } 2517 | }, 2518 | "yargs-parser": { 2519 | "version": "18.1.3", 2520 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", 2521 | "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", 2522 | "dev": true, 2523 | "requires": { 2524 | "camelcase": "^5.0.0", 2525 | "decamelize": "^1.2.0" 2526 | } 2527 | } 2528 | } 2529 | }, 2530 | "object-assign": { 2531 | "version": "4.1.1", 2532 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2533 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 2534 | "dev": true 2535 | }, 2536 | "object-inspect": { 2537 | "version": "1.7.0", 2538 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.7.0.tgz", 2539 | "integrity": "sha512-a7pEHdh1xKIAgTySUGgLMx/xwDZskN1Ud6egYYN3EdRW4ZMPNEDUTF+hwy2LUC+Bl+SyLXANnwz/jyh/qutKUw==", 2540 | "dev": true 2541 | }, 2542 | "object-keys": { 2543 | "version": "1.1.1", 2544 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 2545 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 2546 | "dev": true 2547 | }, 2548 | "object.assign": { 2549 | "version": "4.1.0", 2550 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 2551 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 2552 | "dev": true, 2553 | "requires": { 2554 | "define-properties": "^1.1.2", 2555 | "function-bind": "^1.1.1", 2556 | "has-symbols": "^1.0.0", 2557 | "object-keys": "^1.0.11" 2558 | } 2559 | }, 2560 | "object.getownpropertydescriptors": { 2561 | "version": "2.1.0", 2562 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.0.tgz", 2563 | "integrity": "sha512-Z53Oah9A3TdLoblT7VKJaTDdXdT+lQO+cNpKVnya5JDe9uLvzu1YyY1yFDFrcxrlRgWrEFH0jJtD/IbuwjcEVg==", 2564 | "dev": true, 2565 | "requires": { 2566 | "define-properties": "^1.1.3", 2567 | "es-abstract": "^1.17.0-next.1" 2568 | } 2569 | }, 2570 | "once": { 2571 | "version": "1.4.0", 2572 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2573 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2574 | "dev": true, 2575 | "requires": { 2576 | "wrappy": "1" 2577 | } 2578 | }, 2579 | "onetime": { 2580 | "version": "5.1.0", 2581 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 2582 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 2583 | "dev": true, 2584 | "requires": { 2585 | "mimic-fn": "^2.1.0" 2586 | } 2587 | }, 2588 | "opencollective-postinstall": { 2589 | "version": "2.0.2", 2590 | "resolved": "https://registry.npmjs.org/opencollective-postinstall/-/opencollective-postinstall-2.0.2.tgz", 2591 | "integrity": "sha512-pVOEP16TrAO2/fjej1IdOyupJY8KDUM1CvsaScRbw6oddvpQoOfGk4ywha0HKKVAD6RkW4x6Q+tNBwhf3Bgpuw==", 2592 | "dev": true 2593 | }, 2594 | "p-limit": { 2595 | "version": "2.3.0", 2596 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 2597 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 2598 | "dev": true, 2599 | "requires": { 2600 | "p-try": "^2.0.0" 2601 | } 2602 | }, 2603 | "p-locate": { 2604 | "version": "4.1.0", 2605 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 2606 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 2607 | "dev": true, 2608 | "requires": { 2609 | "p-limit": "^2.2.0" 2610 | } 2611 | }, 2612 | "p-map": { 2613 | "version": "4.0.0", 2614 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 2615 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 2616 | "dev": true, 2617 | "requires": { 2618 | "aggregate-error": "^3.0.0" 2619 | } 2620 | }, 2621 | "p-try": { 2622 | "version": "2.2.0", 2623 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 2624 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 2625 | "dev": true 2626 | }, 2627 | "package-hash": { 2628 | "version": "4.0.0", 2629 | "resolved": "https://registry.npmjs.org/package-hash/-/package-hash-4.0.0.tgz", 2630 | "integrity": "sha512-whdkPIooSu/bASggZ96BWVvZTRMOFxnyUG5PnTSGKoJE2gd5mbVNmR2Nj20QFzxYYgAXpoqC+AiXzl+UMRh7zQ==", 2631 | "dev": true, 2632 | "requires": { 2633 | "graceful-fs": "^4.1.15", 2634 | "hasha": "^5.0.0", 2635 | "lodash.flattendeep": "^4.4.0", 2636 | "release-zalgo": "^1.0.0" 2637 | } 2638 | }, 2639 | "pad": { 2640 | "version": "3.2.0", 2641 | "resolved": "https://registry.npmjs.org/pad/-/pad-3.2.0.tgz", 2642 | "integrity": "sha512-2u0TrjcGbOjBTJpyewEl4hBO3OeX5wWue7eIFPzQTg6wFSvoaHcBTTUY5m+n0hd04gmTCPuY0kCpVIVuw5etwg==", 2643 | "dev": true, 2644 | "requires": { 2645 | "wcwidth": "^1.0.1" 2646 | } 2647 | }, 2648 | "parent-module": { 2649 | "version": "1.0.1", 2650 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2651 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2652 | "dev": true, 2653 | "requires": { 2654 | "callsites": "^3.0.0" 2655 | } 2656 | }, 2657 | "parse-json": { 2658 | "version": "5.0.0", 2659 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.0.0.tgz", 2660 | "integrity": "sha512-OOY5b7PAEFV0E2Fir1KOkxchnZNCdowAJgQ5NuxjpBKTRP3pQhwkrkxqQjeoKJ+fO7bCpmIZaogI4eZGDMEGOw==", 2661 | "dev": true, 2662 | "requires": { 2663 | "@babel/code-frame": "^7.0.0", 2664 | "error-ex": "^1.3.1", 2665 | "json-parse-better-errors": "^1.0.1", 2666 | "lines-and-columns": "^1.1.6" 2667 | } 2668 | }, 2669 | "path-exists": { 2670 | "version": "4.0.0", 2671 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2672 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2673 | "dev": true 2674 | }, 2675 | "path-is-absolute": { 2676 | "version": "1.0.1", 2677 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2678 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2679 | "dev": true 2680 | }, 2681 | "path-key": { 2682 | "version": "3.1.1", 2683 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2684 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2685 | "dev": true 2686 | }, 2687 | "path-parse": { 2688 | "version": "1.0.7", 2689 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2690 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2691 | "dev": true 2692 | }, 2693 | "path-type": { 2694 | "version": "4.0.0", 2695 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2696 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 2697 | "dev": true 2698 | }, 2699 | "pathval": { 2700 | "version": "1.1.1", 2701 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 2702 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 2703 | "dev": true 2704 | }, 2705 | "picomatch": { 2706 | "version": "2.2.2", 2707 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 2708 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 2709 | "dev": true 2710 | }, 2711 | "pidtree": { 2712 | "version": "0.3.1", 2713 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", 2714 | "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==", 2715 | "dev": true 2716 | }, 2717 | "pify": { 2718 | "version": "3.0.0", 2719 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 2720 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 2721 | "dev": true 2722 | }, 2723 | "pkg-dir": { 2724 | "version": "4.2.0", 2725 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 2726 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 2727 | "dev": true, 2728 | "requires": { 2729 | "find-up": "^4.0.0" 2730 | } 2731 | }, 2732 | "please-upgrade-node": { 2733 | "version": "3.2.0", 2734 | "resolved": "https://registry.npmjs.org/please-upgrade-node/-/please-upgrade-node-3.2.0.tgz", 2735 | "integrity": "sha512-gQR3WpIgNIKwBMVLkpMUeR3e1/E1y42bqDQZfql+kDeXd8COYfM8PQA4X6y7a8u9Ua9FHmsrrmirW2vHs45hWg==", 2736 | "dev": true, 2737 | "requires": { 2738 | "semver-compare": "^1.0.0" 2739 | } 2740 | }, 2741 | "prettier": { 2742 | "version": "2.0.5", 2743 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.0.5.tgz", 2744 | "integrity": "sha512-7PtVymN48hGcO4fGjybyBSIWDsLU4H4XlvOHfq91pz9kkGlonzwTfYkaIEwiRg/dAJF9YlbsduBAgtYLi+8cFg==", 2745 | "dev": true 2746 | }, 2747 | "process-on-spawn": { 2748 | "version": "1.0.0", 2749 | "resolved": "https://registry.npmjs.org/process-on-spawn/-/process-on-spawn-1.0.0.tgz", 2750 | "integrity": "sha512-1WsPDsUSMmZH5LeMLegqkPDrsGgsWwk1Exipy2hvB0o/F0ASzbpIctSCcZIK1ykJvtTJULEH+20WOFjMvGnCTg==", 2751 | "dev": true, 2752 | "requires": { 2753 | "fromentries": "^1.2.0" 2754 | } 2755 | }, 2756 | "properties": { 2757 | "version": "1.2.1", 2758 | "resolved": "https://registry.npmjs.org/properties/-/properties-1.2.1.tgz", 2759 | "integrity": "sha1-Dul6f8AgsaKlW4ZZ7aSqjYaQlL0=" 2760 | }, 2761 | "pump": { 2762 | "version": "3.0.0", 2763 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 2764 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 2765 | "dev": true, 2766 | "requires": { 2767 | "end-of-stream": "^1.1.0", 2768 | "once": "^1.3.1" 2769 | } 2770 | }, 2771 | "read-pkg": { 2772 | "version": "3.0.0", 2773 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 2774 | "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", 2775 | "dev": true, 2776 | "requires": { 2777 | "load-json-file": "^4.0.0", 2778 | "normalize-package-data": "^2.3.2", 2779 | "path-type": "^3.0.0" 2780 | }, 2781 | "dependencies": { 2782 | "path-type": { 2783 | "version": "3.0.0", 2784 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 2785 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 2786 | "dev": true, 2787 | "requires": { 2788 | "pify": "^3.0.0" 2789 | } 2790 | } 2791 | } 2792 | }, 2793 | "readdirp": { 2794 | "version": "3.2.0", 2795 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.2.0.tgz", 2796 | "integrity": "sha512-crk4Qu3pmXwgxdSgGhgA/eXiJAPQiX4GMOZZMXnqKxHX7TaoL+3gQVo/WeuAiogr07DpnfjIMpXXa+PAIvwPGQ==", 2797 | "dev": true, 2798 | "requires": { 2799 | "picomatch": "^2.0.4" 2800 | } 2801 | }, 2802 | "release-zalgo": { 2803 | "version": "1.0.0", 2804 | "resolved": "https://registry.npmjs.org/release-zalgo/-/release-zalgo-1.0.0.tgz", 2805 | "integrity": "sha1-CXALflB0Mpc5Mw5TXFqQ+2eFFzA=", 2806 | "dev": true, 2807 | "requires": { 2808 | "es6-error": "^4.0.1" 2809 | } 2810 | }, 2811 | "require-directory": { 2812 | "version": "2.1.1", 2813 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2814 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 2815 | "dev": true 2816 | }, 2817 | "require-main-filename": { 2818 | "version": "2.0.0", 2819 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 2820 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 2821 | "dev": true 2822 | }, 2823 | "resolve": { 2824 | "version": "1.17.0", 2825 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", 2826 | "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", 2827 | "dev": true, 2828 | "requires": { 2829 | "path-parse": "^1.0.6" 2830 | } 2831 | }, 2832 | "resolve-from": { 2833 | "version": "4.0.0", 2834 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2835 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2836 | "dev": true 2837 | }, 2838 | "restore-cursor": { 2839 | "version": "3.1.0", 2840 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 2841 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 2842 | "dev": true, 2843 | "requires": { 2844 | "onetime": "^5.1.0", 2845 | "signal-exit": "^3.0.2" 2846 | } 2847 | }, 2848 | "rimraf": { 2849 | "version": "3.0.2", 2850 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2851 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2852 | "dev": true, 2853 | "requires": { 2854 | "glob": "^7.1.3" 2855 | } 2856 | }, 2857 | "rxjs": { 2858 | "version": "6.5.5", 2859 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.5.tgz", 2860 | "integrity": "sha512-WfQI+1gohdf0Dai/Bbmk5L5ItH5tYqm3ki2c5GdWhKjalzjg93N3avFjVStyZZz+A2Em+ZxKH5bNghw9UeylGQ==", 2861 | "dev": true, 2862 | "requires": { 2863 | "tslib": "^1.9.0" 2864 | } 2865 | }, 2866 | "safe-buffer": { 2867 | "version": "5.1.2", 2868 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2869 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2870 | "dev": true 2871 | }, 2872 | "semver": { 2873 | "version": "5.7.2", 2874 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", 2875 | "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", 2876 | "dev": true 2877 | }, 2878 | "semver-compare": { 2879 | "version": "1.0.0", 2880 | "resolved": "https://registry.npmjs.org/semver-compare/-/semver-compare-1.0.0.tgz", 2881 | "integrity": "sha1-De4hahyUGrN+nvsXiPavxf9VN/w=", 2882 | "dev": true 2883 | }, 2884 | "semver-regex": { 2885 | "version": "2.0.0", 2886 | "resolved": "https://registry.npmjs.org/semver-regex/-/semver-regex-2.0.0.tgz", 2887 | "integrity": "sha512-mUdIBBvdn0PLOeP3TEkMH7HHeUP3GjsXCwKarjv/kGmUFOYg1VqEemKhoQpWMu6X2I8kHeuVdGibLGkVK+/5Qw==", 2888 | "dev": true 2889 | }, 2890 | "set-blocking": { 2891 | "version": "2.0.0", 2892 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2893 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 2894 | "dev": true 2895 | }, 2896 | "shebang-command": { 2897 | "version": "2.0.0", 2898 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2899 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2900 | "dev": true, 2901 | "requires": { 2902 | "shebang-regex": "^3.0.0" 2903 | } 2904 | }, 2905 | "shebang-regex": { 2906 | "version": "3.0.0", 2907 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2908 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2909 | "dev": true 2910 | }, 2911 | "shell-quote": { 2912 | "version": "1.7.3", 2913 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.3.tgz", 2914 | "integrity": "sha512-Vpfqwm4EnqGdlsBFNmHhxhElJYrdfcxPThu+ryKS5J8L/fhAwLazFZtq+S+TWZ9ANj2piSQLGj6NQg+lKPmxrw==", 2915 | "dev": true 2916 | }, 2917 | "signal-exit": { 2918 | "version": "3.0.3", 2919 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 2920 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 2921 | "dev": true 2922 | }, 2923 | "slash": { 2924 | "version": "3.0.0", 2925 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 2926 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 2927 | "dev": true 2928 | }, 2929 | "slice-ansi": { 2930 | "version": "3.0.0", 2931 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-3.0.0.tgz", 2932 | "integrity": "sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ==", 2933 | "dev": true, 2934 | "requires": { 2935 | "ansi-styles": "^4.0.0", 2936 | "astral-regex": "^2.0.0", 2937 | "is-fullwidth-code-point": "^3.0.0" 2938 | } 2939 | }, 2940 | "source-map": { 2941 | "version": "0.5.7", 2942 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2943 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2944 | "dev": true 2945 | }, 2946 | "source-map-support": { 2947 | "version": "0.5.19", 2948 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.19.tgz", 2949 | "integrity": "sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw==", 2950 | "dev": true, 2951 | "requires": { 2952 | "buffer-from": "^1.0.0", 2953 | "source-map": "^0.6.0" 2954 | }, 2955 | "dependencies": { 2956 | "source-map": { 2957 | "version": "0.6.1", 2958 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2959 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2960 | "dev": true 2961 | } 2962 | } 2963 | }, 2964 | "spawn-wrap": { 2965 | "version": "2.0.0", 2966 | "resolved": "https://registry.npmjs.org/spawn-wrap/-/spawn-wrap-2.0.0.tgz", 2967 | "integrity": "sha512-EeajNjfN9zMnULLwhZZQU3GWBoFNkbngTUPfaawT4RkMiviTxcX0qfhVbGey39mfctfDHkWtuecgQ8NJcyQWHg==", 2968 | "dev": true, 2969 | "requires": { 2970 | "foreground-child": "^2.0.0", 2971 | "is-windows": "^1.0.2", 2972 | "make-dir": "^3.0.0", 2973 | "rimraf": "^3.0.0", 2974 | "signal-exit": "^3.0.2", 2975 | "which": "^2.0.1" 2976 | } 2977 | }, 2978 | "spdx-correct": { 2979 | "version": "3.1.1", 2980 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", 2981 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", 2982 | "dev": true, 2983 | "requires": { 2984 | "spdx-expression-parse": "^3.0.0", 2985 | "spdx-license-ids": "^3.0.0" 2986 | } 2987 | }, 2988 | "spdx-exceptions": { 2989 | "version": "2.3.0", 2990 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 2991 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 2992 | "dev": true 2993 | }, 2994 | "spdx-expression-parse": { 2995 | "version": "3.0.1", 2996 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 2997 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 2998 | "dev": true, 2999 | "requires": { 3000 | "spdx-exceptions": "^2.1.0", 3001 | "spdx-license-ids": "^3.0.0" 3002 | } 3003 | }, 3004 | "spdx-license-ids": { 3005 | "version": "3.0.5", 3006 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", 3007 | "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==", 3008 | "dev": true 3009 | }, 3010 | "sprintf-js": { 3011 | "version": "1.0.3", 3012 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 3013 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 3014 | "dev": true 3015 | }, 3016 | "stream-events": { 3017 | "version": "1.0.5", 3018 | "resolved": "https://registry.npmjs.org/stream-events/-/stream-events-1.0.5.tgz", 3019 | "integrity": "sha512-E1GUzBSgvct8Jsb3v2X15pjzN1tYebtbLaMg+eBOUOAxgbLoSbT2NS91ckc5lJD1KfLjId+jXJRgo0qnV5Nerg==", 3020 | "dev": true, 3021 | "requires": { 3022 | "stubs": "^3.0.0" 3023 | } 3024 | }, 3025 | "string-argv": { 3026 | "version": "0.3.1", 3027 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 3028 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 3029 | "dev": true 3030 | }, 3031 | "string-width": { 3032 | "version": "4.2.0", 3033 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 3034 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 3035 | "dev": true, 3036 | "requires": { 3037 | "emoji-regex": "^8.0.0", 3038 | "is-fullwidth-code-point": "^3.0.0", 3039 | "strip-ansi": "^6.0.0" 3040 | } 3041 | }, 3042 | "string.prototype.padend": { 3043 | "version": "3.1.0", 3044 | "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.0.tgz", 3045 | "integrity": "sha512-3aIv8Ffdp8EZj8iLwREGpQaUZiPyrWrpzMBHvkiSW/bK/EGve9np07Vwy7IJ5waydpGXzQZu/F8Oze2/IWkBaA==", 3046 | "dev": true, 3047 | "requires": { 3048 | "define-properties": "^1.1.3", 3049 | "es-abstract": "^1.17.0-next.1" 3050 | } 3051 | }, 3052 | "string.prototype.trimend": { 3053 | "version": "1.0.1", 3054 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz", 3055 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==", 3056 | "dev": true, 3057 | "requires": { 3058 | "define-properties": "^1.1.3", 3059 | "es-abstract": "^1.17.5" 3060 | } 3061 | }, 3062 | "string.prototype.trimleft": { 3063 | "version": "2.1.2", 3064 | "resolved": "https://registry.npmjs.org/string.prototype.trimleft/-/string.prototype.trimleft-2.1.2.tgz", 3065 | "integrity": "sha512-gCA0tza1JBvqr3bfAIFJGqfdRTyPae82+KTnm3coDXkZN9wnuW3HjGgN386D7hfv5CHQYCI022/rJPVlqXyHSw==", 3066 | "dev": true, 3067 | "requires": { 3068 | "define-properties": "^1.1.3", 3069 | "es-abstract": "^1.17.5", 3070 | "string.prototype.trimstart": "^1.0.0" 3071 | } 3072 | }, 3073 | "string.prototype.trimright": { 3074 | "version": "2.1.2", 3075 | "resolved": "https://registry.npmjs.org/string.prototype.trimright/-/string.prototype.trimright-2.1.2.tgz", 3076 | "integrity": "sha512-ZNRQ7sY3KroTaYjRS6EbNiiHrOkjihL9aQE/8gfQ4DtAC/aEBRHFJa44OmoWxGGqXuJlfKkZW4WcXErGr+9ZFg==", 3077 | "dev": true, 3078 | "requires": { 3079 | "define-properties": "^1.1.3", 3080 | "es-abstract": "^1.17.5", 3081 | "string.prototype.trimend": "^1.0.0" 3082 | } 3083 | }, 3084 | "string.prototype.trimstart": { 3085 | "version": "1.0.1", 3086 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz", 3087 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==", 3088 | "dev": true, 3089 | "requires": { 3090 | "define-properties": "^1.1.3", 3091 | "es-abstract": "^1.17.5" 3092 | } 3093 | }, 3094 | "stringify-object": { 3095 | "version": "3.3.0", 3096 | "resolved": "https://registry.npmjs.org/stringify-object/-/stringify-object-3.3.0.tgz", 3097 | "integrity": "sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw==", 3098 | "dev": true, 3099 | "requires": { 3100 | "get-own-enumerable-property-symbols": "^3.0.0", 3101 | "is-obj": "^1.0.1", 3102 | "is-regexp": "^1.0.0" 3103 | } 3104 | }, 3105 | "strip-ansi": { 3106 | "version": "6.0.0", 3107 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 3108 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 3109 | "dev": true, 3110 | "requires": { 3111 | "ansi-regex": "^5.0.0" 3112 | } 3113 | }, 3114 | "strip-bom": { 3115 | "version": "3.0.0", 3116 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 3117 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 3118 | "dev": true 3119 | }, 3120 | "strip-final-newline": { 3121 | "version": "2.0.0", 3122 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 3123 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 3124 | "dev": true 3125 | }, 3126 | "strip-json-comments": { 3127 | "version": "2.0.1", 3128 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 3129 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 3130 | "dev": true 3131 | }, 3132 | "stubs": { 3133 | "version": "3.0.0", 3134 | "resolved": "https://registry.npmjs.org/stubs/-/stubs-3.0.0.tgz", 3135 | "integrity": "sha1-6NK6H6nJBXAwPAMLaQD31fiavls=", 3136 | "dev": true 3137 | }, 3138 | "supports-color": { 3139 | "version": "7.1.0", 3140 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 3141 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 3142 | "dev": true, 3143 | "requires": { 3144 | "has-flag": "^4.0.0" 3145 | } 3146 | }, 3147 | "teeny-request": { 3148 | "version": "6.0.1", 3149 | "resolved": "https://registry.npmjs.org/teeny-request/-/teeny-request-6.0.1.tgz", 3150 | "integrity": "sha512-TAK0c9a00ELOqLrZ49cFxvPVogMUFaWY8dUsQc/0CuQPGF+BOxOQzXfE413BAk2kLomwNplvdtMpeaeGWmoc2g==", 3151 | "dev": true, 3152 | "requires": { 3153 | "http-proxy-agent": "^4.0.0", 3154 | "https-proxy-agent": "^4.0.0", 3155 | "node-fetch": "^2.2.0", 3156 | "stream-events": "^1.0.5", 3157 | "uuid": "^3.3.2" 3158 | }, 3159 | "dependencies": { 3160 | "uuid": { 3161 | "version": "3.4.0", 3162 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 3163 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 3164 | "dev": true 3165 | } 3166 | } 3167 | }, 3168 | "test-exclude": { 3169 | "version": "6.0.0", 3170 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 3171 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 3172 | "dev": true, 3173 | "requires": { 3174 | "@istanbuljs/schema": "^0.1.2", 3175 | "glob": "^7.1.4", 3176 | "minimatch": "^3.0.4" 3177 | } 3178 | }, 3179 | "through": { 3180 | "version": "2.3.8", 3181 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 3182 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 3183 | "dev": true 3184 | }, 3185 | "to-fast-properties": { 3186 | "version": "2.0.0", 3187 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 3188 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 3189 | "dev": true 3190 | }, 3191 | "to-regex-range": { 3192 | "version": "5.0.1", 3193 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3194 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3195 | "dev": true, 3196 | "requires": { 3197 | "is-number": "^7.0.0" 3198 | } 3199 | }, 3200 | "tr46": { 3201 | "version": "0.0.3", 3202 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 3203 | "integrity": "sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o=", 3204 | "dev": true 3205 | }, 3206 | "ts-node": { 3207 | "version": "8.10.1", 3208 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-8.10.1.tgz", 3209 | "integrity": "sha512-bdNz1L4ekHiJul6SHtZWs1ujEKERJnHs4HxN7rjTyyVOFf3HaJ6sLqe6aPG62XTzAB/63pKRh5jTSWL0D7bsvw==", 3210 | "dev": true, 3211 | "requires": { 3212 | "arg": "^4.1.0", 3213 | "diff": "^4.0.1", 3214 | "make-error": "^1.1.1", 3215 | "source-map-support": "^0.5.17", 3216 | "yn": "3.1.1" 3217 | }, 3218 | "dependencies": { 3219 | "diff": { 3220 | "version": "4.0.2", 3221 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 3222 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 3223 | "dev": true 3224 | } 3225 | } 3226 | }, 3227 | "tsconfig-paths": { 3228 | "version": "3.10.1", 3229 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.10.1.tgz", 3230 | "integrity": "sha512-rETidPDgCpltxF7MjBZlAFPUHv5aHH2MymyPvh+vEyWAED4Eb/WeMbsnD/JDr4OKPOA1TssDHgIcpTN5Kh0p6Q==", 3231 | "dev": true, 3232 | "requires": { 3233 | "json5": "^2.2.0", 3234 | "minimist": "^1.2.0", 3235 | "strip-bom": "^3.0.0" 3236 | } 3237 | }, 3238 | "tslib": { 3239 | "version": "1.13.0", 3240 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.13.0.tgz", 3241 | "integrity": "sha512-i/6DQjL8Xf3be4K/E6Wgpekn5Qasl1usyw++dAA35Ue5orEn65VIxOA+YvNNl9HV3qv70T7CNwjODHZrLwvd1Q==", 3242 | "dev": true 3243 | }, 3244 | "tslint": { 3245 | "version": "6.1.2", 3246 | "resolved": "https://registry.npmjs.org/tslint/-/tslint-6.1.2.tgz", 3247 | "integrity": "sha512-UyNrLdK3E0fQG/xWNqAFAC5ugtFyPO4JJR1KyyfQAyzR8W0fTRrC91A8Wej4BntFzcvETdCSDa/4PnNYJQLYiA==", 3248 | "dev": true, 3249 | "requires": { 3250 | "@babel/code-frame": "^7.0.0", 3251 | "builtin-modules": "^1.1.1", 3252 | "chalk": "^2.3.0", 3253 | "commander": "^2.12.1", 3254 | "diff": "^4.0.1", 3255 | "glob": "^7.1.1", 3256 | "js-yaml": "^3.13.1", 3257 | "minimatch": "^3.0.4", 3258 | "mkdirp": "^0.5.3", 3259 | "resolve": "^1.3.2", 3260 | "semver": "^5.3.0", 3261 | "tslib": "^1.10.0", 3262 | "tsutils": "^2.29.0" 3263 | }, 3264 | "dependencies": { 3265 | "ansi-styles": { 3266 | "version": "3.2.1", 3267 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 3268 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 3269 | "dev": true, 3270 | "requires": { 3271 | "color-convert": "^1.9.0" 3272 | } 3273 | }, 3274 | "chalk": { 3275 | "version": "2.4.2", 3276 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 3277 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 3278 | "dev": true, 3279 | "requires": { 3280 | "ansi-styles": "^3.2.1", 3281 | "escape-string-regexp": "^1.0.5", 3282 | "supports-color": "^5.3.0" 3283 | } 3284 | }, 3285 | "color-convert": { 3286 | "version": "1.9.3", 3287 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 3288 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 3289 | "dev": true, 3290 | "requires": { 3291 | "color-name": "1.1.3" 3292 | } 3293 | }, 3294 | "color-name": { 3295 | "version": "1.1.3", 3296 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 3297 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 3298 | "dev": true 3299 | }, 3300 | "commander": { 3301 | "version": "2.20.3", 3302 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 3303 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 3304 | "dev": true 3305 | }, 3306 | "diff": { 3307 | "version": "4.0.2", 3308 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 3309 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 3310 | "dev": true 3311 | }, 3312 | "has-flag": { 3313 | "version": "3.0.0", 3314 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 3315 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 3316 | "dev": true 3317 | }, 3318 | "supports-color": { 3319 | "version": "5.5.0", 3320 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3321 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3322 | "dev": true, 3323 | "requires": { 3324 | "has-flag": "^3.0.0" 3325 | } 3326 | } 3327 | } 3328 | }, 3329 | "tslint-config-prettier": { 3330 | "version": "1.18.0", 3331 | "resolved": "https://registry.npmjs.org/tslint-config-prettier/-/tslint-config-prettier-1.18.0.tgz", 3332 | "integrity": "sha512-xPw9PgNPLG3iKRxmK7DWr+Ea/SzrvfHtjFt5LBl61gk2UBG/DB9kCXRjv+xyIU1rUtnayLeMUVJBcMX8Z17nDg==", 3333 | "dev": true 3334 | }, 3335 | "tslint-eslint-rules": { 3336 | "version": "5.4.0", 3337 | "resolved": "https://registry.npmjs.org/tslint-eslint-rules/-/tslint-eslint-rules-5.4.0.tgz", 3338 | "integrity": "sha512-WlSXE+J2vY/VPgIcqQuijMQiel+UtmXS+4nvK4ZzlDiqBfXse8FAvkNnTcYhnQyOTW5KFM+uRRGXxYhFpuBc6w==", 3339 | "dev": true, 3340 | "requires": { 3341 | "doctrine": "0.7.2", 3342 | "tslib": "1.9.0", 3343 | "tsutils": "^3.0.0" 3344 | }, 3345 | "dependencies": { 3346 | "tslib": { 3347 | "version": "1.9.0", 3348 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.0.tgz", 3349 | "integrity": "sha512-f/qGG2tUkrISBlQZEjEqoZ3B2+npJjIf04H1wuAv9iA8i04Icp+61KRXxFdha22670NJopsZCIjhC3SnjPRKrQ==", 3350 | "dev": true 3351 | }, 3352 | "tsutils": { 3353 | "version": "3.17.1", 3354 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.17.1.tgz", 3355 | "integrity": "sha512-kzeQ5B8H3w60nFY2g8cJIuH7JDpsALXySGtwGJ0p2LSjLgay3NdIpqq5SoOBe46bKDW2iq25irHCr8wjomUS2g==", 3356 | "dev": true, 3357 | "requires": { 3358 | "tslib": "^1.8.1" 3359 | } 3360 | } 3361 | } 3362 | }, 3363 | "tslint-plugin-prettier": { 3364 | "version": "2.3.0", 3365 | "resolved": "https://registry.npmjs.org/tslint-plugin-prettier/-/tslint-plugin-prettier-2.3.0.tgz", 3366 | "integrity": "sha512-F9e4K03yc9xuvv+A0v1EmjcnDwpz8SpCD8HzqSDe0eyg34cBinwn9JjmnnRrNAs4HdleRQj7qijp+P/JTxt4vA==", 3367 | "dev": true, 3368 | "requires": { 3369 | "eslint-plugin-prettier": "^2.2.0", 3370 | "lines-and-columns": "^1.1.6", 3371 | "tslib": "^1.7.1" 3372 | } 3373 | }, 3374 | "tsutils": { 3375 | "version": "2.29.0", 3376 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-2.29.0.tgz", 3377 | "integrity": "sha512-g5JVHCIJwzfISaXpXE1qvNalca5Jwob6FjI4AoPlqMusJ6ftFE7IkkFoMhVLRgK+4Kx3gkzb8UZK5t5yTTvEmA==", 3378 | "dev": true, 3379 | "requires": { 3380 | "tslib": "^1.8.1" 3381 | } 3382 | }, 3383 | "type-detect": { 3384 | "version": "4.0.8", 3385 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3386 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3387 | "dev": true 3388 | }, 3389 | "type-fest": { 3390 | "version": "0.11.0", 3391 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz", 3392 | "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==", 3393 | "dev": true 3394 | }, 3395 | "typedarray-to-buffer": { 3396 | "version": "3.1.5", 3397 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 3398 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 3399 | "dev": true, 3400 | "requires": { 3401 | "is-typedarray": "^1.0.0" 3402 | } 3403 | }, 3404 | "typescript": { 3405 | "version": "3.9.3", 3406 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.3.tgz", 3407 | "integrity": "sha512-D/wqnB2xzNFIcoBG9FG8cXRDjiqSTbG2wd8DMZeQyJlP1vfTkIxH4GKveWaEBYySKIg+USu+E+EDIR47SqnaMQ==", 3408 | "dev": true 3409 | }, 3410 | "urlgrey": { 3411 | "version": "0.4.4", 3412 | "resolved": "https://registry.npmjs.org/urlgrey/-/urlgrey-0.4.4.tgz", 3413 | "integrity": "sha1-iS/pWWCAXoVRnxzUOJ8stMu3ZS8=", 3414 | "dev": true 3415 | }, 3416 | "uuid": { 3417 | "version": "7.0.3", 3418 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-7.0.3.tgz", 3419 | "integrity": "sha512-DPSke0pXhTZgoF/d+WSt2QaKMCFSfx7QegxEWT+JOuHF5aWrKEn0G+ztjuJg/gG8/ItK+rbPCD/yNv8yyih6Cg==" 3420 | }, 3421 | "validate-npm-package-license": { 3422 | "version": "3.0.4", 3423 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 3424 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 3425 | "dev": true, 3426 | "requires": { 3427 | "spdx-correct": "^3.0.0", 3428 | "spdx-expression-parse": "^3.0.0" 3429 | } 3430 | }, 3431 | "wcwidth": { 3432 | "version": "1.0.1", 3433 | "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz", 3434 | "integrity": "sha1-8LDc+RW8X/FSivrbLA4XtTLaL+g=", 3435 | "dev": true, 3436 | "requires": { 3437 | "defaults": "^1.0.3" 3438 | } 3439 | }, 3440 | "webidl-conversions": { 3441 | "version": "3.0.1", 3442 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 3443 | "integrity": "sha1-JFNCdeKnvGvnvIZhHMFq4KVlSHE=", 3444 | "dev": true 3445 | }, 3446 | "whatwg-url": { 3447 | "version": "5.0.0", 3448 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 3449 | "integrity": "sha1-lmRU6HZUYuN2RNNib2dCzotwll0=", 3450 | "dev": true, 3451 | "requires": { 3452 | "tr46": "~0.0.3", 3453 | "webidl-conversions": "^3.0.0" 3454 | } 3455 | }, 3456 | "which": { 3457 | "version": "2.0.2", 3458 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3459 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3460 | "dev": true, 3461 | "requires": { 3462 | "isexe": "^2.0.0" 3463 | } 3464 | }, 3465 | "which-module": { 3466 | "version": "2.0.0", 3467 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 3468 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 3469 | "dev": true 3470 | }, 3471 | "which-pm-runs": { 3472 | "version": "1.0.0", 3473 | "resolved": "https://registry.npmjs.org/which-pm-runs/-/which-pm-runs-1.0.0.tgz", 3474 | "integrity": "sha1-Zws6+8VS4LVd9rd4DKdGFfI60cs=", 3475 | "dev": true 3476 | }, 3477 | "wide-align": { 3478 | "version": "1.1.3", 3479 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 3480 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 3481 | "dev": true, 3482 | "requires": { 3483 | "string-width": "^1.0.2 || 2" 3484 | }, 3485 | "dependencies": { 3486 | "ansi-regex": { 3487 | "version": "3.0.1", 3488 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.1.tgz", 3489 | "integrity": "sha512-+O9Jct8wf++lXxxFc4hc8LsjaSq0HFzzL7cVsw8pRDIPdjKD2mT4ytDZlLuSBZ4cLKZFXIrMGO7DbQCtMJJMKw==", 3490 | "dev": true 3491 | }, 3492 | "is-fullwidth-code-point": { 3493 | "version": "2.0.0", 3494 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 3495 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 3496 | "dev": true 3497 | }, 3498 | "string-width": { 3499 | "version": "2.1.1", 3500 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 3501 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 3502 | "dev": true, 3503 | "requires": { 3504 | "is-fullwidth-code-point": "^2.0.0", 3505 | "strip-ansi": "^4.0.0" 3506 | } 3507 | }, 3508 | "strip-ansi": { 3509 | "version": "4.0.0", 3510 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 3511 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 3512 | "dev": true, 3513 | "requires": { 3514 | "ansi-regex": "^3.0.0" 3515 | } 3516 | } 3517 | } 3518 | }, 3519 | "wrap-ansi": { 3520 | "version": "6.2.0", 3521 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 3522 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 3523 | "dev": true, 3524 | "requires": { 3525 | "ansi-styles": "^4.0.0", 3526 | "string-width": "^4.1.0", 3527 | "strip-ansi": "^6.0.0" 3528 | } 3529 | }, 3530 | "wrappy": { 3531 | "version": "1.0.2", 3532 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3533 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3534 | "dev": true 3535 | }, 3536 | "write-file-atomic": { 3537 | "version": "3.0.3", 3538 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 3539 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 3540 | "dev": true, 3541 | "requires": { 3542 | "imurmurhash": "^0.1.4", 3543 | "is-typedarray": "^1.0.0", 3544 | "signal-exit": "^3.0.2", 3545 | "typedarray-to-buffer": "^3.1.5" 3546 | } 3547 | }, 3548 | "y18n": { 3549 | "version": "4.0.1", 3550 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.1.tgz", 3551 | "integrity": "sha512-wNcy4NvjMYL8gogWWYAO7ZFWFfHcbdbE57tZO8e4cbpj8tfUcwrwqSl3ad8HxpYWCdXcJUCeKKZS62Av1affwQ==", 3552 | "dev": true 3553 | }, 3554 | "yaml": { 3555 | "version": "1.10.0", 3556 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.0.tgz", 3557 | "integrity": "sha512-yr2icI4glYaNG+KWONODapy2/jDdMSDnrONSjblABjD9B4Z5LgiircSt8m8sRZFNi08kG9Sm0uSHtEmP3zaEGg==", 3558 | "dev": true 3559 | }, 3560 | "yargs": { 3561 | "version": "13.3.2", 3562 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", 3563 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", 3564 | "dev": true, 3565 | "requires": { 3566 | "cliui": "^5.0.0", 3567 | "find-up": "^3.0.0", 3568 | "get-caller-file": "^2.0.1", 3569 | "require-directory": "^2.1.1", 3570 | "require-main-filename": "^2.0.0", 3571 | "set-blocking": "^2.0.0", 3572 | "string-width": "^3.0.0", 3573 | "which-module": "^2.0.0", 3574 | "y18n": "^4.0.0", 3575 | "yargs-parser": "^13.1.2" 3576 | }, 3577 | "dependencies": { 3578 | "ansi-regex": { 3579 | "version": "4.1.1", 3580 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.1.tgz", 3581 | "integrity": "sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g==", 3582 | "dev": true 3583 | }, 3584 | "emoji-regex": { 3585 | "version": "7.0.3", 3586 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 3587 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 3588 | "dev": true 3589 | }, 3590 | "find-up": { 3591 | "version": "3.0.0", 3592 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 3593 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 3594 | "dev": true, 3595 | "requires": { 3596 | "locate-path": "^3.0.0" 3597 | } 3598 | }, 3599 | "is-fullwidth-code-point": { 3600 | "version": "2.0.0", 3601 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 3602 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 3603 | "dev": true 3604 | }, 3605 | "locate-path": { 3606 | "version": "3.0.0", 3607 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 3608 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 3609 | "dev": true, 3610 | "requires": { 3611 | "p-locate": "^3.0.0", 3612 | "path-exists": "^3.0.0" 3613 | } 3614 | }, 3615 | "p-locate": { 3616 | "version": "3.0.0", 3617 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 3618 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 3619 | "dev": true, 3620 | "requires": { 3621 | "p-limit": "^2.0.0" 3622 | } 3623 | }, 3624 | "path-exists": { 3625 | "version": "3.0.0", 3626 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 3627 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 3628 | "dev": true 3629 | }, 3630 | "string-width": { 3631 | "version": "3.1.0", 3632 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 3633 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 3634 | "dev": true, 3635 | "requires": { 3636 | "emoji-regex": "^7.0.1", 3637 | "is-fullwidth-code-point": "^2.0.0", 3638 | "strip-ansi": "^5.1.0" 3639 | } 3640 | }, 3641 | "strip-ansi": { 3642 | "version": "5.2.0", 3643 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 3644 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 3645 | "dev": true, 3646 | "requires": { 3647 | "ansi-regex": "^4.1.0" 3648 | } 3649 | } 3650 | } 3651 | }, 3652 | "yargs-parser": { 3653 | "version": "13.1.2", 3654 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", 3655 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", 3656 | "dev": true, 3657 | "requires": { 3658 | "camelcase": "^5.0.0", 3659 | "decamelize": "^1.2.0" 3660 | } 3661 | }, 3662 | "yargs-unparser": { 3663 | "version": "1.6.0", 3664 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.0.tgz", 3665 | "integrity": "sha512-W9tKgmSn0DpSatfri0nx52Joq5hVXgeLiqR/5G0sZNDoLZFOr/xjBUDcShCOGNsBnEMNo1KAMBkTej1Hm62HTw==", 3666 | "dev": true, 3667 | "requires": { 3668 | "flat": "^4.1.0", 3669 | "lodash": "^4.17.15", 3670 | "yargs": "^13.3.0" 3671 | } 3672 | }, 3673 | "yn": { 3674 | "version": "3.1.1", 3675 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 3676 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 3677 | "dev": true 3678 | } 3679 | } 3680 | } 3681 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "ts-test-decorators", 3 | "version": "0.0.6", 4 | "description": "Write your tests in a Java-like annotation-driven manner via JS decorators.", 5 | "main": "dist/src/index.js", 6 | "types": "dist/src/index.d.ts", 7 | "keywords": [ 8 | "mocha", 9 | "typescript", 10 | "allure", 11 | "decorator" 12 | ], 13 | "author": "Sergey Korol", 14 | "license": "Apache-2.0", 15 | "repository": "https://github.com/sskorol/ts-test-decorators", 16 | "bugs": "https://github.com/sskorol/ts-test-decorators/issues", 17 | "homepage": "https://github.com/sskorol/ts-test-decorators#README.md", 18 | "scripts": { 19 | "build": "tsc", 20 | "clean": "rimraf ./dist ./allure-results ./.allure-report ./coverage ./.nyc_output", 21 | "test": "run-s clean tslint && tsc -p ./tests/tsconfig.json && nyc mocha", 22 | "generate-report": "allure generate ./allure-results -o ./.allure-report --clean", 23 | "serve-report": "allure serve ./allure-results", 24 | "allure": "run-s generate-report serve-report", 25 | "coverage": "codecov", 26 | "tslint-fix": "tslint --fix --project .", 27 | "tslint": "tslint ./src/**/*.ts ./tests/**/*.ts", 28 | "precommit": "lint-staged", 29 | "postcommit": "git update-index -g" 30 | }, 31 | "peerDependencies": { 32 | "@testdeck/mocha": "^0.1.0", 33 | "allure-mocha": "2.0.0-beta.7", 34 | "allure-js-commons": "2.0.0-beta.7" 35 | }, 36 | "dependencies": { 37 | "allure-js-commons": "2.0.0-beta.7" 38 | }, 39 | "devDependencies": { 40 | "@testdeck/mocha": "^0.1.0", 41 | "@types/chai": "^4.2.11", 42 | "@types/mocha": "^7.0.2", 43 | "@types/node": "^13.13.4", 44 | "allure-mocha": "2.0.0-beta.7", 45 | "allure-commandline": "^2.13.0", 46 | "chai": "^4.2.0", 47 | "codecov": "^3.6.5", 48 | "dotenv": "^8.2.0", 49 | "fs-jetpack": "^2.2.3", 50 | "glob": "^7.1.6", 51 | "husky": "^4.2.5", 52 | "lint-staged": "^10.2.2", 53 | "mocha": "^7.1.2", 54 | "mocha-multi": "^1.1.3", 55 | "npm-run-all": "^4.1.5", 56 | "nyc": "^15.0.1", 57 | "prettier": "^2.0.5", 58 | "rimraf": "^3.0.2", 59 | "source-map-support": "^0.5.19", 60 | "ts-node": "^8.9.1", 61 | "tsconfig-paths": "^3.9.0", 62 | "tslint": "^6.1.2", 63 | "tslint-config-prettier": "^1.18.0", 64 | "tslint-eslint-rules": "^5.4.0", 65 | "tslint-plugin-prettier": "^2.3.0", 66 | "typescript": "^3.8.3" 67 | }, 68 | "nyc": { 69 | "check-coverage": true, 70 | "lines": 95, 71 | "statements": 95, 72 | "functions": 95, 73 | "branches": 75, 74 | "extension": [ 75 | ".ts" 76 | ], 77 | "exclude": [ 78 | "tests/**/*.*", 79 | "**/*.d.ts" 80 | ], 81 | "reporter": [ 82 | "lcov", 83 | "text" 84 | ], 85 | "all": true 86 | }, 87 | "lint-staged": { 88 | "*.{ts,tsx}": [ 89 | "prettier --parser typescript --write", 90 | "git add" 91 | ] 92 | } 93 | } 94 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | import { ContentType, Severity, Allure } from 'allure-js-commons' 2 | 3 | const defaultTrackerAddress: string = 'http://localhost' 4 | let pmsUrl: string = defaultTrackerAddress 5 | let tmsUrl: string = defaultTrackerAddress 6 | let allure: Allure 7 | 8 | /** 9 | * This code was partially cloned from testdeck/core package and improved to support missing features. 10 | */ 11 | const nodeSymbol: (key: string) => string = (key): string => '__testdeck_' + key 12 | const testNameSymbol: string = nodeSymbol('name') 13 | const parametersSymbol: string = nodeSymbol('parametersSymbol') 14 | const nameForParametersSymbol: string = nodeSymbol('nameForParameters') 15 | 16 | type Params = any | ((arg?: any) => any) 17 | type Execution = undefined | 'pending' | 'only' | 'skip' | 'execution' 18 | type TestDecorator = (target: object, property: string, descriptor: PropertyDescriptor) => PropertyDescriptor 19 | type ParamsDecorator = (params: Params, name?: string) => TestDecorator 20 | 21 | interface ParameterizedPropertyDescriptor extends PropertyDescriptor { 22 | (params: Params, name?: string): MethodDecorator 23 | 24 | skip(params: Params, name?: string): MethodDecorator 25 | 26 | only(params: Params, name?: string): MethodDecorator 27 | 28 | pending(params: Params, name?: string): MethodDecorator 29 | 30 | naming(nameForParameters: (params: Params) => string): MethodDecorator 31 | } 32 | 33 | const enum LinkType { 34 | issue = 'issue', 35 | tms = 'tms', 36 | } 37 | 38 | export const data: ParameterizedPropertyDescriptor = makeParamsObject() 39 | 40 | export function step(nameFn: string | ((arg: T) => string)): TestDecorator { 41 | return (target: object, propertyKey: string, descriptor: PropertyDescriptor) => { 42 | const original: object = descriptor.value 43 | let callable: (args: T) => void = () => {} 44 | 45 | if (typeof original === 'function') { 46 | descriptor.value = function (...args: [T]) { 47 | try { 48 | const value: string = typeof nameFn === 'function' ? nameFn.apply(this, args) : nameFn 49 | callable = () => getAllure().step(value, () => original.apply(this, args)) 50 | } catch (e) { 51 | // tslint:disable-next-line:no-console 52 | console.error(`[ERROR] Failed to apply decorator: ${e}`) 53 | } 54 | return callable.apply(this, args) 55 | } 56 | } 57 | return descriptor 58 | } 59 | } 60 | 61 | export function attachment(name: string, type: ContentType) { 62 | return (target: object, propertyKey: string, descriptor: PropertyDescriptor) => { 63 | const original: object = descriptor.value 64 | let callable: (args: T) => void = () => {} 65 | 66 | if (typeof original === 'function') { 67 | descriptor.value = function (...args: [T]) { 68 | try { 69 | const content: Buffer | string = original.apply(this, args) 70 | callable = () => getAllure().attachment(name, content, type) 71 | } catch (e) { 72 | // tslint:disable-next-line:no-console 73 | console.error(`[ERROR] Failed to apply decorator: ${e}`) 74 | } 75 | return callable.apply(this, args) 76 | } 77 | } 78 | return descriptor 79 | } 80 | } 81 | 82 | export function testCaseId(idFn: string | ((arg: T) => string)): TestDecorator { 83 | return processDecorator(idFn, (id) => getAllure().link(`${tmsUrl}/${id}`, id, LinkType.tms)) 84 | } 85 | 86 | export function issue(idFn: string | ((arg: T) => string)): TestDecorator { 87 | return processDecorator(idFn, (id) => getAllure().link(`${pmsUrl}/${id}`, id, LinkType.issue)) 88 | } 89 | 90 | export function feature(featureFn: string | ((arg: T) => string)): TestDecorator { 91 | return processDecorator(featureFn, (name) => getAllure().feature(name)) 92 | } 93 | 94 | export function story(storyFn: string | ((arg: T) => string)): TestDecorator { 95 | return processDecorator(storyFn, (name) => getAllure().story(name)) 96 | } 97 | 98 | export function severity(severityFn: Severity | string | ((arg: T) => string | Severity)): TestDecorator { 99 | return processDecorator(severityFn, (name) => getAllure().severity(name)) 100 | } 101 | 102 | export function tag(tagFn: string | ((arg: T) => string)): TestDecorator { 103 | return processDecorator(tagFn, (name) => getAllure().tag(name)) 104 | } 105 | 106 | export function owner(ownerFn: string | ((arg: T) => string)): TestDecorator { 107 | return processDecorator(ownerFn, (name) => getAllure().owner(name)) 108 | } 109 | 110 | export function epic(epicFn: string | ((arg: T) => string)): TestDecorator { 111 | return processDecorator(epicFn, (name) => getAllure().epic(name)) 112 | } 113 | 114 | export function description(descriptionFn: string | ((arg: T) => string)): TestDecorator { 115 | return processDecorator(descriptionFn, (text) => getAllure().description(text)) 116 | } 117 | 118 | export function assignTmsUrl(url: string): void { 119 | tmsUrl = url 120 | } 121 | 122 | export function assignPmsUrl(url: string): void { 123 | pmsUrl = url 124 | } 125 | 126 | export function decorate(allureInstance: T): void { 127 | allure = allureInstance 128 | } 129 | 130 | function getAllure(): T { 131 | if (!allure) { 132 | throw new Error('Unable to find Allure implementation') 133 | } 134 | return allure as T 135 | } 136 | 137 | function processDescriptor( 138 | parameterFn: string | ((arg: T) => string), 139 | reporterFn: (arg: string) => void, 140 | descriptor: PropertyDescriptor 141 | ): PropertyDescriptor { 142 | const original: object = descriptor.value 143 | if (typeof original === 'function') { 144 | descriptor.value = function (...args: [T]) { 145 | try { 146 | const value: string = typeof parameterFn === 'function' ? parameterFn.apply(this, args) : parameterFn 147 | reporterFn(value) 148 | } catch (e) { 149 | // tslint:disable-next-line:no-console 150 | console.error(`[ERROR] Failed to apply decorator: ${e}`) 151 | } 152 | return original.apply(this, args) 153 | } 154 | } 155 | 156 | for (const prop of Object.keys(original)) { 157 | if (original.hasOwnProperty(prop) && prop.startsWith('__testdeck_')) { 158 | descriptor.value[prop] = original[prop] 159 | } 160 | } 161 | 162 | return descriptor 163 | } 164 | 165 | function makeParamsFunction(execution?: Execution): ParamsDecorator { 166 | return (params: Params, name?: string) => { 167 | return (target: object, propertyKey: string, descriptor: PropertyDescriptor) => { 168 | const adjustedParams = typeof params === 'function' ? params() : params 169 | target[propertyKey][testNameSymbol] = propertyKey.toString() 170 | target[propertyKey][parametersSymbol] = target[propertyKey][parametersSymbol] || [] 171 | ;[].concat(adjustedParams || []).forEach((param) => { 172 | target[propertyKey][parametersSymbol].push({ execution, name, params: param }) 173 | }) 174 | return processDescriptor( 175 | (args) => JSON.stringify(args), 176 | (arg) => getAllure().parameter('inputs', arg), 177 | descriptor 178 | ) 179 | } 180 | } 181 | } 182 | 183 | function makeParamsNameFunction(): any { 184 | return (nameForParameters: (params: Params) => string) => { 185 | return (target: object, propertyKey: string, descriptor: PropertyDescriptor) => { 186 | target[propertyKey][nameForParametersSymbol] = nameForParameters 187 | return descriptor 188 | } 189 | } 190 | } 191 | 192 | function makeParamsObject(): any { 193 | return Object.assign(makeParamsFunction(), { 194 | only: makeParamsFunction('only'), 195 | pending: makeParamsFunction('pending'), 196 | skip: makeParamsFunction('skip'), 197 | naming: makeParamsNameFunction(), 198 | }) 199 | } 200 | 201 | function processDecorator( 202 | parameterFn: string | ((arg: T) => string), 203 | reporterFn: (arg: string) => void 204 | ): TestDecorator { 205 | return (target: object, property: string, descriptor: PropertyDescriptor) => { 206 | return processDescriptor(parameterFn, reporterFn, descriptor) 207 | } 208 | } 209 | -------------------------------------------------------------------------------- /tests/fixtures/specs/attachment.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { attachment, step } from '../../../src' 3 | import { ContentType } from 'allure-js-commons' 4 | import { BaseTest } from './baseTest' 5 | 6 | @suite 7 | class Attachment extends BaseTest { 8 | @attachment('Test attachment', ContentType.TEXT) 9 | public testAttachment() { 10 | return 'Attachment 1' 11 | } 12 | 13 | @attachment('Step attachment', ContentType.TEXT) 14 | public stepAttachment() { 15 | return 'Attachment 2' 16 | } 17 | 18 | @step('Step with attachment') 19 | public testStep() { 20 | this.stepAttachment() 21 | } 22 | 23 | @test 24 | shouldAssignDecoratedAttachment() { 25 | this.testAttachment() 26 | this.testStep() 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /tests/fixtures/specs/baseTest.ts: -------------------------------------------------------------------------------- 1 | import { assignPmsUrl, assignTmsUrl, decorate } from '../../../src' 2 | import { allure, MochaAllure } from 'allure-mocha/runtime' 3 | 4 | export class BaseTest { 5 | public before() { 6 | const gitHubUrl: string = 'https://github.com/sskorol/ts-test-decorators/issues' 7 | assignPmsUrl(gitHubUrl) 8 | assignTmsUrl(gitHubUrl) 9 | decorate(allure) 10 | } 11 | } 12 | -------------------------------------------------------------------------------- /tests/fixtures/specs/description.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { description } from '../../../src' 3 | import { BaseTest } from './baseTest' 4 | 5 | @suite 6 | class Description extends BaseTest { 7 | @description('Decorated description') 8 | @test 9 | shouldAssignDecoratedDescription() {} 10 | } 11 | -------------------------------------------------------------------------------- /tests/fixtures/specs/epic.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { epic } from '../../../src' 3 | import { BaseTest } from './baseTest' 4 | 5 | @suite 6 | class Epic extends BaseTest { 7 | @epic('Epic Name') 8 | @test 9 | shouldAssignDecoratedEpic() {} 10 | } 11 | -------------------------------------------------------------------------------- /tests/fixtures/specs/feature.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { feature } from '../../../src' 3 | import { BaseTest } from './baseTest' 4 | 5 | @suite 6 | class Feature extends BaseTest { 7 | @feature('Decorated Feature') 8 | @test 9 | shouldAssignDecoratedFeature() {} 10 | } 11 | -------------------------------------------------------------------------------- /tests/fixtures/specs/issueAndTms.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { issue, testCaseId } from '../../../src' 3 | import { BaseTest } from './baseTest' 4 | 5 | @suite 6 | class IssueAndTms extends BaseTest { 7 | @issue('4') 8 | @testCaseId('5') 9 | @test 10 | shouldAssignDecoratedIssueAndTms() {} 11 | } 12 | -------------------------------------------------------------------------------- /tests/fixtures/specs/missingAllure.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { decorate, description } from '../../../src' 3 | import { Allure } from 'allure-js-commons' 4 | 5 | @suite 6 | export class MissingAllure { 7 | // Emulate missing Allure instance 8 | before() { 9 | decorate((null as unknown) as Allure) 10 | } 11 | 12 | @description('Will not be handled without Allure instance') 13 | @test 14 | public shouldFailDecoratingMethodWithoutAllure() {} 15 | } 16 | -------------------------------------------------------------------------------- /tests/fixtures/specs/owner.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { owner } from '../../../src' 3 | import { BaseTest } from './baseTest' 4 | 5 | @suite 6 | class Owner extends BaseTest { 7 | @owner('Sergey Korol') 8 | @test 9 | shouldAssignDecoratedOwner() {} 10 | } 11 | -------------------------------------------------------------------------------- /tests/fixtures/specs/severity.ts: -------------------------------------------------------------------------------- 1 | import { Severity } from 'allure-js-commons' 2 | import { suite, test } from '@testdeck/mocha' 3 | import { severity } from '../../../src' 4 | import { BaseTest } from './baseTest' 5 | 6 | @suite 7 | class SeveritySubSuite extends BaseTest { 8 | @severity(Severity.CRITICAL) 9 | @test 10 | shouldAssignDecoratedSeverity() {} 11 | } 12 | -------------------------------------------------------------------------------- /tests/fixtures/specs/step.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { step } from '../../../src' 3 | import { BaseTest } from './baseTest' 4 | 5 | @suite 6 | class Step extends BaseTest { 7 | @test 8 | shouldAddDecoratedSteps() { 9 | this.step1() 10 | this.step2() 11 | this.step3() 12 | this.step5().step1() 13 | } 14 | 15 | @test 16 | shouldFailDecoratingStep() { 17 | this.step7() 18 | } 19 | 20 | @step('Execute step 1') 21 | step1() {} 22 | 23 | @step('Execute step 2') 24 | step2() { 25 | this.step3() 26 | } 27 | 28 | @step('Execute step 3') 29 | step3() { 30 | this.step4() 31 | } 32 | 33 | @step('Execute step 4') 34 | step4() {} 35 | 36 | @step('Execute step 5') 37 | step5() { 38 | return this.step6() 39 | } 40 | 41 | @step(() => 'Execute step 6') 42 | step6() { 43 | return this 44 | } 45 | 46 | @step(() => { 47 | throw new Error('Step is broken') 48 | }) 49 | step7() { 50 | return this 51 | } 52 | } 53 | -------------------------------------------------------------------------------- /tests/fixtures/specs/story.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { story } from '../../../src' 3 | import { BaseTest } from './baseTest' 4 | 5 | @suite 6 | class Story extends BaseTest { 7 | @story('Common decorated story') 8 | @test 9 | shouldAssignDecoratedStory() {} 10 | } 11 | -------------------------------------------------------------------------------- /tests/fixtures/specs/tag.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { tag } from '../../../src' 3 | import { BaseTest } from './baseTest' 4 | 5 | @suite 6 | class Tag extends BaseTest { 7 | @tag('regression') 8 | @test 9 | shouldAssignDecoratedTag() {} 10 | } 11 | -------------------------------------------------------------------------------- /tests/fixtures/specs/testData.ts: -------------------------------------------------------------------------------- 1 | import { suite, test } from '@testdeck/mocha' 2 | import { data } from '../../../src' 3 | import { User } from '../../model/User' 4 | import { BaseTest } from './baseTest' 5 | 6 | @suite 7 | class TestData extends BaseTest { 8 | static testData = () => { 9 | return new User('Test', 'User') 10 | } 11 | 12 | @data(TestData.testData) 13 | @data.naming((value: User) => `shouldCall${value.toString()}DataOnTest`) 14 | @test 15 | shouldCallDataOnTest(value: User) {} 16 | 17 | @data('') 18 | shouldNotBeExecuted(value: string) {} 19 | } 20 | -------------------------------------------------------------------------------- /tests/model/User.ts: -------------------------------------------------------------------------------- 1 | export class User { 2 | constructor(readonly firstName: string, readonly lastName: string) {} 3 | 4 | toString(): string { 5 | return `${this.firstName}${this.lastName}` 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /tests/specs/attachment.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findSteps, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class AttachmentSuite { 8 | before() { 9 | cleanResults() 10 | runTests('attachment') 11 | } 12 | 13 | @test 14 | shouldHaveAttachment() { 15 | return whenResultsAppeared().then(() => { 16 | expect(findTest('Attachment')).not.eq(undefined) 17 | const currentTest = findTest('shouldAssignDecoratedAttachment') 18 | const steps = findSteps(currentTest.name) 19 | expect(currentTest.status).eq(Status.PASSED) 20 | expect(currentTest.attachments.length).eq(1) 21 | expect(currentTest.attachments[0].name).eq('Test attachment') 22 | expect(currentTest.attachments[0].type).eq('text/plain') 23 | expect(steps.length).eq(1) 24 | expect(steps[0].attachments.length).eq(1) 25 | expect(steps[0].attachments[0].name).eq('Step attachment') 26 | expect(steps[0].attachments[0].type).eq('text/plain') 27 | }) 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /tests/specs/description.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class DescriptionSuite { 8 | before() { 9 | cleanResults() 10 | runTests('description') 11 | } 12 | 13 | @test 14 | shouldHaveDescription() { 15 | return whenResultsAppeared().then(() => { 16 | expect(findTest('Description')).not.eq(undefined) 17 | const currentTest = findTest('shouldAssignDecoratedDescription') 18 | expect(currentTest.status).eq(Status.PASSED) 19 | expect(currentTest.description).eq('Decorated description') 20 | }) 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /tests/specs/epic.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findLabel, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class EpicSuite { 8 | before() { 9 | cleanResults() 10 | runTests('epic') 11 | } 12 | 13 | @test 14 | shouldHaveEpic() { 15 | const testName = 'shouldAssignDecoratedEpic' 16 | return whenResultsAppeared().then(() => { 17 | expect(findTest('Epic')).not.eq(undefined) 18 | expect(findTest(testName).status).eq(Status.PASSED) 19 | expect(findLabel(testName, 'epic').value).eq('Epic Name') 20 | }) 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /tests/specs/feature.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findLabel, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class FeatureSuite { 8 | before() { 9 | cleanResults() 10 | runTests('feature') 11 | } 12 | 13 | @test 14 | shouldHaveFeature() { 15 | const testName = 'shouldAssignDecoratedFeature' 16 | return whenResultsAppeared().then(() => { 17 | expect(findTest('Feature')).not.eq(undefined) 18 | expect(findTest(testName).status).eq(Status.PASSED) 19 | expect(findLabel(testName, 'feature').value).eq('Decorated Feature') 20 | }) 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /tests/specs/issueAndTms.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findLinks, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class IssueAndTmsSuite { 8 | before() { 9 | cleanResults() 10 | runTests('issueAndTms') 11 | } 12 | 13 | @test 14 | shouldHaveIssueAndTmsLinks() { 15 | const testName = 'shouldAssignDecoratedIssueAndTms' 16 | return whenResultsAppeared().then(() => { 17 | expect(findTest('IssueAndTms')).not.eq(undefined) 18 | 19 | const links = findLinks(testName) 20 | expect(links).length(2) 21 | expect(findTest(testName).status).eq(Status.PASSED) 22 | 23 | const gitHubUrl: string = 'https://github.com/sskorol/ts-test-decorators/issues' 24 | expect(links.map((link) => link.name)).contains('4', '5') 25 | expect(links.map((link) => link.url)).contains(`${gitHubUrl}/4`, `${gitHubUrl}/5`) 26 | expect(links.map((link) => link.type)).contains('issue', 'tms') 27 | }) 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /tests/specs/missingAllure.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class MissingAllureSuite { 8 | before() { 9 | cleanResults() 10 | runTests('missingAllure') 11 | } 12 | 13 | @test 14 | shouldNotFailTestWithoutAllure() { 15 | return whenResultsAppeared().then(() => { 16 | expect(findTest('MissingAllure')).not.eq(undefined) 17 | const currentTest = findTest('shouldFailDecoratingMethodWithoutAllure') 18 | expect(currentTest.status).eq(Status.PASSED) 19 | expect(currentTest.description).eq(undefined) 20 | }) 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /tests/specs/owner.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findLabel, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class OwnerSuite { 8 | before() { 9 | cleanResults() 10 | runTests('owner') 11 | } 12 | 13 | @test 14 | shouldHaveOwner() { 15 | const testName = 'shouldAssignDecoratedOwner' 16 | return whenResultsAppeared().then(() => { 17 | expect(findTest('Owner')).not.eq(undefined) 18 | expect(findTest(testName).status).eq(Status.PASSED) 19 | expect(findLabel(testName, 'owner').value).eq('Sergey Korol') 20 | }) 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /tests/specs/severity.ts: -------------------------------------------------------------------------------- 1 | import { Severity, Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findLabel, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class SeveritySuite { 8 | before() { 9 | cleanResults() 10 | runTests('severity') 11 | } 12 | 13 | @test 14 | shouldHaveSeverity() { 15 | const testName = 'shouldAssignDecoratedSeverity' 16 | return whenResultsAppeared().then(() => { 17 | expect(findTest('SeveritySubSuite')).not.eq(undefined) 18 | expect(findTest(testName).status).eq(Status.PASSED) 19 | expect(findLabel(testName, 'severity').value).eq(Severity.CRITICAL) 20 | }) 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /tests/specs/step.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findSteps, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class StepSuite { 8 | before() { 9 | cleanResults() 10 | runTests('step') 11 | } 12 | 13 | @test 14 | shouldHaveSteps() { 15 | const passedTestName = 'shouldAddDecoratedSteps' 16 | const testNameWithFailedDecorator = 'shouldFailDecoratingStep' 17 | 18 | return whenResultsAppeared().then(() => { 19 | expect(findTest('Step')).not.eq(undefined) 20 | expect(findTest(passedTestName).status).eq(Status.PASSED) 21 | 22 | const steps = findSteps(passedTestName) 23 | expect(steps.map((step) => step.name)).deep.eq([ 24 | 'Execute step 1', 25 | 'Execute step 2', 26 | 'Execute step 3', 27 | 'Execute step 5', 28 | 'Execute step 1', 29 | ]) 30 | expect(steps.map((step) => step.status)).contains(Status.PASSED) 31 | 32 | let subStep = steps.find((step) => step.name === 'Execute step 2').steps.pop() 33 | expect(subStep.name).eq('Execute step 3') 34 | expect(subStep.status).eq(Status.PASSED) 35 | 36 | subStep = subStep.steps.pop() 37 | expect(subStep.name).eq('Execute step 4') 38 | expect(subStep.status).eq(Status.PASSED) 39 | 40 | subStep = steps.find((step) => step.name === 'Execute step 3').steps.pop() 41 | expect(subStep.name).eq('Execute step 4') 42 | expect(subStep.status).eq(Status.PASSED) 43 | 44 | subStep = steps.find((step) => step.name === 'Execute step 5').steps.pop() 45 | expect(subStep.name).eq('Execute step 6') 46 | expect(subStep.status).eq(Status.PASSED) 47 | 48 | expect(findTest(testNameWithFailedDecorator).status).eq(Status.PASSED) 49 | const missingTestSteps = findSteps(testNameWithFailedDecorator) 50 | expect(missingTestSteps).length(0) 51 | }) 52 | } 53 | } 54 | -------------------------------------------------------------------------------- /tests/specs/story.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findLabel, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class StorySuite { 8 | before() { 9 | cleanResults() 10 | runTests('story') 11 | } 12 | 13 | @test 14 | shouldHaveStories() { 15 | const testName = 'shouldAssignDecoratedStory' 16 | return whenResultsAppeared().then(() => { 17 | expect(findTest('Story')).not.eq(undefined) 18 | expect(findTest(testName).status).eq(Status.PASSED) 19 | expect(findLabel(testName, 'story').value).eq('Common decorated story') 20 | }) 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /tests/specs/tag.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findLabel, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class TagSuite { 8 | before() { 9 | cleanResults() 10 | runTests('tag') 11 | } 12 | 13 | @test 14 | shouldHaveTags() { 15 | const testName = 'shouldAssignDecoratedTag' 16 | return whenResultsAppeared().then(() => { 17 | expect(findTest('Tag')).not.eq(undefined) 18 | expect(findTest(testName).status).eq(Status.PASSED) 19 | expect(findLabel(testName, 'tag').value).eq('regression') 20 | }) 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /tests/specs/testData.ts: -------------------------------------------------------------------------------- 1 | import { Status } from 'allure-js-commons' 2 | import { expect } from 'chai' 3 | import { suite, test } from '@testdeck/mocha' 4 | import { cleanResults, findParameter, findTest, runTests, whenResultsAppeared } from '../utils' 5 | 6 | @suite 7 | class ParameterSuite { 8 | before() { 9 | cleanResults() 10 | runTests('testData') 11 | } 12 | 13 | @test 14 | shouldHaveParameter() { 15 | const testName = 'shouldCallTestUserDataOnTest' 16 | return whenResultsAppeared().then(() => { 17 | expect(findTest('TestData')).not.eq(undefined) 18 | expect(findTest(testName).status).eq(Status.PASSED) 19 | expect(findParameter(testName, 'inputs').value).eq(JSON.stringify({ firstName: 'Test', lastName: 'User' })) 20 | }) 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /tests/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "../tsconfig.json", 3 | "include": ["./**/*.ts"] 4 | } 5 | -------------------------------------------------------------------------------- /tests/tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "../tslint.json", 3 | "jsRules": {}, 4 | "rules": { 5 | "member-access": false 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /tests/utils/index.ts: -------------------------------------------------------------------------------- 1 | import * as jetpack from 'fs-jetpack' 2 | import Mocha from 'mocha' 3 | import { MochaAllureReporter } from 'allure-mocha/runtime' 4 | import * as path from 'path' 5 | 6 | const testDir = './dist/tests/fixtures/specs' 7 | const resultsDir = path.join(__dirname, '../../allure-results') 8 | const resultsPollingInterval: number = 10 9 | 10 | let results: any[] = [] 11 | 12 | export function runTests(...specs: string[]) { 13 | const mocha = new Mocha() 14 | assignSpecs(mocha, specs) 15 | mocha 16 | .reporter(MochaAllureReporter) 17 | .run((failures) => { 18 | process.exitCode = failures ? 1 : 0 19 | }) 20 | .on('end', () => (results = readResults('*.json'))) 21 | } 22 | 23 | export function whenResultsAppeared() { 24 | return new Promise((resolve, reject) => { 25 | ;(function waitForResults() { 26 | if (results.length > 0) { 27 | return resolve() 28 | } 29 | setTimeout(waitForResults, resultsPollingInterval) 30 | })() 31 | }) 32 | } 33 | 34 | export function findTest(name: string): any { 35 | return results.find((result) => result.name === name) 36 | } 37 | 38 | export function findLabel(testName: string, labelName: string): any { 39 | return findTest(testName).labels.find((label) => label.name === labelName) 40 | } 41 | 42 | export function findParameter(testName: string, parameterName: string): any { 43 | return findParameters(testName).find((parameter) => parameter.name === parameterName) 44 | } 45 | 46 | export function findParameters(testName: string): any[] { 47 | return findTest(testName).parameters 48 | } 49 | 50 | export function findLinks(testName: string): any[] { 51 | return findTest(testName).links 52 | } 53 | 54 | export function findSteps(testName: string): any[] { 55 | return findTest(testName).steps 56 | } 57 | 58 | export function cleanResults() { 59 | results = [] 60 | } 61 | 62 | export function readResults(pattern: string): any[] { 63 | return findFiles(pattern).map((file) => require(file)) 64 | } 65 | 66 | export function findFiles(pattern: string): any[] { 67 | return jetpack 68 | .dir(resultsDir) 69 | .find({ matching: pattern }) 70 | .map((fileName) => path.join(resultsDir, fileName)) 71 | } 72 | 73 | function assignSpecs(mocha: Mocha, specs: string[]) { 74 | jetpack 75 | .dir(testDir) 76 | .find({ matching: specs.map((spec) => `${spec}.js`) }) 77 | .forEach((file) => mocha.addFile(path.join(testDir, file))) 78 | } 79 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es6", 4 | "lib": [ 5 | "es6" 6 | ], 7 | "module": "commonjs", 8 | "moduleResolution": "node", 9 | "declaration": true, 10 | "strict": true, 11 | "sourceMap": true, 12 | "emitDecoratorMetadata": true, 13 | "experimentalDecorators": true, 14 | "allowSyntheticDefaultImports": true, 15 | "removeComments": true, 16 | "noImplicitAny": false, 17 | "esModuleInterop": true, 18 | "paths": { 19 | "*": ["node_modules/*"] 20 | }, 21 | "baseUrl": ".", 22 | "outDir": "dist", 23 | "typeRoots" : ["./node_modules/@types"] 24 | }, 25 | "include": [ 26 | "src/**/*.ts" 27 | ] 28 | } 29 | -------------------------------------------------------------------------------- /tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "defaultSeverity": "error", 3 | "extends": [ 4 | "tslint:latest", 5 | "tslint-eslint-rules", 6 | "tslint-config-prettier" 7 | ], 8 | "jsRules": {}, 9 | "rules": { 10 | "prettier": [ 11 | true, 12 | "./.prettierrc" 13 | ], 14 | "no-implicit-dependencies": [ 15 | true, 16 | "dev" 17 | ], 18 | "trailing-comma": false, 19 | "no-empty": false, 20 | "no-submodule-imports": false, 21 | "ter-indent": [ 22 | true, 23 | 2, 24 | { 25 | "FunctionExpression": { 26 | "parameters": 1, 27 | "body": 1 28 | } 29 | } 30 | ], 31 | "linebreak-style": [ 32 | true, 33 | "LF" 34 | ], 35 | "no-console": [ 36 | true, 37 | "log", 38 | "info", 39 | "error" 40 | ], 41 | "no-duplicate-variable": [ 42 | true, 43 | "check-parameters" 44 | ], 45 | "quotemark": [ 46 | true, 47 | "single", 48 | "avoid-escape", 49 | "avoid-template" 50 | ], 51 | "semicolon": [ 52 | false, 53 | "always" 54 | ] 55 | }, 56 | "rulesDirectory": [ 57 | "tslint-plugin-prettier" 58 | ] 59 | } 60 | --------------------------------------------------------------------------------