私はAngular 4 CLI(v.1.0.0)を使用しており、テストを処理するために、ジャスミンを使用してスパイを作成するモックをいくつか作成しました。IDE =すべて正常に見えますが、ターミナルで「名前「ジャスミン」が見つかりません」というエラーが表示されます。
最初は、ジャスミンがタイピングに追加されていないことが問題だと思っていましたが、package.jsonにジャスミンタイプdefのインポートが含まれているので、何が欠けているのかわかりません。
mocks.ts
export class MockAuthService {
public login: Function = jasmine.createSpy('login');
}
export class MockHttpService {
public delete: Function = jasmine.createSpy('delete');
public get: Function = jasmine.createSpy('get');
public post: Function = jasmine.createSpy('post');
public put: Function = jasmine.createSpy('put');
}
ng serveを実行すると、ターミナルに次のエラーメッセージが返されます。
C:/Users/efarley/Desktop/repos/prod/src/app/mocks/mocks.ts(2,23)のエラー:名前「jasmine」が見つかりません。 C:/Users/efarley/Desktop/repos/prod/src/app/mocks/mocks.ts(6,24):「jasmine」という名前が見つかりません。 C:/Users/efarley/Desktop/repos/prod/src/app/mocks/mocks.ts(7,21):「jasmine」という名前が見つかりません。 C:/Users/efarley/Desktop/repos/prod/src/app/mocks/mocks.ts(8,22):「jasmine」という名前が見つかりません。 C:/Users/efarley/Desktop/repos/prod/src/app/mocks/mocks.ts(9,21):「jasmine」という名前が見つかりません。 webpack:コンパイルに失敗しました。
tsconfig.json
{
"compileOnSave": false,
"compilerOptions": {
"outDir": "./dist/out-tsc",
"baseUrl": "src",
"sourceMap": true,
"declaration": false,
"moduleResolution": "node",
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"target": "es5",
"typeRoots": [
"node_modules/@types"
],
"lib": [
"es2016",
"dom"
]
}
}
tsconfig.spec.json
{
"extends": "../tsconfig.json",
"compilerOptions": {
"outDir": "../out-tsc/spec",
"module": "commonjs",
"target": "es5",
"baseUrl": "",
"types": [
"jasmine",
"node"
]
},
"files": [
"test.ts"
],
"include": [
"**/*.spec.ts",
"**/*.d.ts"
]
}
tsconfig.app.json
{
"extends": "../tsconfig.json",
"compilerOptions": {
"outDir": "../out-tsc/app",
"module": "es2015",
"baseUrl": "",
"types": []
},
"exclude": [
"test.ts",
"**/*.spec.ts"
]
}
package.json
{
"name": "prod",
"version": "0.0.0",
"license": "MIT",
"scripts": {
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
"private": true,
"dependencies": {
"@angular/animations": "^4.0.2",
"@angular/common": "^4.0.0",
"@angular/compiler": "^4.0.0",
"@angular/core": "^4.0.0",
"@angular/flex-layout": "^2.0.0-beta.8",
"@angular/forms": "^4.0.0",
"@angular/http": "^4.0.0",
"@angular/material": "^2.0.0-beta.3",
"@angular/platform-browser": "^4.0.0",
"@angular/platform-browser-dynamic": "^4.0.0",
"@angular/router": "^4.0.0",
"core-js": "^2.4.1",
"rxjs": "^5.1.0",
"zone.js": "^0.8.4"
},
"devDependencies": {
"@angular/cli": "1.0.0",
"@angular/compiler-cli": "^4.0.0",
"@types/jasmine": "2.5.38",
"@types/node": "~6.0.60",
"codelyzer": "~2.0.0",
"jasmine-core": "~2.5.2",
"jasmine-spec-reporter": "~3.2.0",
"karma": "~1.4.1",
"karma-chrome-launcher": "~2.0.0",
"karma-cli": "~1.0.1",
"karma-jasmine": "~1.1.0",
"karma-jasmine-html-reporter": "^0.2.2",
"karma-coverage-istanbul-reporter": "^0.2.0",
"protractor": "~5.1.0",
"ts-node": "~2.0.0",
"tslint": "~4.5.0",
"TypeScript": "~2.2.0"
}
}
TypeScriptがモックをapp
ビルドに含めようとしており、アプリが(正しく)Jasmineを認識していないため、エラーが発生します。
モックをtsconfig.app.json
のexclude
配列に追加して、モックをアプリのコンパイルから除外します。
{
"extends": "../tsconfig.json",
"compilerOptions": {
"outDir": "../out-tsc/app",
"module": "es2015",
"baseUrl": "",
"types": []
},
"exclude": [
"test.ts",
"**/*.spec.ts",
"**/*.mock.ts"
]
}
その方法でジャスミンのスパイを作成する必要があるかどうかはわかりませんが、
問題はあなたのファイル名にあります
通知:tsconfig.spec.json
には:"include": ["**/*.spec.ts","**/*.d.ts"]
ファイル名はmocks.ts
です。
ファイル名をmocks.spec.ts
に変更するか、
または"**/*.mock.ts"
を追加し、service.mock.ts
のような名前に変更します
お役に立てれば。