angular - Jasmine 规范中没有路由器错误的提供者

标签 angular jasmine

我只是想为一个基本的 angular 2 组件编写一个简单的 jasmine 规范,但我收到了这个错误:

zone.js:388 Unhandled Promise rejection: No provider for Router! ; Zone: ProxyZone ; Task: Promise.then ; Value:



我该如何解决?

我的 Jasmine 测试:
import 'zone.js/dist/long-stack-trace-zone.js';
import 'zone.js/dist/async-test.js';
import 'zone.js/dist/fake-async-test.js';
import 'zone.js/dist/sync-test.js';
import 'zone.js/dist/proxy.js';
import 'zone.js/dist/jasmine-patch.js';

import { ComponentFixture, TestBed } from '@angular/core/testing';
import {
    BrowserDynamicTestingModule,
    platformBrowserDynamicTesting
} from '@angular/platform-browser-dynamic/testing';
import { By } from '@angular/platform-browser';
import { DebugElement } from '@angular/core';

import { MiddleRowComponent } from './middle-row.component';
import { CirclesComponent } from './circles.component';
import { ButtonComponent } from '../../shared/subcomponents/button.component';
import { Router } from '@angular/router';

let comp: MiddleRowComponent;
let fixture: ComponentFixture<MiddleRowComponent>;
let de: DebugElement;
let el: HTMLElement;

describe('MiddleRowComponent', () => {
   var fixture: any;
   var comp: any;
    beforeAll(() => {
        TestBed.resetTestEnvironment();
        TestBed.initTestEnvironment(BrowserDynamicTestingModule,
            platformBrowserDynamicTesting());
    });

    beforeEach((done) => {
        TestBed.configureTestingModule({
            declarations: [MiddleRowComponent, CirclesComponent, ButtonComponent], // declare the test component
            providers: [Router]
        }).compileComponents().then(() => {
            fixture = TestBed.createComponent(MiddleRowComponent);
            comp = fixture.componentInstance; // MiddleRowComponent test instance
            // query for the title <h1> by CSS element selector
            de = fixture.debugElement.query(By.css('h1'));
            el = de.nativeElement;
            done();
        });
    });

    it('should display original title', () => {
        fixture.detectChanges();
        expect(el.textContent).toContain(comp.word);
    });

    it('should display a different test title', () => {
        comp.word = 'Test Title';
        fixture.detectChanges();
        expect(el.textContent).toContain('Test Title');
    });
});

编辑:

我看到我的规范确实使用路由器。我在哪里添加路由器作为提供者?
import { Component } from '@angular/core';
import { Router } from '@angular/router';

@Component({
    selector: 'middle-row',
    templateUrl: 'app/landing-page/subcomponents/middle-row.component.html',
    styleUrls: ['app/landing-page/subcomponents/middle-row.component.css']
})
export class MiddleRowComponent {
    public word: string = "stuff";
    private isGreen: boolean;
    constructor(private router: Router) { };

    private tryNowClick(): void {
        this.router.navigateByUrl('/find');
    };

    private onWordChanged(event: any): void {
        this.isGreen = event.isGreen;
        this.word = event.word;
    }
}

最佳答案

如果使用路由器,则 TestBed.configureTestingModulebeforeEach需要包含这样的 providers 字段:

providers: [ { provide: Router, useClass: class { navigate = jasmine.createSpy("navigate"); } }]

例如:
 beforeEach((done) => {
        TestBed.configureTestingModule({
            declarations: [MiddleRowComponent, CirclesComponent, ButtonComponent], // declare the test component
            providers: [ { provide: Router, useClass: class { navigate = jasmine.createSpy("navigate"); } }]

        }).compileComponents().then(() => {
            fixture = TestBed.createComponent(MiddleRowComponent);

关于angular - Jasmine 规范中没有路由器错误的提供者,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40734256/

相关文章:

javascript - 我使用 NgFor 和 NgForOf 吗?

angular - 我如何知道子元素何时在 Angular 中完成渲染?

html - 响应式导航栏以 Angular 重叠在内容上

angular - 禁用按钮的单元测试

asp.net - 在 ASP.Net MVC 中使用 @Html.AntiForgeryToken() 提供 CSRF token 的替代方法

Angular2 导入绝对路径或自定义路径(typescript 2)

javascript - Jasmine 中 NUnit 的 TestCaseSource 是否有相应的设置?

javascript - 如何在 Sinon 中过滤请求

selenium-webdriver - Protractor :如果我提前关闭浏览器,我可以继续执行测试吗?

javascript - 在 if 语句中调用函数时的 Jasmine 测试用例