mirror of https://github.com/renovatebot/renovate
642 lines
15 KiB
JavaScript
642 lines
15 KiB
JavaScript
/* eslint-env mocha */
|
|
/* eslint-disable react/no-multi-comp, react/prop-types */
|
|
|
|
import React from 'react';
|
|
import expect from 'expect';
|
|
import {createRenderer} from 'react-addons-test-utils';
|
|
import reactElementToJSXString from './index';
|
|
import AnonymousStatelessComponent from './AnonymousStatelessComponent';
|
|
|
|
class TestComponent extends React.Component {}
|
|
|
|
function NamedStatelessComponent(props) {
|
|
const {children} = props;
|
|
return <div>{children}</div>;
|
|
}
|
|
|
|
class DefaultPropsComponent extends React.Component {}
|
|
|
|
DefaultPropsComponent.defaultProps = {test: 'test'};
|
|
|
|
class DisplayNamePrecedence extends React.Component {}
|
|
|
|
DisplayNamePrecedence.displayName = 'This should take precedence';
|
|
|
|
describe('reactElementToJSXString(ReactElement)', () => {
|
|
it('reactElementToJSXString(<TestComponent/>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<TestComponent/>)
|
|
).toEqual('<TestComponent />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<NamedStatelessComponent/>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<NamedStatelessComponent/>)
|
|
).toEqual('<NamedStatelessComponent />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<AnonymousStatelessComponent/>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<AnonymousStatelessComponent/>)
|
|
).toEqual('<No Display Name />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<AnonymousStatelessComponent/>) with a displayName', () => {
|
|
AnonymousStatelessComponent.displayName = 'I have a name!';
|
|
|
|
expect(
|
|
reactElementToJSXString(<AnonymousStatelessComponent/>)
|
|
).toEqual('<I have a name! />');
|
|
|
|
delete AnonymousStatelessComponent.displayName;
|
|
});
|
|
|
|
it('reactElementToJSXString(React.createElement(\'div\'))', () => {
|
|
expect(
|
|
reactElementToJSXString(React.createElement('div'))
|
|
).toEqual('<div />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div/>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div/>)
|
|
).toEqual('<div />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div fn={() => {}}/>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div fn={() => {}}/>)
|
|
).toEqual('<div fn={function noRefCheck() {}} />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div fn={function hello(){}}/>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div fn={function hello() {}}/>)
|
|
).toEqual('<div fn={function noRefCheck() {}} />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div co={<div a="1" />} />)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div co={<div a="1" />}/>)
|
|
).toEqual('<div co={<div a="1" />} />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div re={/^Hello world$/} />)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div re={/^Hello world$/}/>)
|
|
).toEqual('<div re={/^Hello world$/} />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div int={8}/>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div int={8}/>)
|
|
).toEqual('<div int={8} />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div obj={{hello: \'world\'}}/>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div obj={{hello: 'world'}}/>)
|
|
).toEqual(`<div
|
|
obj={{
|
|
hello: 'world'
|
|
}}
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div obj={{hello: [1, 2], world: {nested: true}}}/>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div obj={{hello: [1, 2], world: {nested: true}}}/>)
|
|
).toEqual(`<div
|
|
obj={{
|
|
hello: [
|
|
1,
|
|
2
|
|
],
|
|
world: {
|
|
nested: true
|
|
}
|
|
}}
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div></div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div></div>)
|
|
).toEqual('<div />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div z="3" a="1" b="2"/>)', () => {
|
|
/* eslint react/jsx-sort-props: 0 */
|
|
expect(
|
|
reactElementToJSXString(<div z="3" a="1" b="2"/>)
|
|
).toEqual(
|
|
`<div
|
|
a="1"
|
|
b="2"
|
|
z="3"
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a="1">Hello</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a="1">Hello</div>)
|
|
).toEqual(
|
|
`<div a="1">
|
|
Hello
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a="1" b="5">Hello</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a="1" b="5">Hello</div>)
|
|
).toEqual(
|
|
`<div
|
|
a="1"
|
|
b="5"
|
|
>
|
|
Hello
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>Hello</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>Hello</div>)
|
|
).toEqual(
|
|
`<div>
|
|
Hello
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>Hello</div>, {tabStop: 4})', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>Hello</div>, {tabStop: 4})
|
|
).toEqual(
|
|
`<div>
|
|
Hello
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div><div>Hello</div></div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div><div>Hello</div></div>)
|
|
).toEqual(
|
|
`<div>
|
|
<div>
|
|
Hello
|
|
</div>
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div><div>Hello</div></div>, {tabStop: 4})', () => {
|
|
expect(
|
|
reactElementToJSXString(<div><div>Hello</div></div>, {tabStop: 4})
|
|
).toEqual(
|
|
`<div>
|
|
<div>
|
|
Hello
|
|
</div>
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a="1" b="2"><div>Hello</div></div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a="1" b="2"><div>Hello</div></div>)
|
|
).toEqual(
|
|
`<div
|
|
a="1"
|
|
b="2"
|
|
>
|
|
<div>
|
|
Hello
|
|
</div>
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a="1" b="2"><div>Hello</div></div>, {tabStop: 4})', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a="1" b="2"><div>Hello</div></div>, {tabStop: 4})
|
|
).toEqual(
|
|
`<div
|
|
a="1"
|
|
b="2"
|
|
>
|
|
<div>
|
|
Hello
|
|
</div>
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={{a: "1", b: {c: "3"}}}><div b={{c: {d: "4"}}}>Hello</div></div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(
|
|
<div a={{a: '1', b: {c: '3'}}}><div b={{c: {d: '4'}}}>Hello</div></div>,
|
|
)
|
|
).toEqual(
|
|
`<div
|
|
a={{
|
|
a: '1',
|
|
b: {
|
|
c: '3'
|
|
}
|
|
}}
|
|
>
|
|
<div
|
|
b={{
|
|
c: {
|
|
d: '4'
|
|
}
|
|
}}
|
|
>
|
|
Hello
|
|
</div>
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString()', () => {
|
|
expect(() => {
|
|
reactElementToJSXString();
|
|
}).toThrow('react-element-to-jsx-string: Expected a ReactElement');
|
|
});
|
|
|
|
it('reactElementToJSXString(null)', () => {
|
|
expect(() => {
|
|
reactElementToJSXString(null);
|
|
}).toThrow('react-element-to-jsx-string: Expected a ReactElement');
|
|
});
|
|
|
|
it('ignores object keys order (sortobject)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div o={{a: 1, b: 2}}/>)
|
|
).toEqual(
|
|
reactElementToJSXString(<div o={{b: 2, a: 1}}/>)
|
|
);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={null} />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={null} />)
|
|
).toEqual(
|
|
reactElementToJSXString(<div a={null} />)
|
|
);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={undefined} />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={undefined} />)
|
|
).toEqual(
|
|
reactElementToJSXString(<div a={undefined} />)
|
|
);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={{b: function hello() {}}} />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={{b: function hello() {}}} />)
|
|
).toEqual(`<div
|
|
a={{
|
|
b: function noRefCheck() {}
|
|
}}
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={{b: {c: {d: <div />, e: null}}}} />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={{b: {c: {d: <div />, e: null}}}} />)
|
|
).toEqual(`<div
|
|
a={{
|
|
b: {
|
|
c: {
|
|
d: <div />,
|
|
e: null
|
|
}
|
|
}
|
|
}}
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={{b: {}}} />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={{b: {}}} />)
|
|
).toEqual(`<div
|
|
a={{
|
|
b: {}
|
|
}}
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={{}} />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={{}} />)
|
|
).toEqual('<div a={{}} />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div><span /><span /></div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div><span /><span /></div>)
|
|
).toEqual(`<div>
|
|
<span />
|
|
<span />
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>foo<div /></div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>foo<div /></div>)
|
|
).toEqual(`<div>
|
|
foo
|
|
<div />
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={[1, 2, 3, 4]} />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={[1, 2, 3, 4]} />)
|
|
).toEqual(`<div
|
|
a={[
|
|
1,
|
|
2,
|
|
3,
|
|
4
|
|
]}
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={[{Hello: \', world!\'}]} />)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={[{Hello: ', world!'}]} />)
|
|
).toEqual(`<div
|
|
a={[
|
|
{
|
|
Hello: ', world!'
|
|
}
|
|
]}
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={[{}]} />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={[{}]} />)
|
|
).toEqual(`<div
|
|
a={[
|
|
{}
|
|
]}
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={[]} />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={[]} />)
|
|
).toEqual('<div a={[]} />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div a={[<div key="0"><span /></div>]} />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div a={[<div key="0"><span /></div>]} />)
|
|
).toEqual(`<div
|
|
a={[
|
|
<div key="0"><span /></div>
|
|
]}
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(decorator(<span />)', () => {
|
|
function myDecorator(ComposedComponent) {
|
|
class MyDecorator extends React.Component {
|
|
render() {
|
|
return (
|
|
<div>
|
|
{React.createElement(ComposedComponent.type, this.props)}
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
MyDecorator.displayName = `${ComposedComponent.name}-Decorated`;
|
|
return MyDecorator;
|
|
}
|
|
|
|
const NestedSpan = myDecorator(<span />);
|
|
const renderer = createRenderer();
|
|
renderer.render(<NestedSpan />);
|
|
expect(
|
|
reactElementToJSXString(renderer.getRenderOutput())
|
|
).toEqual(`<div>
|
|
<span />
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>Hello {this.props.name}</div>', () => {
|
|
class InlineProps extends React.Component {
|
|
render() {
|
|
return <div>Hello {this.props.name}</div>;
|
|
}
|
|
}
|
|
|
|
const renderer = createRenderer();
|
|
renderer.render(<InlineProps name="John" />);
|
|
const actualElement = renderer.getRenderOutput();
|
|
expect(reactElementToJSXString(actualElement))
|
|
.toEqual(
|
|
`<div>
|
|
Hello John
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div aprop="test" ref="yes" />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div aprop="test" ref="yes" />)
|
|
).toEqual(
|
|
`<div
|
|
ref="yes"
|
|
aprop="test"
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div aprop="a" ref="yes"><span ref="wee" zprop="z"/></div>', () => {
|
|
expect(
|
|
reactElementToJSXString(<div aprop="a" ref="yes"><span ref="wee" zprop="z"/></div>)
|
|
).toEqual(
|
|
`<div
|
|
ref="yes"
|
|
aprop="a"
|
|
>
|
|
<span
|
|
ref="wee"
|
|
zprop="z"
|
|
/>
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div aprop="test" key="yes" />', () => {
|
|
expect(
|
|
reactElementToJSXString(<div aprop="test" key="yes" />)
|
|
).toEqual(
|
|
`<div
|
|
key="yes"
|
|
aprop="test"
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>\\n {null}\\n</div>', () => {
|
|
const element = <div>
|
|
{null}
|
|
</div>;
|
|
|
|
expect(reactElementToJSXString(element)).toEqual('<div />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>{true}</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>{true}</div>)
|
|
).toEqual('<div />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>{false}</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>{false}</div>)
|
|
).toEqual('<div />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>{false}</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>
|
|
{false}
|
|
</div>)
|
|
).toEqual(
|
|
reactElementToJSXString(<div></div>)
|
|
);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>\n{false}\n</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>
|
|
{false}
|
|
</div>)
|
|
).toEqual('<div />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div> {false} </div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div> {false} </div>)
|
|
).toEqual('<div>\n \n</div>');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>{null}</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>{null}</div>)
|
|
).toEqual('<div />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>{123}</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>{123}</div>)
|
|
).toEqual(`<div>
|
|
123
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>{\'\'}</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>{''}</div>)
|
|
).toEqual(reactElementToJSXString(<div/>));
|
|
});
|
|
|
|
it('reactElementToJSXString(<div>String with {1} js expression</div>)', () => {
|
|
expect(
|
|
reactElementToJSXString(<div>String with {1} js number</div>)
|
|
).toEqual(`<div>
|
|
String with 1 js number
|
|
</div>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<TestComponent />, { displayName: toUpper })', () => {
|
|
expect(
|
|
reactElementToJSXString(<TestComponent />, {
|
|
displayName: element => element.type.name.toUpperCase(),
|
|
})
|
|
).toEqual('<TESTCOMPONENT />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<TestComponent />, { filterProps: [\'key\', \'className\'] })', () => {
|
|
expect(
|
|
reactElementToJSXString(<TestComponent a="b" key="aKey" className="aClass" />, {
|
|
filterProps: ['key', 'className'],
|
|
})
|
|
).toEqual('<TestComponent a="b" />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<TestComponent />, { useBooleanShorthandSyntax: false })', () => {
|
|
expect(
|
|
reactElementToJSXString(<TestComponent testTrue={true} testFalse={false} />, {
|
|
useBooleanShorthandSyntax: false,
|
|
})
|
|
).toEqual(
|
|
`<TestComponent
|
|
testFalse={false}
|
|
testTrue={true}
|
|
/>`);
|
|
});
|
|
|
|
it('should render default props', () => {
|
|
expect(
|
|
reactElementToJSXString(<DefaultPropsComponent />)
|
|
).toEqual('<DefaultPropsComponent test="test" />');
|
|
});
|
|
|
|
it('should not render default props if "showDefaultProps" option is false', () => {
|
|
expect(
|
|
reactElementToJSXString(<DefaultPropsComponent />, {showDefaultProps: false})
|
|
).toEqual('<DefaultPropsComponent />');
|
|
});
|
|
|
|
it('should render props that differ from their defaults if "showDefaultProps" option is false', () => {
|
|
expect(
|
|
reactElementToJSXString(<DefaultPropsComponent test="foo" />, {showDefaultProps: false})
|
|
).toEqual('<DefaultPropsComponent test="foo" />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div co={<div a="1" />} />, { displayName: toUpper })', () => {
|
|
expect(
|
|
reactElementToJSXString(<div co={<div a="1" />} />, {
|
|
displayName: element => element.type.toUpperCase(),
|
|
})
|
|
).toEqual('<DIV co={<DIV a="1" />} />');
|
|
});
|
|
|
|
it('reactElementToJSXString(<div co={{a: <div a="1" />}} />, { displayName: toUpper })', () => {
|
|
expect(
|
|
reactElementToJSXString(<div co={{a: <div a="1" />}} />, {
|
|
displayName: element => element.type.toUpperCase(),
|
|
})
|
|
).toEqual(`<DIV
|
|
co={{
|
|
a: <DIV a="1" />
|
|
}}
|
|
/>`);
|
|
});
|
|
it('should omit true as value', () => {
|
|
expect(
|
|
reactElementToJSXString(<div primary={true} />) // eslint-disable-line react/jsx-boolean-value
|
|
).toEqual('<div primary />');
|
|
});
|
|
it('should omit attributes with false as value', () => {
|
|
expect(
|
|
reactElementToJSXString(<div primary={false} />) // eslint-disable-line react/jsx-boolean-value
|
|
).toEqual('<div />');
|
|
});
|
|
|
|
it('should return the actual functions when "showFunctions" is true', () => {
|
|
expect(
|
|
reactElementToJSXString(<div fn={() => 'value'}/>, {showFunctions: true})
|
|
).toEqual(`<div
|
|
fn={function fn() {
|
|
return 'value';
|
|
}}
|
|
/>`);
|
|
});
|
|
|
|
it('reactElementToJSXString(<DisplayNamePrecedence />)', () => {
|
|
expect(
|
|
reactElementToJSXString(<DisplayNamePrecedence />)
|
|
).toEqual('<This should take precedence />');
|
|
});
|
|
});
|