【问题标题】:VS-Code wrong Types for Unit-Tests (Mocha&Chai instead of Jasmine)单元测试的 VS 代码错误类型(Mocha&Chai 而不是 Jasmine)
【发布时间】:2018-08-22 08:33:04
【问题描述】:

我有一个离子项目,我想使用 Cypress 进行 e2e 测试并使用 Jasmine 进行单元测试。 在我将 cypress 包添加到 package.json 并开始编写第一个 e2e 测试后,VS-Code 在我的单元测试的 spec.ts 文件中显示了一些错误。 问题是,VS-Code 假设我正在使用 Mocha 和 Chai 进行测试。

我可以毫无错误地运行测试。

这是我的 tsconfig.json 文件:

{
  "compileOnSave": false,
  "compilerOptions": {
    "baseUrl": "./",
    "outDir": "./dist/out-tsc",
    "sourceMap": true,
    "dec

    laration": false,
    "moduleResolution": "node",
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "target": "es5",
    "typeRoots": [
      "node_modules/@types"
    ],
    "lib": [
      "es2017",
      "dom"
    ]
  }
}

还有我的 tsconfig.spec.json 文件:

{
  "extends": "../tsconfig.json",
  "compilerOptions": {
    "outDir": "../out-tsc/spec",
    "module": "commonjs",
    "types": [
      "jasmine",
      "node"
    ]
  },
  "files": [
    "test.ts",
    "polyfills.ts",
  ],
  "include": [
    "**/*.spec.ts",
    "**/*.d.ts"
  ]
}

最后我的依赖来自 package.json:

"dependencies": {
    "@angular/common": "~6.1.1",
    "@angular/core": "~6.1.1",
    "@angular/forms": "~6.1.1",
    "@angular/http": "~6.1.1",
    "@angular/platform-browser": "~6.1.1",
    "@angular/platform-browser-dynamic": "~6.1.1",
    "@angular/pwa": "^0.8.0-beta.2",
    "@angular/router": "~6.1.1",
    "@angular/service-worker": "~6.1.1",
    "@ionic-native/core": "5.0.0-beta.14",
    "@ionic-native/splash-screen": "5.0.0-beta.14",
    "@ionic-native/status-bar": "5.0.0-beta.14",
    "@ionic/angular": "^4.0.0-beta.0",
    "@ngxs/devtools-plugin": "^3.2.0",
    "@ngxs/router-plugin": "^3.2.0",
    "@ngxs/store": "^3.2.0",
    "child_process": "^1.0.2",
    "core-js": "^2.5.3",
    "karma-junit-reporter": "^1.2.0",
    "prompt": "^1.0.0",
    "rxjs": "6.2.2",
    "zone.js": "^0.8.26"
  },
  "devDependencies": {
    "@angular-devkit/architect": "~0.7.2",
    "@angular-devkit/build-angular": "~0.7.2",
    "@angular-devkit/core": "~0.7.2",
    "@angular-devkit/schematics": "~0.7.2",
    "@angular/cli": "^6.2.0-beta.2",
    "@angular/compiler": "~6.1.1",
    "@angular/compiler-cli": "~6.1.1",
    "@angular/language-service": "~6.1.1",
    "@compodoc/compodoc": "^1.1.3",
    "@ionic/ng-toolkit": "^1.0.0",
    "@ionic/schematics-angular": "^1.0.0",
    "@types/jasmine": "~2.8.6",
    "@types/jasminewd2": "~2.0.3",
    "@types/node": "~10.5.2",
    "codelyzer": "~4.4.2",
    "cypress": "^3.1.0",
    "jasmine-core": "~2.99.1",
    "jasmine-spec-reporter": "~4.2.1",
    "karma": "~3.0.0",
    "karma-chrome-launcher": "~2.2.0",
    "karma-coverage-istanbul-reporter": "~2.0.0",
    "karma-jasmine": "~1.1.1",
    "karma-jasmine-html-reporter": "^0.2.2",
    "start-server-and-test": "^1.7.0",
    "ts-node": "~7.0.0",
    "tslint": "~5.11.0",
    "typescript": "~2.7.2"
  }

如何解决这些测试框架的困惑?

亲切的问候,

大卫

【问题讨论】:

  • 我认为VS默认采用tsconfig.json文件。由于您没有指定“类型”,因此它采用“@types”中的所有类型。可能的解决方案是在嵌套文件夹而不是 tsconfig.spec.json 文件中创建 tsconfig.json 并在其中指定“类型”字段。
  • 是的!这就是解决方案。我以为 VS-Code 会识别 tsconfig.spec.json,但它忽略了它。重命名后,VS-Code 在规范文件中使用正确的类型。坦克你的帮助。如果您创建答案,我会将其标记为已解决。
  • 你把tsconfig.spec.json改名为什么了?
  • 我将它重命名为 tsconfig.json 它位于一个单独的文件夹中,其中包含所有 cypress 测试

标签: unit-testing visual-studio-code jasmine mocha.js cypress


【解决方案1】:

VS 默认采用tsconfig.json 文件。由于您没有在其中指定 types 字段,因此它采用 @types 目录中的所有类型。可能的解决方案是在嵌套文件夹中创建 tsconfig.json 而不是 tsconfig.spec.json 文件并在其中指定 types 字段。

【讨论】:

    猜你喜欢
    • 2018-04-17
    • 2023-04-11
    • 1970-01-01
    • 2018-02-13
    • 1970-01-01
    • 2018-11-05
    • 1970-01-01
    • 2020-02-28
    • 1970-01-01
    相关资源
    最近更新 更多