使用茉莉花进行代码覆盖的单元测试
Unit Test With Code coverage using jasmine
我有一个简单的记录器 .ts 文件。我正在尝试对其进行单元测试。如果有人帮助我修复我的单元测试。
logging.service.ts
import 'reflect-metadata'; // Required for tsyringe
import { singleton } from 'tsyringe';
import { Category } from 'typescript-logging';
@singleton()
export class Logger {
private logger: Category;
constructor(){
this.logger = new Category('oidc-security-logger');
}
trace(msg: string): void {
this.logger.trace(msg);
}
debug(msg: string): void {
this.logger.debug(msg);
}
info(msg: string): void {
this.logger.info(msg);
}
warn(msg: string): void {
this.logger.warn(msg);
}
error(msg: string, error?: Error): void {
if(error){
this.logger.error(msg, error);
} else {
this.logger.error(msg, null);
}
}
fatal(msg: string, error?: Error): void {
if (error) {
this.logger.fatal(msg, error);
} else {
this.logger.fatal(msg, null);
}
}
}
我试过用下面的方法来完成我的单元测试。
logging.service.spec.ts
import { Logger } from "./logging.service";
describe("Logger", () => {
let loggerMok: Logger;
beforeEach(() => {
loggerMok = new Logger();
});
it("should be test logger", () => {
const msg='This is for test';
spyOn(loggerMok,'trace').and.stub();
spyOn(loggerMok,'debug').and.stub();
spyOn(loggerMok,'info').and.stub();
spyOn(loggerMok,'warn').and.stub();
spyOn(loggerMok,'error').and.stub();
spyOn(loggerMok,'fatal').and.stub();
loggerMok.trace(msg);
loggerMok.debug(msg);
loggerMok.info(msg);
loggerMok.warn(msg);
loggerMok.error(msg);
loggerMok.fatal(msg);
expect(loggerMok.trace).toHaveBeenCalled();
expect(loggerMok.debug).toHaveBeenCalled();
expect(loggerMok.info).toHaveBeenCalled();
expect(loggerMok.warn).toHaveBeenCalled();
expect(loggerMok.error).toHaveBeenCalled();
expect(loggerMok.fatal).toHaveBeenCalled();
});
});
此单元测试运行良好,但代码覆盖率未给出分数。
您应该使用 callThrough
而不是 stub
。当你 stub
它不会调用实际的实现,基本上只是忽略调用。查看 Method stubs 了解更多信息。
当您使用 callThrough
时,它会调用实际实现,从而增加覆盖范围。所以你可以使用类似的东西:
it("should be test logger", () => {
const msg='This is for test';
spyOn(loggerMok,'trace').and.callThrough();
spyOn(loggerMok,'debug').and.callThrough();
spyOn(loggerMok,'info').and.callThrough();
spyOn(loggerMok,'warn').and.callThrough();
spyOn(loggerMok,'error').and.callThrough();
spyOn(loggerMok,'fatal').and.callThrough();
loggerMok.trace(msg);
loggerMok.debug(msg);
loggerMok.info(msg);
loggerMok.warn(msg);
loggerMok.error(msg);
loggerMok.fatal(msg);
expect(loggerMok.trace).toHaveBeenCalled();
expect(loggerMok.debug).toHaveBeenCalled();
expect(loggerMok.info).toHaveBeenCalled();
expect(loggerMok.warn).toHaveBeenCalled();
expect(loggerMok.error).toHaveBeenCalled();
expect(loggerMok.fatal).toHaveBeenCalled();
});
});
但是这个测试用例不是很有用,因为你所做的就是调用它,然后检查它是否被调用。相反,我建议监视 new Category
并检查它是否已被调用。
我有一个简单的记录器 .ts 文件。我正在尝试对其进行单元测试。如果有人帮助我修复我的单元测试。
logging.service.ts
import 'reflect-metadata'; // Required for tsyringe
import { singleton } from 'tsyringe';
import { Category } from 'typescript-logging';
@singleton()
export class Logger {
private logger: Category;
constructor(){
this.logger = new Category('oidc-security-logger');
}
trace(msg: string): void {
this.logger.trace(msg);
}
debug(msg: string): void {
this.logger.debug(msg);
}
info(msg: string): void {
this.logger.info(msg);
}
warn(msg: string): void {
this.logger.warn(msg);
}
error(msg: string, error?: Error): void {
if(error){
this.logger.error(msg, error);
} else {
this.logger.error(msg, null);
}
}
fatal(msg: string, error?: Error): void {
if (error) {
this.logger.fatal(msg, error);
} else {
this.logger.fatal(msg, null);
}
}
}
我试过用下面的方法来完成我的单元测试。 logging.service.spec.ts
import { Logger } from "./logging.service";
describe("Logger", () => {
let loggerMok: Logger;
beforeEach(() => {
loggerMok = new Logger();
});
it("should be test logger", () => {
const msg='This is for test';
spyOn(loggerMok,'trace').and.stub();
spyOn(loggerMok,'debug').and.stub();
spyOn(loggerMok,'info').and.stub();
spyOn(loggerMok,'warn').and.stub();
spyOn(loggerMok,'error').and.stub();
spyOn(loggerMok,'fatal').and.stub();
loggerMok.trace(msg);
loggerMok.debug(msg);
loggerMok.info(msg);
loggerMok.warn(msg);
loggerMok.error(msg);
loggerMok.fatal(msg);
expect(loggerMok.trace).toHaveBeenCalled();
expect(loggerMok.debug).toHaveBeenCalled();
expect(loggerMok.info).toHaveBeenCalled();
expect(loggerMok.warn).toHaveBeenCalled();
expect(loggerMok.error).toHaveBeenCalled();
expect(loggerMok.fatal).toHaveBeenCalled();
});
});
此单元测试运行良好,但代码覆盖率未给出分数。
您应该使用 callThrough
而不是 stub
。当你 stub
它不会调用实际的实现,基本上只是忽略调用。查看 Method stubs 了解更多信息。
当您使用 callThrough
时,它会调用实际实现,从而增加覆盖范围。所以你可以使用类似的东西:
it("should be test logger", () => {
const msg='This is for test';
spyOn(loggerMok,'trace').and.callThrough();
spyOn(loggerMok,'debug').and.callThrough();
spyOn(loggerMok,'info').and.callThrough();
spyOn(loggerMok,'warn').and.callThrough();
spyOn(loggerMok,'error').and.callThrough();
spyOn(loggerMok,'fatal').and.callThrough();
loggerMok.trace(msg);
loggerMok.debug(msg);
loggerMok.info(msg);
loggerMok.warn(msg);
loggerMok.error(msg);
loggerMok.fatal(msg);
expect(loggerMok.trace).toHaveBeenCalled();
expect(loggerMok.debug).toHaveBeenCalled();
expect(loggerMok.info).toHaveBeenCalled();
expect(loggerMok.warn).toHaveBeenCalled();
expect(loggerMok.error).toHaveBeenCalled();
expect(loggerMok.fatal).toHaveBeenCalled();
});
});
但是这个测试用例不是很有用,因为你所做的就是调用它,然后检查它是否被调用。相反,我建议监视 new Category
并检查它是否已被调用。