2017-12-26 4 views
0

ngx-restangular를 사용하여 Angular 5 앱을 만들고 있습니다.ngx-restangular를 사용하지 않는 서비스 테스트

나는 http 호출이 ngx-restangular를 사용하여 만들어진 서비스를 만들었습니다.

Project.service.ts

import { Injectable } from '@angular/core'; 
import { Restangular } from 'ngx-restangular'; 
import { Observable } from 'rxjs/Observable'; 

@Injectable() 
export class ProjectService { 

    constructor(public restangular: Restangular) {} 

    restoreProject(project): Observable<any> { 
     return this.restangular.one('projects', project.id).get(); 
    } 

} 

다음은 위의 서비스에 대한 재스민의 테스트입니다 - - 서비스 코드는 다음

Project.service.spec.ts는

import { TestBed, inject } from '@angular/core/testing'; 
import { Restangular } from 'ngx-restangular'; 
import { HttpModule, Http, BaseRequestOptions, XHRBackend } from '@angular/http'; 
import { MockBackend } from '@angular/http/testing'; 

import {ProjectService } from './project.service'; 

describe('ProjectService',() => { 
    let service = ' '; 

    beforeEach(() => { 
     TestBed.configureTestingModule({ 
      providers: [ 
       ProjectService, 
       { provide: XHRBackend, useClass: MockBackend } 
      ] 
     }); 
    }); 

    beforeEach(() => { 
     service = new ProjectService(Restangular); 
    }); 

    describe('restoreProject method',() => { 

     let connection = ''; 

     beforeEach(inject([XHRBackend], (MockBackend) => { 
      MockBackend.connections.subscribe((httpConnection: any) => connection = httpConnection); 
     })); 

     it('should query restore project',() => {  
      service.restoreProject({id: 2}); 
      expect(connection.request.url).toMatch('projects/2', 'url invalid'); 
     }); 
    })  
}); 

나는 카르마 테스트 러너를 사용하고 있습니다. 테스트를 실행, 그것은

this.restangular.one is not a function

내가 여기 실종 어떤 출력?

답변

관련 문제