Cree una caja de arena que actuará como un contenedor de caja negra para todos sus espías, trozos, simulacros y falsificaciones.
Todo lo que tiene que hacer es crear un sandbox en el primer bloque de descripción para que sea accesible en todos los casos de prueba. Y una vez que haya terminado con todos los casos de prueba, debe liberar los métodos originales y limpiar los apéndices utilizando el método sandbox.restore()
en el gancho afterEach para que en tiempo de ejecución libere el afterEach
caso de prueba de recursos retenidos que se pasa o falla.
Aquí hay un ejemplo:
describe('MyController', () => {
//Creates a new sandbox object
const sandbox = sinon.createSandbox();
let myControllerInstance: MyController;
let loginStub: sinon.SinonStub;
beforeEach(async () => {
let config = {key: 'value'};
myControllerInstance = new MyController(config);
loginStub = sandbox.stub(ThirdPartyModule, 'login').resolves({success: true});
});
describe('MyControllerMethod1', () => {
it('should run successfully', async () => {
loginStub.withArgs({username: 'Test', password: 'Test'}).resolves();
let ret = await myControllerInstance.run();
expect(ret.status).to.eq('200');
expect(loginStub.called).to.be.true;
});
});
afterEach(async () => {
//clean and release the original methods afterEach test case at runtime
sandbox.restore();
});
});