import React from 'react'
import { shallow } from 'enzyme'

import { NAMESPACE } from '../../../constants'
import { Grid } from '../'

describe('<Grid.Item />', () => {
  it('takes a default className', () => {
    const $ = shallow(<Grid.Item />)
    expect($.hasClass(`${NAMESPACE}o-grid__item`)).toBe(true)
  })

  it('takes a defined className', () => {
    const $ = shallow(<Grid.Item className="test" />)
    expect($.hasClass('test')).toBe(true)
  })

  it('renders the children', () => {
    const $ = shallow(
      <Grid.Item>
        <div className="test" />
      </Grid.Item>
    )
    expect($.contains(<div className="test" />)).toBe(true)
  })

  it('renders with attributes', () => {
    const $ = shallow(
      <Grid.Item style={{ position: 'relative' }} ariaHidden="true">
        _
      </Grid.Item>
    )
    expect($.prop('style')).toEqual({
      position: 'relative'
    })
    expect($.prop('ariaHidden')).toBe('true')
  })

  it('renders a defined tag type', () => {
    const $ = shallow(<Grid.Item tag="article" />)
    expect($.type()).toBe('article')
  })

  it('renders a div by default', () => {
    const $ = shallow(<Grid.Item />)
    expect($.type()).toBe('div')
  })

  it('takes a single width fraction', () => {
    const $ = shallow(<Grid.Item width="1/2" />)
    expect($.hasClass(`${NAMESPACE}o-grid__item ${NAMESPACE}u-1/2`)).toBe(true)
  })

  it('takes a list of width fractions', () => {
    const fractions = ['1/2', '1/3@sm', '1/4@lg']
    const $ = shallow(<Grid.Item width={fractions} />)
    expect($.hasClass(`${NAMESPACE}o-grid__item ${NAMESPACE}u-1/2 ${NAMESPACE}u-1/3@sm ${NAMESPACE}u-1/4@lg`)).toBe(true)
  })

  it('takes a single push fraction', () => {
    const $ = shallow(<Grid.Item push="1/2" />)
    expect($.hasClass(`${NAMESPACE}o-grid__item ${NAMESPACE}u-push-1/2`)).toBe(true)
  })

  it('takes a list of push fractions', () => {
    const fractions = ['1/2', '1/3@sm']
    const $ = shallow(<Grid.Item push={fractions} />)
    expect($.hasClass(`${NAMESPACE}o-grid__item ${NAMESPACE}u-push-1/2 ${NAMESPACE}u-push-1/3@sm`)).toBe(true)
  })

  it('takes a single pull fraction', () => {
    const $ = shallow(<Grid.Item pull="1/2" />)
    expect($.hasClass(`${NAMESPACE}o-grid__item ${NAMESPACE}u-pull-1/2`)).toBe(true)
  })

  it('takes a list of pull fractions', () => {
    const fractions = ['1/2']
    const $ = shallow(<Grid.Item pull={fractions} />)
    expect($.hasClass(`${NAMESPACE}o-grid__item ${NAMESPACE}u-pull-1/2`)).toBe(true)
  })
})
