Je travaille sur la création de tests unitaires de composants réactifs utilisant du moka, enzyme. Vous trouverez ci-dessous un exemple de composant.
Foo.js
class Foo extends React.Component {
customFunction=() => {
}
render() {
return (<div className={this.props.name}/>);
}
}
Et voici le fichier de test.
Foo-Test.js
import React from 'react';
import { expect } from 'chai';
import { shallow, mount, render } from 'enzyme';
import Foo from '../src/Foo';
describe("A suite", function() {
it("contains spec with an expectation", function() {
expect(shallow(<Foo />).contains(<div className="foo" />)).to.equal(true);
});
it("contains spec with an expectation", function() {
expect(shallow(<Foo />).is('.foo')).to.equal(true);
});
});
Tout est bon. mais je ne comprenais pas comment faire des tests unitaires avec CustomFunction dans Foo.js quand on utilise enzyme
La meilleure réponse à cette question dépend vraiment de ce que customFunction
fait réellement ...
Vous pouvez appeler la fonction comme ceci:
wrapper.instance().customFunction('foo', 'bar');
S'il s'agit d'une fonction qui définit l'état sur l'instance elle-même et affecte donc l'aspect de la sortie rendue, vous pouvez également appeler .update()
wrapper.instance().customFunction('foo', 'bar'); // uses setState internally
wrapper.update(); // updates render tree
// do assertions on the rendered output
Vous pouvez également utiliser le plugin chai pour espionner des fonctions personnalisées dans votre fichier jsx.
// to use this pluggin add this to the top of your testing file
const chai = require("chai"), spies = require("chai-spies");
chai.use(spies);
import Foo from "./<path to component>/Foo.jsx";
describe("Foo", () => {
it("a call to customFunction will not error", () => {
let spy = chai.spy(Foo.prototype, "customFunciton"); // spy
const wrapper = mount(<Foo/>);
wrapper.setProps({bar: "baz"}); // manipulate you component in some way
expect(spy).to.have.been.called.once();
});
});
@ leland-richardson a raison, cela dépend de ce que fait votre test. Comprendre qui vous aidera à composer de nouvelles façons de manipuler votre composant et ainsi faire des assertions.
Un autre exemple de test d'une fonction qui met à jour l'état de vos composants.
it("function will assert new state", () => {
const wrapper = shallow(<Foo {...props}/>);
wrapper.instance.customFunction(); // call custom function
wrapper.update();
expect(wrapper.state("bar")).to.equal("new-state");
});
Chai-spies dispose également d’une poignée d’accessoires en chaîne facilitant le test des fonctions personnalisées. Veuillez consulter les docs pour une explication plus détaillée.