2

実際のバックエンド URL を呼び出すサービスをテストしたいのですが、解決策が見つかりません。私のサービスはサーバーからデータを呼び出す必要があり、データがサービスに送られ、サービスがそれを正しく処理することを確認したいと思います。

ここに、私のログイン サービスの簡単な例を示します。

@Injectable()
export class LoginService {
/**
 * The token, which will be stored on the localStorage.
 */
public token: string;
//Eventemitter, for updating the navigation, when the user logs in
@Output() loggedInEm:EventEmitter<any> = new EventEmitter();


constructor(private http: Http) {
    // set token if saved in local storage
    var currentUser = JSON.parse(localStorage.getItem('currentUser'));
    this.token = currentUser && currentUser.token;
}

login(_mail, _pass): Observable<number> {
    var headers = new Headers();
    headers.append('Content-Type', 'application/json');
    var data = {
        mail: _mail,
        pass: _pass
    };
    return this.http.post('/login', JSON.stringify(data), {
        headers : headers
    }).map((response: Response) => {
        let res = response.json();
        this.logged = res;
    });
}

public loggedIn() : boolean {
    return this.logged;
}

これは私がそれをテストしたい方法です:

describe('Login Service', () => {

    let loginService: LoginService;

    beforeEach(() =>  {
        TestBed.configureTestingModule({
            declarations: [
            ],
            providers: [
                LoginService
            ],
            imports: [
                FormsModule,
                IonicModule
            ],
        });
        inject([LoginService], (service) => {
            loginService = service;
        });
    });


    it("Should login user", () => {
        loginService.login("mail@mail.ru", "123456");
        let loggedIn = loginService.loggedIn();
        expect(loggedIn).toBe(true);
    });
});

しかし、次のエラーが発生します: TypeError: Cannot read property 'login' of undefined, so the service must be undefined. サービスをモックすることもできますが、バックエンド サーバーにある実際のデータベースで動作させたいと考えています。

では、何が問題で、どうすれば解決できますか?

敬具、

アンドレイ

4

1 に答える 1