grafana/public/app/features/explore/MetaInfoText.test.tsx
Josh Hunt 3c6e0e8ef8
Chore: ESlint import order (#44959)
* Add and configure eslint-plugin-import

* Fix the lint:ts npm command

* Autofix + prettier all the files

* Manually fix remaining files

* Move jquery code in jest-setup to external file to safely reorder imports

* Resolve issue caused by circular dependencies within Prometheus

* Update .betterer.results

* Fix missing // @ts-ignore

* ignore iconBundle.ts

* Fix missing // @ts-ignore
2022-04-22 14:33:13 +01:00

28 lines
1.1 KiB
TypeScript

import { render, screen } from '@testing-library/react';
import React from 'react';
import { MetaInfoText, MetaItemProps } from './MetaInfoText';
describe('MetaInfoText', () => {
it('should render component and items', () => {
const items: MetaItemProps[] = [
{ label: 'label', value: 'value' },
{ label: 'label2', value: 'value2' },
];
render(<MetaInfoText metaItems={items} />);
expect(screen.getAllByTestId('meta-info-text')).toHaveLength(1);
expect(screen.getAllByTestId('meta-info-text-item')).toHaveLength(2);
expect(screen.getByText('label:')).toBeInTheDocument();
expect(screen.getByText('label2:')).toBeInTheDocument();
expect(screen.getByText(/^value$/)).toBeInTheDocument();
expect(screen.getByText(/^value2$/)).toBeInTheDocument();
});
it('should render component with no items when the array is empty', () => {
const items: MetaItemProps[] = [];
render(<MetaInfoText metaItems={items} />);
expect(screen.getAllByTestId('meta-info-text')).toHaveLength(1);
expect(screen.queryByTestId('meta-info-text-item')).toBeNull();
});
});