Skip to content

Commit

Permalink
Add database overview page filtering jest tests
Browse files Browse the repository at this point in the history
  • Loading branch information
arbulu89 committed Feb 27, 2023
1 parent 58c81fd commit 47d06ce
Showing 1 changed file with 134 additions and 0 deletions.
134 changes: 134 additions & 0 deletions assets/js/components/DatabasesOverview/DatabasesOverview.test.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,134 @@
import React from 'react';
import { screen, fireEvent } from '@testing-library/react';
import 'intersection-observer';
import '@testing-library/jest-dom';
import { databaseFactory } from '@lib/test-utils/factories';
import { renderWithRouter, withState } from '@lib/test-utils';
import { filterTable, clearFilter } from '@components/Table/Table.test';

import DatabasesOverview from './DatabasesOverview';

describe('DatabasesOverview component', () => {
describe('filtering', () => {
const cleanInitialState = {
hostsList: {
hosts: [],
},
clustersList: {
clusters: [],
},
databasesList: {
databases: [],
databaseInstances: [],
},
};

const scenarios = [
{
filter: 'Health',
options: ['unknown', 'passing', 'warning', 'critical'],
state: {
...cleanInitialState,
databasesList: {
databases: [].concat(
databaseFactory.buildList(2, { health: 'unknown' }),
databaseFactory.buildList(2, { health: 'passing' }),
databaseFactory.buildList(2, { health: 'warning' }),
databaseFactory.buildList(2, { health: 'critical' })
),
databaseInstances: [],
},
},
expectedRows: 2,
},
{
filter: 'SID',
options: ['PRD', 'QAS'],
state: {
...cleanInitialState,
databasesList: {
databases: [].concat(
databaseFactory.buildList(4),
databaseFactory.buildList(2, { sid: 'PRD' }),
databaseFactory.buildList(2, { sid: 'QAS' })
),
databaseInstances: [],
},
},
expectedRows: 2,
},
{
filter: 'Tags',
options: ['Tag1', 'Tag2'],
state: {
...cleanInitialState,
databasesList: {
databases: [].concat(
databaseFactory.buildList(2),
databaseFactory.buildList(2, { tags: [{ value: 'Tag1' }] }),
databaseFactory.buildList(2, { tags: [{ value: 'Tag2' }] })
),
databaseInstances: [],
},
},
expectedRows: 2,
},
];

it.each(scenarios)(
'should filter the table content by $filter filter',
({ filter, options, state, expectedRows }) => {
const [StatefulDatbaseList] = withState(<DatabasesOverview />, state);

renderWithRouter(StatefulDatbaseList);

options.forEach((option) => {
filterTable(filter, option);

const table = screen.getByRole('table');
expect(
table.querySelectorAll('tbody > tr.cursor-pointer')
).toHaveLength(expectedRows);

clearFilter(filter);
});
}
);

it('should put the filters values in the query string when filters are selected', () => {
const databases = databaseFactory.buildList(1, {
tags: [{ value: 'Tag1' }],
});

const state = {
...cleanInitialState,
databasesList: {
databases,
databaseInstances: [],
},
};

const { health, sid, tags } = databases[0];

const [StatefulDatabasesOverview] = withState(
<DatabasesOverview />,
state
);
renderWithRouter(StatefulDatabasesOverview);

['Health', 'SID', 'Tags'].forEach((filter) => {
fireEvent.click(screen.getByTestId(`filter-${filter}`));

fireEvent.click(
screen
.getByTestId(`filter-${filter}-options`)
.querySelector('li > div > span').firstChild
);
});

expect(window.location.search).toEqual(
`?health=${health}&sid=${sid}&tags=${tags[0].value}`
);
});
});
});

0 comments on commit 47d06ce

Please sign in to comment.