請幫忙!嘗試運行淺集成測驗時,我得到了上面的型別錯誤。
我多次查看我的代碼以檢查我是否有問題,但一切似乎都已就位。
我正在努力讓這個測驗通過。
expect(fixture.componentInstance.heroes.length).toBe(3)
它在 Karma 中因此錯誤而不斷失敗。
型別錯誤:無法讀取未定義的屬性(讀取“和”)
import { ComponentFixture, TestBed } from "@angular/core/testing"
import { of } from "rxjs";
import { HeroService } from "../hero.service";
import { HeroesComponent } from "./heroes.component"
describe('HeroesComponent (shallow tests)', () => {
let fixture: ComponentFixture<HeroesComponent>;
let mockHeroService;
let HEROES;
beforeEach(() =>{
HEROES = [
{id:1, name: 'SpiderDude', strength: 8},
{id:2, name: 'Wonderful Woman', strength: 24},
{id:3, name: 'SuperDude', strength: 55}
];
mockHeroService = jasmine.createSpyObj(['getHeroes, addHero, deleteHero']);
TestBed.configureTestingModule({
declarations: [HeroesComponent],
providers: [
{ provide: HeroService, useValue: mockHeroService}
],
schemas: [NO_ERRORS_SCHEMA]
})
fixture = TestBed.createComponent(HeroesComponent)
})
it('should set heroes correctly from the service', () => {
mockHeroService.getHeroes.and.returnValue(of(HEROES))
fixture.detectChanges();
expect(fixture.componentInstance.heroes.length).toBe(3)
});
});
uj5u.com熱心網友回復:
我不確定您使用的是什么單元測驗框架:
你的線路在這里
mockHeroService.getHeroes.and.returnValue(of(HEROES))
通過錯誤,我可以看出編譯器正在嘗試and從 object讀取屬性mockHeroService.getHeroes。但是mockHeroService.getHeroes本身是未定義的。所以編譯器無法讀取andundefined
問題就在這里 mockHeroService.getHeroes
請檢查mockHeroService茉莉花
uj5u.com熱心網友回復:
mockHeroService 方法中的引號未正確放置。
mockHeroService = jasmine.createSpyObj(['getHeroes, addHero, deleteHero']);
應該是這個。
mockHeroService = jasmine.createSpyObj(['getHeroes', 'addHero', 'deleteHero']);
轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/355612.html
標籤:javascript 有角的 单元测试 测试 集成测试
