Jest tests are currently organized into main configuration files (src/dev/jest/config.js and x-pack/dev-tools/jest/create_jest_config.js). Both of these are similar, but very slightly due to previously being in separate repositories. This change consolidates the scripts referenced in those configs and moves them to the `@kbn/test` project. OSS contained an alias for `test_utils`. Those aliases have been removed in favor of importing these utilities from `@kbn/test/jest` Blocker to #72569 Signed-off-by: Tyler Smalley <tyler.smalley@elastic.co>
108 lines
3.5 KiB
TypeScript
108 lines
3.5 KiB
TypeScript
/*
|
|
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
* or more contributor license agreements. Licensed under the Elastic License;
|
|
* you may not use this file except in compliance with the Elastic License.
|
|
*/
|
|
|
|
import React from 'react';
|
|
import { EuiLoadingSpinner, EuiNotificationBadge } from '@elastic/eui';
|
|
import { coreMock } from 'src/core/public/mocks';
|
|
import { mountWithIntl, shallowWithIntl } from '@kbn/test/jest';
|
|
import { DataPublicPluginStart } from '../../../../../src/plugins/data/public';
|
|
import { dataPluginMock } from '../../../../../src/plugins/data/public/mocks';
|
|
import { IndexPattern } from './types';
|
|
import { FieldItem } from './field_item';
|
|
import { FieldsAccordion, FieldsAccordionProps, FieldItemSharedProps } from './fields_accordion';
|
|
import { chartPluginMock } from '../../../../../src/plugins/charts/public/mocks';
|
|
|
|
describe('Fields Accordion', () => {
|
|
let defaultProps: FieldsAccordionProps;
|
|
let indexPattern: IndexPattern;
|
|
let core: ReturnType<typeof coreMock['createSetup']>;
|
|
let data: DataPublicPluginStart;
|
|
let fieldProps: FieldItemSharedProps;
|
|
|
|
beforeEach(() => {
|
|
indexPattern = {
|
|
id: '1',
|
|
title: 'my-fake-index-pattern',
|
|
timeFieldName: 'timestamp',
|
|
fields: [
|
|
{
|
|
name: 'timestamp',
|
|
type: 'date',
|
|
aggregatable: true,
|
|
searchable: true,
|
|
},
|
|
{
|
|
name: 'bytes',
|
|
type: 'number',
|
|
aggregatable: true,
|
|
searchable: true,
|
|
},
|
|
],
|
|
} as IndexPattern;
|
|
core = coreMock.createSetup();
|
|
data = dataPluginMock.createStartContract();
|
|
core.http.post.mockClear();
|
|
|
|
fieldProps = {
|
|
indexPattern,
|
|
data,
|
|
core,
|
|
highlight: '',
|
|
dateRange: {
|
|
fromDate: 'now-7d',
|
|
toDate: 'now',
|
|
},
|
|
query: { query: '', language: 'lucene' },
|
|
filters: [],
|
|
chartsThemeService: chartPluginMock.createSetupContract().theme,
|
|
};
|
|
|
|
defaultProps = {
|
|
initialIsOpen: true,
|
|
onToggle: jest.fn(),
|
|
id: 'id',
|
|
label: 'label',
|
|
hasLoaded: true,
|
|
fieldsCount: 2,
|
|
isFiltered: false,
|
|
paginatedFields: indexPattern.fields,
|
|
fieldProps,
|
|
renderCallout: <div id="lens-test-callout">Callout</div>,
|
|
exists: () => true,
|
|
};
|
|
});
|
|
|
|
it('renders correct number of Field Items', () => {
|
|
const wrapper = mountWithIntl(
|
|
<FieldsAccordion {...defaultProps} exists={(field) => field.name === 'timestamp'} />
|
|
);
|
|
expect(wrapper.find(FieldItem).at(0).prop('exists')).toEqual(true);
|
|
expect(wrapper.find(FieldItem).at(1).prop('exists')).toEqual(false);
|
|
});
|
|
|
|
it('passed correct exists flag to each field', () => {
|
|
const wrapper = mountWithIntl(<FieldsAccordion {...defaultProps} />);
|
|
expect(wrapper.find(FieldItem).length).toEqual(2);
|
|
});
|
|
|
|
it('renders callout if no fields', () => {
|
|
const wrapper = shallowWithIntl(
|
|
<FieldsAccordion {...defaultProps} fieldsCount={0} paginatedFields={[]} />
|
|
);
|
|
expect(wrapper.find('#lens-test-callout').length).toEqual(1);
|
|
});
|
|
|
|
it('renders accented notificationBadge state if isFiltered', () => {
|
|
const wrapper = mountWithIntl(<FieldsAccordion {...defaultProps} isFiltered={true} />);
|
|
expect(wrapper.find(EuiNotificationBadge).prop('color')).toEqual('accent');
|
|
});
|
|
|
|
it('renders spinner if has not loaded', () => {
|
|
const wrapper = mountWithIntl(<FieldsAccordion {...defaultProps} hasLoaded={false} />);
|
|
expect(wrapper.find(EuiLoadingSpinner).length).toEqual(1);
|
|
});
|
|
});
|