错误: :无法找到一个对象来侦察角色()

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了错误: :无法找到一个对象来侦察角色()相关的知识,希望对你有一定的参考价值。

我正在写我的第一个Angular 6单元测试。我按照这个源https://www.youtube.com/watch?v=lTKhB6uAmno来构建我的测试文件,我最终得到了我无法解决的错误。我在SO中发现了一个similar question但不幸的是没有得到答案。请指导我排除这个错误。谢谢。这是我的文件,

component.ts

import { Component } from '@angular/core';
import { InputModel } from '../model/formInput';
import { APIService } from '../service/APIService';

@Component({
    selector: 'results-component',
    templateUrl: './result.component.html',
    styleUrls: ['./result.component.css']
})

export class ResultComponent {
    constructor(private apiService: APIService) { }
    sendTask(model: InputModel) {
        this.apiService.getRoles(model.TaskName)
            .subscribe(
                res => {
                    console.log(res)
                }, err => { console.log(err) });
    }
}

service.ts

import {Injectable} from '@angular/core';
import { HttpClient, HttpParams } from '@angular/common/http';
import { ApiResponse } from '../model/ApiResponse';
import { Observable, throwError } from 'rxjs';
import { map, catchError } from 'rxjs/operators';

@Injectable()

export class APIService{

    private url:string = 'http://localhost:1/api/default';
    result:ApiResponse;
    private http:HttpClient;

    constructor(){}

    getRoles(taskName:string):Observable<ApiResponse>{
        var params = this.getParams(taskName);
        return this.http.get<ApiResponse>(this.url,{ params })
        .pipe(
            map((data:ApiResponse)=>data),
            catchError((err:ApiResponse)=>throwError(err))
            )
        }

    private getParams(taskName:string){
        let param = new HttpParams().set('taskName', taskName);
        return param;
    }
}

component.spec.ts

import { ResultComponent } from "./result.component";
import {ComponentFixture, TestBed, inject} from '@angular/core/testing';
import { APIService } from "../service/APIService";
import { of } from "rxjs";
import { ApiResponse } from "../model/ApiResponse";
import { InputModel } from "../model/formInput";
import { HttpClientTestingModule } from "@angular/common/http/testing";

describe('ResultComponent', ()=>{
    let fixture:ComponentFixture<ResultComponent>;
    let component:ResultComponent;
    let apiService:APIService;
    let model:InputModel = new InputModel();
    let mockResponse : ApiResponse=
    {
        code:'0',
        data:{
            permissionsList:[
                {
                    orgRoles:'Edit Access TRUE',
                    roleType:'OPTIONAL'
                }
            ]
        },
        message:'',
        status:'success'
    };

    beforeEach(()=>{
        TestBed.configureTestingModule({
            imports:[HttpClientTestingModule],
            declarations:[ResultComponent],
            providers:[APIService]//,
            //{provide:HttpClient}]
        }).compileComponents();

        fixture = TestBed.createComponent(ResultComponent);
        component = fixture.componentInstance;
        apiService=TestBed.get(APIService);

        model.TaskName='Edit';
    });

    it('test service response', ()=>{
        spyOn(apiService, 'getRoles').and.returnValue(of(mockResponse));
         component.sendTask(model);
        expect(apiService.getOrgRoles).toHaveBeenCalled();
    });
})

如果我使用假服务,单元测试工作正常。我无法在我的spec文件中找到我想念的内容。

答案

无需使用spyOnmethod即可轻松完成此操作。

而不是为您的服务创建spy object并提供间谍对象作为providers数组中的服务。

describe('Result component tests', () => {

  let fixture: ComponentFixture<ResultComponent>;
  let component: ResultComponent;

  let apiService: APIService;
  let spyApiService: jasmine.SpyObj<APIService>;

  let getRolesSubject;
  let mockResponse: ApiResponse =
    {
      code: '0',
      data: {
        permissionsList: [
          {
            orgRoles: 'Edit Access TRUE',
            roleType: 'OPTIONAL'
          }
        ]
      },
      message: '',
      status: 'success'
    };

  beforeEach(async(() => {
    getRolesSubject = new Subject();

    spyApiService = jasmine.createSpyObj('APIService', ['getRoles']);
    spyApiService.getRoles.and.returnValue(getRolesSubject.asObservable());

    TestBed.configureTestingModule({
      declarations: [ResultComponent],
      providers: [
        {provide: APIService, useValue: spyApiService},
      ],
      schemas: [NO_ERRORS_SCHEMA]
    }).compileComponents().then(() => {
      fixture = TestBed.createComponent(ResultComponent);
      component = fixture.componentInstance;

      apiService = TestBed.get(APIService);
    });
  }));


  it('Should invoke getRoles of api service when ...', () => {
    component.sendTask(model);
    getRolesSubject.next(mockResponse);
    expect(apiService.getRoles).toHaveBeenCalled();
  });

});

我正在使用subject将值作为服务中的可观察对象返回。

getRolesSubject.next(mockResponse);

认为你在subscribe方法中有很少的方法。现在你也可以测试它们了。

以上是关于错误: :无法找到一个对象来侦察角色()的主要内容,如果未能解决你的问题,请参考以下文章

错误:无法删除角色,因为某些对象依赖于它

viewpager 中的片段,未找到视图错误

Flyway 无法找到 postgres docker 的角色

无法找到指定dll库文件skinH_EL.dll中的输出命令skinH_Attach_EX_

无法找到包含 Intent 在片段中时的配置根

片段 TextView 无法从 parcelable 对象更新