je le composant suivant:Comment obtenir l'attribut de style du noeud DOM en utilisant Jest?
// Styled component.
export const StyledBtn = styled.button`
height: ${(height) => height};
`;
// Functional component.
const Btn = ({ height }) => <StyledBtn height={height} />;
export default Btn;
Je veux être en mesure de vérifier que la hauteur réelle (dans le DOM) est ce qui a été transmis à la composante Btn
(je ne veux pas vérifier la valeur de prop) . Voici comment j'envisager le test recherche:
test('button renders at the correct height',() => {
const btn = mount(<Btn height={20});
const node = findDOMNode(btn);
const height = node.getAttribute('height');
expect(height).toEqual('20');
});
Mais, le test échoue:
expect(received).toEqual(expected)
Expected value to equal:
"20"
Received:
null
Toute idée comment tester cela?
Je pense que votre code pour 'Btn' est erroné. Vous passez les accessoires à l'attribut 'height'. Il devrait être: 'const Btn = props => ;' –
ericgio
yup, désolé, mon erreur J'ai édité la question pour montrer la syntaxe correcte. Le problème existe toujours avec le code correct. – JoeTidee
y at-il une fonction '.props()' comme dans Enzyme? Vous pouvez faire '.props(). Style' si c'est le cas – AHB