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

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

describe('<Pagination.Item />', () => {
  it('renders with appropriate classNames', () => {
    const $ = shallow(<Pagination.Item className="test">Test</Pagination.Item>)
    expect($.hasClass(`${NAMESPACE}c-pagination__item`)).toBe(true)
    expect($.hasClass('test')).toBe(true)
  })

  it('renders children', () => {
    const $ = shallow(
      <Pagination.Item>
        Item text
      </Pagination.Item>
    )
    expect($.contains('Item text')).toBe(true)
  })

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

  it('renders an li by default', () => {
    const $ = shallow(<Pagination.Item>_</Pagination.Item>)
    expect($.type()).toBe('li')
  })

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