実際のバックエンド 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. サービスをモックすることもできますが、バックエンド サーバーにある実際のデータベースで動作させたいと考えています。
では、何が問題で、どうすれば解決できますか?
敬具、
アンドレイ