UNPKG

style-it

Version:

Component for writing plaintext CSS in React apps -- isomorphic, scoped, FOUC-free, fully featured, CSS-in-JS

37 lines (31 loc) 1.21 kB
import React from 'react'; import { findDOMNode, render } from 'react-dom'; import TestUtils from 'react-addons-test-utils'; const removeNewlines = (string) => (string.replace(/(\r\n|\n|\r)/gm, '')) import Style from '../src/index.js'; describe('Style-09', () => { it('does not scope keyframe selectors or keyframe offset % syntax', () => { const wrapper = TestUtils.renderIntoDocument( <div> <Style> {` @keyframes NAME-YOUR-ANIMATION { 0% { opacity: 0; } 100% { opacity: 1; } } #box { animation: NAME-YOUR-ANIMATION 5s infinite; } `} <div id="box"></div> </Style> </div> ); const rootNode = findDOMNode(wrapper).children[0]; const styleNode = rootNode.children[0]; const scopedClass = rootNode.className.split(' ').slice(-1)[0]; expect(rootNode.className).toEqual(`${scopedClass}`); expect( removeNewlines(styleNode.textContent) ) .toEqual(` @keyframes NAME-YOUR-ANIMATION { 0% { opacity: 0; } 100% { opacity: 1; }} #box.${scopedClass} , .${scopedClass} #box { animation: NAME-YOUR-ANIMATION 5s infinite; }`); }); });