Angular中的Jasmine测试用例中导航和getCurrentNavigation方法不起作用。
创始人
2024-10-31 06:30:13
0

可能是因为在Jasmine测试用例中没有正确设置需要测试的应用程序的根。 以下是一个示例代码,展示如何在Jasmine测试用例中设置根并正确使用导航和getCurrentNavigation方法:

import { TestBed, async, ComponentFixture } from '@angular/core/testing';
import { RouterTestingModule } from '@angular/router/testing';
import { Router } from '@angular/router';

import { MyComponent } from './my.component';

describe('MyComponent', () => {
  let component: MyComponent;
  let fixture: ComponentFixture;
  let router: Router;

  beforeEach(async(() => {
    TestBed.configureTestingModule({
      imports: [ RouterTestingModule ],
      declarations: [ MyComponent ]
    })
    .compileComponents();
  }));

  beforeEach(() => {
    fixture = TestBed.createComponent(MyComponent);
    component = fixture.componentInstance;
    router = TestBed.inject(Router);
    fixture.detectChanges();
  });

  it('should navigate to home page', () => {
    const navigateSpy = spyOn(router, 'navigate');
    component.goToHomePage();
    expect(navigateSpy).toHaveBeenCalledWith(['/home']);
  });

  it('should get current navigation', () => {
    component.goToHomePage();
    expect(router.getCurrentNavigation().extractedUrl.toString()).toBe('/home');
  });
});

在上面的示例代码中,测试用例导入了RouterTestingModule,这是为了设置正确的根并初始化路由模块。在beforeEach函数中,我们可以获取到路由的实例,可以通过该实例使用导航并获取当前导航信息。在it函数中,我们使用spyOn来替换navigate方法并检查是否正确导航到了目标页面。在第二个it函数中,我们检查getCurrentNavigation()方法是否能正确返回导航信息对象,并查看其URL是否与所期望的相同。

注意:我们需要确保在测试用例中所使用的路径与应用程序中的路由匹配。并且在测试用例中执行导航操作时,通常会在测试完成后导航回原来的页面,以

相关内容

热门资讯

黑科技代打(Wepoke代码)... 黑科技代打(Wepoke代码)wPk往昔存在有挂!太嚣张了起初真的有挂(2021已更新)(哔哩哔哩)...
黑科技好友房(Wepoke安装... 黑科技好友房(Wepoke安装)菠萝德州app起初是有挂!太夸张了都是真的是有挂(2021已更新)(...
黑科技计算(Wepoke辅助a... 黑科技计算(Wepoke辅助ai)传奇扑克往昔是有挂!太嚣张了一向真的是有挂(2020已更新)(哔哩...
黑科技辅助(微扑克脚本)nzt... 黑科技辅助(微扑克脚本)nzt德州确实有挂!太实锤了一向是真的有挂(2021已更新)(哔哩哔哩)1、...
黑科技攻略(wpk修改器)wP... WePoker透视辅助工具核心要点解析‌,黑科技攻略(wpk修改器)wPK切实真的有挂!太夸张了竟然...
黑科技教学(德州竞技联盟)鱼扑... 黑科技教学(德州竞技联盟)鱼扑克app俱乐部竟然是真的有挂!太夸张了原生存在有挂(2020已更新)(...
黑科技软件(扑克世界app)a... WePoker透视辅助版本稳定性对比与推荐‌:黑科技软件(扑克世界app)aapokER一贯真的是有...
黑科技代打(aapoker操作... 黑科技代打(aapoker操作)微扑克插件一贯是真的有挂!太无语了本然真的有挂(2024已更新)(哔...
黑科技有挂(德扑窥牌)德州we... 黑科技有挂(德扑窥牌)德州wepower原本有挂!太无语了从前是有挂(2025已更新)(哔哩哔哩);...
黑科技中牌率(Wepoke总结... 黑科技中牌率(Wepoke总结)轰趴十三水原本真的有挂!太无语了真是真的是有挂(2026已更新)(哔...