P.P*_*kov 12 migration testing angular
我使用以下格式进行测试:
export function main() {
describe('Angular2 component test', function() {
it('should initialize component',
async(inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
var template = '<specific-component-tag>';
return tcb.overrideTemplate(TestComponent, template)
.createAsync(TestComponent)
.then((fixture) => {
expect(fixture.componentInstance.viewChild).toBeDefined();
fixture.detectChanges();
expect(fixture.componentInstance.viewChild.items.length).toBe(1);
// .... etc.
}).catch (reason => {
console.log(reason);
return Promise.reject(reason);
});
})));
});
}Run Code Online (Sandbox Code Playgroud)
Module ".... @angular/core/testing" has no exported member 'it'.
Module ".... @angular/core/testing" has no exported member 'describe'.
Module ".... @angular/core/testing" has no exported member 'expect'.
Module ".... @angular/core/testing" has no exported member 'beforeEachProviders'.
Module ".... @angular/compiler/testing" has no exported member 'TestComponentBuilder'.
Module ".... @angular/compiler/testing" has no exported member 'ComponentFixture'.Run Code Online (Sandbox Code Playgroud)
请帮我将此测试迁移到angular2 RC5.
更新:我已经阅读了RC5 发行说明,但我没有想到如何实现我的目标.
use*_*723 14
通过@ angular/core/testing提供的Jasmine导入将被删除.因此,请删除以下内容的导入
之前:
import {
beforeEach,
beforeEachProviders,
describe,
expect,
it,
inject,
} from '@angular/core/testing';
Run Code Online (Sandbox Code Playgroud)
后
/// <reference path="../../../typings/main/ambient/jasmine/index.d.ts" />
import {
inject, addProviders
} from '@angular/core/testing';
Run Code Online (Sandbox Code Playgroud)
引用路径应该是文件中的第一行,它应该指向jasmine类型定义文件.(更新相对向上.即../../为什么)要获取茉莉花类型定义,请将以下行添加到ambientDevDependencies.我看起来像这样
{
"ambientDevDependencies": {
"angular-protractor": "registry:dt/angular-protractor#1.5.0+20160425143459",
"jasmine": "registry:dt/jasmine#2.2.0+20160412134438",
"selenium-webdriver": "registry:dt/selenium-webdriver#2.44.0+20160317120654"
},
"ambientDependencies": {
"es6-shim": "registry:dt/es6-shim#0.31.2+20160317120654"
}
}
Run Code Online (Sandbox Code Playgroud)
也改变
beforeEachProviders(() => [InMemoryDataService]);
Run Code Online (Sandbox Code Playgroud)
至
import { TestBed } from '@angular/core/testing';
...
describe('...', () => {
TestBed.configureTestingModule({
providers: [ InMemoryDataService ]
});
it(...);
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5155 次 |
| 最近记录: |