/*
* Copyright OpenSearch Contributors
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
import { RoleList } from '../role-list';
import { mount, shallow } from 'enzyme';
import React from 'react';
import { EuiInMemoryTable, EuiTableFieldDataColumnType } from '@elastic/eui';
import { buildHashUrl } from '../../utils/url-builder';
import { Action, ResourceType } from '../../types';
import { RoleListing } from '../../utils/role-list-utils';
import { useDeleteConfirmState } from '../../utils/delete-confirm-modal-utils';
jest.mock('../../utils/role-list-utils');
jest.mock('../../utils/display-utils', () => ({
...jest.requireActual('../../utils/display-utils'),
ExternalLink: jest.fn(),
}));
jest.mock('../../utils/context-menu', () => ({
useContextMenuState: jest
.fn()
.mockImplementation((buttonText, buttonProps, children) => [children, jest.fn()]),
}));
jest.mock('../../utils/delete-confirm-modal-utils', () => ({
useDeleteConfirmState: jest.fn().mockReturnValue([jest.fn(), '']),
}));
// eslint-disable-next-line
const mockRoleListUtils = require('../../utils/role-list-utils');
describe('Role list', () => {
const setState = jest.fn();
const mockCoreStart = {
http: 1,
};
beforeEach(() => {
jest.spyOn(React, 'useState').mockImplementation((initialValue) => [initialValue, setState]);
});
it('Render empty', () => {
const mockRoleListingData = [
{
roleName: 'role_1',
reserved: true,
clusterPermission: ['readonly'],
indexPermission: ['data1'],
tenantPermission: ['tenant1'],
internaluser: [],
backendRoles: [],
},
];
mockRoleListUtils.transformRoleData = jest.fn().mockReturnValue(mockRoleListingData);
const component = shallow(
);
expect(component.find(EuiInMemoryTable).prop('items').length).toBe(0);
});
it('Render error', (done) => {
jest.spyOn(React, 'useEffect').mockImplementationOnce((f) => f());
// Hide the error message
jest.spyOn(console, 'log').mockImplementationOnce(() => {});
mockRoleListUtils.fetchRole.mockImplementationOnce(() => {
throw Error();
});
shallow(
);
process.nextTick(() => {
// Expect setting error to true
expect(setState).toHaveBeenCalledWith(true);
done();
});
});
it('Render data', (done) => {
jest.spyOn(React, 'useEffect').mockImplementationOnce((f) => f());
const mockRoleListingData = [
{
roleName: 'role_1',
reserved: true,
clusterPermission: ['readonly'],
indexPermission: ['data1'],
tenantPermission: ['tenant1'],
internaluser: [],
backendRoles: [],
},
];
mockRoleListUtils.transformRoleData = jest.fn().mockReturnValue(mockRoleListingData);
shallow(
);
process.nextTick(() => {
expect(mockRoleListUtils.fetchRole).toHaveBeenCalledTimes(1);
expect(mockRoleListUtils.fetchRoleMapping).toHaveBeenCalledTimes(1);
expect(mockRoleListUtils.transformRoleData).toHaveBeenCalledTimes(1);
expect(setState).toHaveBeenCalledWith(mockRoleListingData);
done();
});
});
it('delete role', (done) => {
shallow(
);
const deleteFunc = useDeleteConfirmState.mock.calls[0][0];
deleteFunc();
process.nextTick(() => {
expect(mockRoleListUtils.requestDeleteRoles).toBeCalled();
done();
});
});
it('error occurred while deleting the role', () => {
(mockRoleListUtils.requestDeleteRoles as jest.Mock).mockImplementationOnce(() => {
throw new Error();
});
const spy = jest.spyOn(console, 'log').mockImplementationOnce(() => {});
shallow(
);
const deleteFunc = useDeleteConfirmState.mock.calls[0][0];
deleteFunc();
expect(spy).toBeCalled();
});
describe('Action menu click', () => {
let component;
const mockRoleListingData: RoleListing = {
roleName: 'role_1',
reserved: true,
clusterPermissions: ['readonly'],
indexPermissions: ['data1'],
tenantPermissions: ['tenant1'],
internalUsers: [],
backendRoles: [],
};
beforeEach(() => {
jest.spyOn(React, 'useState').mockImplementation(() => [[mockRoleListingData], jest.fn()]);
component = shallow(
);
});
it('Edit click', () => {
component.find('[data-test-subj="edit"]').simulate('click');
expect(window.location.hash).toBe(
buildHashUrl(ResourceType.roles, Action.edit, mockRoleListingData.roleName)
);
});
it('Duplicate click', () => {
component.find('[data-test-subj="duplicate"]').simulate('click');
expect(window.location.hash).toBe(
buildHashUrl(ResourceType.roles, Action.duplicate, mockRoleListingData.roleName)
);
});
});
describe('Render columns', () => {
it('render role name column', () => {
const wrapper = shallow(
);
const roleList = wrapper.find('[data-test-subj="role-list"]');
const component = mount(<>{roleList}>);
const columns = component.prop>>('columns');
const roleNameRenderer = columns[0].render as (roleName: string) => JSX.Element;
const Container = (props: { roleName: string }) => roleNameRenderer(props.roleName);
const result = shallow();
expect(result).toMatchSnapshot();
});
it('render Customization column', () => {
const wrapper = shallow(
);
const roleList = wrapper.find('[data-test-subj="role-list"]');
const component = mount(<>{roleList}>);
const columns = component.prop>>('columns');
const customizationRenderer = columns[6].render as (reserved: boolean) => JSX.Element;
const Container = (props: { reserved: boolean }) => customizationRenderer(props.reserved);
const result = shallow();
expect(result).toMatchSnapshot();
});
});
});