mirror of
https://github.com/tooot-app/app
synced 2024-12-27 18:02:34 +01:00
60 lines
1.5 KiB
JavaScript
60 lines
1.5 KiB
JavaScript
import React from 'react'
|
|
import {
|
|
toBeDisabled,
|
|
toContainElement,
|
|
toHaveStyle,
|
|
toHaveTextContent
|
|
} from '@testing-library/jest-native'
|
|
import { cleanup, render } from '@testing-library/react-native/pure'
|
|
|
|
import Card from '@components/Timelines/Timeline/Shared/Card'
|
|
|
|
expect.extend({
|
|
toBeDisabled,
|
|
toContainElement,
|
|
toHaveStyle,
|
|
toHaveTextContent
|
|
})
|
|
|
|
describe('Testing component timeline card', () => {
|
|
afterEach(cleanup)
|
|
|
|
it('with text only', () => {
|
|
const { getByTestId, queryByTestId, toJSON } = render(
|
|
<Card
|
|
card={{
|
|
url: 'http://example.com',
|
|
title: 'Title'
|
|
}}
|
|
/>
|
|
)
|
|
|
|
expect(queryByTestId('image')).toBeNull()
|
|
expect(getByTestId('base')).toContainElement(getByTestId('title'))
|
|
expect(queryByTestId('description')).toBeNull()
|
|
|
|
expect(getByTestId('title')).toHaveTextContent('Title')
|
|
expect(toJSON()).toMatchSnapshot()
|
|
})
|
|
|
|
it('with text and description', () => {
|
|
const { getByTestId, queryByTestId, toJSON } = render(
|
|
<Card
|
|
card={{
|
|
url: 'http://example.com',
|
|
title: 'Title',
|
|
description: 'Description'
|
|
}}
|
|
/>
|
|
)
|
|
|
|
expect(queryByTestId('image')).toBeNull()
|
|
expect(getByTestId('base')).toContainElement(getByTestId('title'))
|
|
expect(getByTestId('base')).toContainElement(getByTestId('description'))
|
|
|
|
expect(getByTestId('title')).toHaveTextContent('Title')
|
|
expect(getByTestId('description')).toHaveTextContent('Description')
|
|
expect(toJSON()).toMatchSnapshot()
|
|
})
|
|
})
|