- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我是 Angular 4 Jasmine 单元测试的新手。
感谢您的帮助。
登录组件:
import { Component, OnInit } from '@angular/core';
import { Router } from '@angular/router';
import { Http, Headers, RequestOptions, Response } from '@angular/http';
import { HttpError } from '../core/http-error';
import { jsonFields } from '../app.constants';
import { LoggedUserData } from '../shared/model/loggedUserData';
import { Observable } from 'rxjs/Observable';
import { FormControl, Validators } from '@angular/forms';
import { LoginService } from '../shared/login.service';
@Component({
selector: 'app-login',
templateUrl: './login.component.html',
styleUrls: ['./login.component.scss']
})
export class LoginComponent implements OnInit {
userID: string;
userPassword: string;
hide: boolean = true;
errorMsg: string;
errorShow: boolean = false;
showLoad: boolean = false;
constructor(private router: Router, private _http: Http, private _LoginService: LoginService) { }
loginFormControl = new FormControl('', [
Validators.required]);
ngOnInit() {
}
onLogin() {
this.showLoad = true;
var loggedUserData = new LoggedUserData();
var secPayload = {};
secPayload[jsonFields.login.userId] = this.userID;
secPayload[jsonFields.login.password] = this.userPassword;
secPayload[jsonFields.login.businessUnitId] = "7238";
secPayload[jsonFields.login.domainName] = "";
this._LoginService.authenticate(secPayload).subscribe(
result => {
loggedUserData.userId = result[jsonFields.loggedUserData.userId];
loggedUserData.token = result[jsonFields.loggedUserData.token];
loggedUserData.authTypeCode = result[jsonFields.loggedUserData.authTypeCode];
loggedUserData.businessUnitId = result[jsonFields.loggedUserData.businessUnitId];
loggedUserData.firstName = result[jsonFields.loggedUserData.firstName];
loggedUserData.lastName = result[jsonFields.loggedUserData.lastName];
loggedUserData.links = result[jsonFields.loggedUserData.links];
loggedUserData.locale = result[jsonFields.loggedUserData.locale];
loggedUserData.pwdExpired = result[jsonFields.loggedUserData.pwdExpired];
loggedUserData.securityId = result[jsonFields.loggedUserData.securityId];
loggedUserData.upn = result[jsonFields.loggedUserData.upn];
this.errorShow = false;
const token: string = loggedUserData.token;
if (token != null) {
localStorage.setItem("tokenId", token);
this.router.navigate(['delivery']);
}
else {
localStorage.removeItem("tokenId");
this.router.navigate(['login']);
}
this.showLoad = false;
},
(error: HttpError) => {
this.errorShow = true;
this.errorMsg = error.message;
this.showLoad = false;
}
);
}
}
登录组件规范:
import { async, ComponentFixture, TestBed, inject } from '@angular/core/testing';
import { LoginComponent } from './login.component';
import { LoginService } from '../shared/login.service';
import { MatProgressBarModule } from '@angular/material';
import { TranslateModule, TranslateService, TranslateLoader, TranslateFakeLoader, TranslateCompiler, TranslateParser, MissingTranslationHandler } from '@ngx-translate/core';
import { MatInputModule } from '@angular/material';
import { FormsModule } from '@angular/forms';
import { Router, RouterModule } from '@angular/router';
import { HttpModule } from '@angular/http';
import { TranslationService } from '../translation/translation.service';
import { TranslateStore } from "@ngx-translate/core/src/translate.store";
describe('LoginComponent', () => {
let component: LoginComponent;
let fixture: ComponentFixture<LoginComponent>;
const mockLoginService = {
authenticate() { },
validateLoginToken() { }
};
const mockTranslationService = {
validateLanguage() {
}
}
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [LoginComponent],
imports: [MatProgressBarModule, FormsModule, HttpModule, RouterModule, TranslateModule],
providers: [
{
provide: LoginService, useValue: mockLoginService
},
{
provide: TranslationService, useValue: mockTranslationService
},
{
provide: Router,
useClass: class { navigate = jasmine.createSpy("navigate"); }
},
{
provide: TranslateLoader,
useClass: TranslateFakeLoader
},
TranslateService, TranslateStore, TranslateCompiler, TranslateParser, MissingTranslationHandler
]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(LoginComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
component.errorMsg = "dsadsad";
component.errorShow = true;
component.hide = true;
component.showLoad = true;
component.userID = '';
component.userPassword = '';
expect(component).toBeTruthy();
expect(component.onLogin).toBeTruthy();
});
it('validate Login', inject([LoginService],
(service: LoginService) => {
expect(service.authenticate).toBeTruthy();
expect(service.validateLoginToken).toBeTruthy();
}));
it('should translate the language service', inject([TranslationService],
(service: TranslationService) => {
expect(service).toBeTruthy();
expect(service.validateLanguage).toBeTruthy();
}));
});
翻译模块:
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { HttpClientModule, HttpClient } from '@angular/common/http';
import { TranslateModule, TranslateLoader } from '@ngx-translate/core';
import { TranslateHttpLoader } from '@ngx-translate/http-loader';
// AoT requires an exported function for factories
export function HttpLoaderFactory(httpClient: HttpClient) {
return new TranslateHttpLoader(httpClient, "./assets/i18n/", ".json");
}
@NgModule({
imports: [
CommonModule,
HttpClientModule,
TranslateModule.forRoot({
loader: {
provide: TranslateLoader,
useFactory: HttpLoaderFactory,
deps: [HttpClient]
}
})
],
declarations: []
})
export class TranslationModule { }
最佳答案
在您的规范文件中,将此提供程序添加到 TestBed 的配置部分:
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [LoginComponent],
imports: [MatProgressBarModule, FormsModule, HttpModule, RouterModule, TranslateModule],
providers: [
{ provide: USE_DEFAULT_LANG }, // <== add this line
{
provide: LoginService, useValue: mockLoginService
},
{
provide: TranslationService, useValue: mockTranslationService
},
{
provide: Router,
useClass: class { navigate = jasmine.createSpy("navigate"); }
},
{
provide: TranslateLoader,
useClass: TranslateFakeLoader
},
TranslateService, TranslateStore, TranslateCompiler, TranslateParser, MissingTranslationHandler
]
})
.compileComponents();
}));
您还需要此导入:
import {USE_DEFAULT_LANG} from '@ngx-translate/core';
这应该添加到来自 @ngx-translate/core
的其他导入中
关于angular - 错误 : No provider for InjectionToken USE_DEFAULT_LANG,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47712728/
正在复制的问题是,当sew呈现登录页面时,然后我们继续执行身份验证,现在将我们重定向到网站的仪表板,此时我们继续关闭会话,并且在之前的交互中生成的这些cookie没有被删除。这个问题是重复性的,并且一
我是 Flutter 的新手,目前正在研究 DI。 我正在使用 flutter_bloc 和 provider 包。 flutter_bloc 附带一个 RepositoryProvider,我现在问
我是 Flutter 的新手,目前正在研究 DI。 我正在使用 flutter_bloc 和 provider 包。 flutter_bloc 附带一个 RepositoryProvider,我现在问
我正在使用 Angular2 开发一个应用程序。 我正在尝试在我的应用程序中使用 Reactive Forms,但我遇到了一些错误: 第一个错误是关于 NgControl 的,如下所示: No pro
最近很多用户在使用电脑的时候发现了wmi provider host进程占用内存比较大,不知道这个进程到底是干什么的,能不能禁止,怎么禁止。下面来一起看看想想的介绍吧。 wmi provide
我的问题是: 当我在设计时不知道这些表达式的数量和类型时,如何将列表中的表达式拼接成一个引用? 在底部,我包含了类型提供程序的完整代码。 (我已经剥离了这个概念来证明这个问题。)我的问题出现在这些行:
我目前正在学习使用 Flutter 进行应用程序开发,并已开始学习 Provider 包。我遇到了一些困难并收到错误: “在此...小部件之上找不到正确的提供者” 我最终移动了 Provider 小部
我是 android 的新手,我正在学习如何使用 JavaMail API 发送电子邮件的教程,我已经正确添加了必要的 Jar,但我总是遇到无法解析 GmailSender 类上的符号提供程序,我尝试
我正在我的 Angular 应用程序中进行单元测试,我正在使用 TestBed 方法, 我正在测试组件,所以每个规范文件看起来像这样 import... describe('AppComponent'
enter image description here 代码:这是我的 index.js 文件 index.js import { Provider } from "react-redux"
Microsoft ASP.NET Universal Providers 1.1昨天与System.Web.Providers 1.2一起发布.在后面的 nuget 页面上声明:Legacy pac
在我的 Next js 项目中,我使用了 Next auth,其中 import {Provider} from 'next-auth/client' , 并包裹 在 _app.js 中。 但是,与此
当我在 View 模型中使用如下界面时 class MainViewModel @ViewModelInject constructor( private val trafficImagesR
更新 - 我实际上发现它是 Flutter Issue . 我有两个 Provider,一个是 EntriesProvider,另一个是 EntryProvider。我在创建条目时使用我的 Entry
function configure($provide, $injector) { $provide.provider("testservice", function () {
这真让我抓狂。我似乎无法弄清楚这有什么问题。 代码: public interface IMinutesCounter { void startTimer(); void stopTi
我在我的项目中玩 Dagger 2,然后我陷入了这个错误编译。-> Error:(18, 21) error: ....MyManager cannot be provided without an
我有一个 Resteasy 应用程序,它使用 Spring 并包含 ContainerRequestFilter 和 ContainerResponseFilter 实现,并用 @Provider 注
我正在尝试使用 Dagger2 设置一个新项目,我以前使用过 Dagger2,但现在我正在尝试自己从头开始设置它。我正在从我参与的 Kotlin 项目中获取示例,但无法像现在在 Kotlin 中一样为
我刚开始学习 dagger2,遇到了一个奇怪的问题,在我看来像是一个错误。这是模块: @Module public class SimpleModule { @Provides Coo
我是一名优秀的程序员,十分优秀!