import { renderProps, renderClass, renderStyle } from '../src' describe('ssr: renderProps', () => { test('ignore reserved props', () => { expect( renderProps({ key: 1, ref: () => {}, onClick: () => {} }) ).toBe('') }) test('normal attrs', () => { expect( renderProps({ id: 'foo', title: 'bar' }) ).toBe(` id="foo" title="bar"`) }) test('escape attrs', () => { expect( renderProps({ id: '"> { expect( renderProps({ checked: true, multiple: false }) ).toBe(` checked`) // boolean attr w/ false should be ignored }) test('ignore falsy values', () => { expect( renderProps({ foo: false, title: null, baz: undefined }) ).toBe(` foo="false"`) // non boolean should render `false` as is }) test('props to attrs', () => { expect( renderProps({ readOnly: true, // simple lower case conversion htmlFor: 'foobar' // special cases }) ).toBe(` readonly for="foobar"`) }) test('preserve name on custom element', () => { expect( renderProps( { fooBar: 'ok' }, 'my-el' ) ).toBe(` fooBar="ok"`) }) }) describe('ssr: renderClass', () => { test('via renderProps', () => { expect( renderProps({ class: ['foo', 'bar'] }) ).toBe(` class="foo bar"`) }) test('standalone', () => { expect(renderClass(`foo`)).toBe(`foo`) expect(renderClass([`foo`, `bar`])).toBe(`foo bar`) expect(renderClass({ foo: true, bar: false })).toBe(`foo`) expect(renderClass([{ foo: true, bar: false }, `baz`])).toBe(`foo baz`) }) test('escape class values', () => { expect(renderClass(`"> { test('via renderProps', () => { expect( renderProps({ style: { color: 'red' } }) ).toBe(` style="color:red;"`) }) test('standalone', () => { expect(renderStyle(`color:red`)).toBe(`color:red`) expect( renderStyle({ color: `red` }) ).toBe(`color:red;`) expect( renderStyle([ { color: `red` }, { fontSize: `15px` } // case conversion ]) ).toBe(`color:red;font-size:15px;`) }) test('number handling', () => { expect( renderStyle({ fontSize: 15, // should be ignored since font-size requires unit opacity: 0.5 }) ).toBe(`opacity:0.5;`) }) test('escape inline CSS', () => { expect(renderStyle(`">