【发布时间】:2021-09-20 20:41:46
【问题描述】:
我想对此 onSubmit 函数执行单元测试,其中肯定提交导致 MatSnackbar 并显示消息“提交成功”。我是 Jasmine Karma 的新手,请指导我在这种情况下测试 MatSnackbar。
Component.ts
import { MatSnackBar } from "@angular/material/snack-bar";
constructor(
private snackBar: MatSnackBar,
private auth: AuthenticateService,
) {}
...
...
onSubmit(e) {
const newYellow = {
G1: e.value.Yellow_G1,
G2: e.value.Yellow_G2,
G3: e.value.Yellow_G3,
G4: e.value.Yellow_G4,
B1: e.value.Yellow_B1,
B2: e.value.Yellow_B2,
B3: e.value.Yellow_B3,
B4: e.value.Yellow_B4,
};
console.log(newYellow);
this.auth.submitnominYellow(newYellow).subscribe(
(res) => {
console.log(res);
this.snackBar.open("Submitted Successfully", "", {
duration: 2000,
});
},
(error) => {
console.log(error);
}
);
}
这是submitnomin 函数的代码。
auth.service.ts
submitnominYellow(inpobj) {
console.log(inpobj);
return this.http.post(environment.apiUrl + '/api/customize/yellow', inpobj);
}
我的单元测试用例有点像这样。
component.spec.ts
const mockSnackbarMock = jasmine.createSpyObj(['open']);
mockSnackbarMock.open
const mockopblue =
{
success: true
}
const MockAuthService = {
submitnominYellow:(id) => (mockopblue),
getuser:() => (undefined)
};
...
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ YellowCustomizeComponent ],
imports: [HttpClientTestingModule, MatSnackBarModule, FormsModule, RouterTestingModule],
providers:[{provide: MatSnackBar, useValue: mockSnackbarMock},
{provide: AuthenticateService, useValue: MockAuthService}
]
})
.compileComponents();
}));
...
fit('should open the snack bar with correct arguments when form submitted', () => {
const e = {
value:{
Yellow_G1: "YGirlName1",
Yellow_G2: "GirlName2",
Yellow_G3: "GirlName3",
Yellow_G4: "GirlName4",
Yellow_B1: "BoyName1",
Yellow_B2: "BoyName2",
Yellow_B3: "BoyName3",
Yellow_B4: "BoyName4",
}
};
component.onSubmit(e)
console.log('mockSnackbarMock',mockSnackbarMock)
// console.log('yellow onsubmit',component.onSubmit(e));
expect(mockSnackbarMock.open).toHaveBeenCalledWith("Submitted Successfully", "", );
})
【问题讨论】:
-
如果您只想测试小吃店而不是整个方法,我会说创建一个带有存根 submitnominYellow 方法的模拟/存根 authService,该方法将返回成功。您需要在“it”测试方法中使用 fakeAsync 测试回调。您可以创建一个spyBar 及其创建方法的间谍。希望这会有所帮助
-
谢谢,但是快餐栏是功能的一部分,所以我将如何继续。请指导我,我是 jasmine 业力单元测试的新手。
-
this.snackBar是组件的 viewChild 还是什么? -
我不明白你想说什么。请以代码形式回答。
-
`Hitesh Agashe` 能否提供一段代码来声明
snackBar属性?
标签: angular unit-testing jestjs karma-jasmine angular-unit-test