// Copyright (C) The Arvados Authors. All rights reserved.
//
// SPDX-License-Identifier: AGPL-3.0
import React from 'react';
import { mount, configure } from 'enzyme';
import { GroupMembersCount, ProcessStatus, ResourceFileSize } from './renderers';
import Adapter from "enzyme-adapter-react-16";
import { Provider } from 'react-redux';
import configureMockStore from 'redux-mock-store'
import { ResourceKind } from '../../models/resource';
import { ContainerRequestState as CR } from '../../models/container-request';
import { ContainerState as C } from '../../models/container';
import { ProcessStatus as PS } from '../../store/processes/process';
import { MuiThemeProvider } from '@material-ui/core';
import { CustomTheme } from 'common/custom-theme';
import { InlinePulser} from 'components/loading/inline-pulser';
import { ErrorIcon } from "components/icon/icon";
const middlewares = [];
const mockStore = configureMockStore(middlewares);
configure({ adapter: new Adapter() });
describe('renderers', () => {
let props: any = null;
describe('ProcessStatus', () => {
props = {
uuid: 'zzzzz-xvhdp-zzzzzzzzzzzzzzz',
theme: {
customs: {
colors: {
// Color values are arbitrary, but they should be
// representative of the colors used in the UI.
green800: 'rgb(0, 255, 0)',
red900: 'rgb(255, 0, 0)',
orange: 'rgb(240, 173, 78)',
grey600: 'rgb(128, 128, 128)',
}
},
spacing: {
unit: 8,
},
palette: {
common: {
white: 'rgb(255, 255, 255)',
},
},
},
};
[
// CR Status ; Priority ; C Status ; Exit Code ; C RuntimeStatus ; Expected label ; Expected bg color ; Expected fg color
[CR.COMMITTED, 1, C.RUNNING, null, {}, PS.RUNNING, props.theme.palette.common.white, props.theme.customs.colors.green800],
[CR.COMMITTED, 1, C.RUNNING, null, { error: 'whoops' }, PS.FAILING, props.theme.palette.common.white, props.theme.customs.colors.red900],
[CR.COMMITTED, 1, C.RUNNING, null, { warning: 'watch out!' }, PS.WARNING, props.theme.palette.common.white, props.theme.customs.colors.green800],
[CR.FINAL, 1, C.CANCELLED, null, {}, PS.CANCELLED, props.theme.customs.colors.red900, props.theme.palette.common.white],
[CR.FINAL, 1, C.COMPLETE, 137, {}, PS.FAILED, props.theme.customs.colors.red900, props.theme.palette.common.white],
[CR.FINAL, 1, C.COMPLETE, 0, {}, PS.COMPLETED, props.theme.customs.colors.green800, props.theme.palette.common.white],
[CR.COMMITTED, 0, C.LOCKED, null, {}, PS.ONHOLD, props.theme.customs.colors.grey600, props.theme.palette.common.white],
[CR.COMMITTED, 0, C.QUEUED, null, {}, PS.ONHOLD, props.theme.customs.colors.grey600, props.theme.palette.common.white],
[CR.COMMITTED, 1, C.LOCKED, null, {}, PS.QUEUED, props.theme.palette.common.white, props.theme.customs.colors.grey600],
[CR.COMMITTED, 1, C.QUEUED, null, {}, PS.QUEUED, props.theme.palette.common.white, props.theme.customs.colors.grey600],
].forEach(([crState, crPrio, cState, exitCode, rs, eLabel, eColor, tColor]) => {
it(`should render the state label '${eLabel}' and color '${eColor}' for CR state=${crState}, priority=${crPrio}, C state=${cState}, exitCode=${exitCode} and RuntimeStatus=${JSON.stringify(rs)}`, () => {
const containerUuid = 'zzzzz-dz642-zzzzzzzzzzzzzzz';
const store = mockStore({
resources: {
[props.uuid]: {
kind: ResourceKind.CONTAINER_REQUEST,
state: crState,
containerUuid: containerUuid,
priority: crPrio,
},
[containerUuid]: {
kind: ResourceKind.CONTAINER,
state: cState,
runtimeStatus: rs,
exitCode: exitCode,
},
}
});
const wrapper = mount(
);
expect(wrapper.text()).toEqual(eLabel);
expect(getComputedStyle(wrapper.getDOMNode())
.getPropertyValue('color')).toEqual(tColor);
expect(getComputedStyle(wrapper.getDOMNode())
.getPropertyValue('background-color')).toEqual(eColor);
});
})
});
describe('ResourceFileSize', () => {
beforeEach(() => {
props = {
uuid: 'UUID',
};
});
it('should render collection fileSizeTotal', () => {
// given
const store = mockStore({
resources: {
[props.uuid]: {
kind: ResourceKind.COLLECTION,
fileSizeTotal: 100,
}
}
});
// when
const wrapper = mount(
);
// then
expect(wrapper.text()).toContain('100 B');
});
it('should render 0 B as file size', () => {
// given
const store = mockStore({ resources: {} });
// when
const wrapper = mount(
);
// then
expect(wrapper.text()).toContain('0 B');
});
it('should render empty string for non collection resource', () => {
// given
const store1 = mockStore({
resources: {
[props.uuid]: {
kind: ResourceKind.PROJECT,
}
}
});
const store2 = mockStore({
resources: {
[props.uuid]: {
kind: ResourceKind.PROJECT,
}
}
});
// when
const wrapper1 = mount(
);
const wrapper2 = mount(
);
// then
expect(wrapper1.text()).toContain('');
expect(wrapper2.text()).toContain('');
});
});
describe('GroupMembersCount', () => {
let fakeGroup;
beforeEach(() => {
props = {
uuid: 'zzzzz-j7d0g-000000000000000',
};
fakeGroup = {
"canManage": true,
"canWrite": true,
"createdAt": "2020-09-24T22:52:57.546521000Z",
"deleteAt": null,
"description": "Test Group",
"etag": "0000000000000000000000000",
"frozenByUuid": null,
"groupClass": "role",
"href": `/groups/${props.uuid}`,
"isTrashed": false,
"kind": ResourceKind.GROUP,
"modifiedAt": "2020-09-24T22:52:57.545669000Z",
"modifiedByUserUuid": "zzzzz-tpzed-000000000000000",
"name": "System group",
"ownerUuid": "zzzzz-tpzed-000000000000000",
"properties": {},
"trashAt": null,
"uuid": props.uuid,
"writableBy": [
"zzzzz-tpzed-000000000000000",
]
};
});
it('shows loading group count when no memberCount', () => {
// Given
const store = mockStore({resources: {
[props.uuid]: fakeGroup,
}});
const wrapper = mount(
);
expect(wrapper.find(InlinePulser)).toHaveLength(1);
});
it('shows group count when memberCount present', () => {
// Given
const store = mockStore({resources: {
[props.uuid]: {
...fakeGroup,
"memberCount": 765,
}
}});
const wrapper = mount(
);
expect(wrapper.text()).toBe("765");
});
it('shows group count error icon when memberCount is null', () => {
// Given
const store = mockStore({resources: {
[props.uuid]: {
...fakeGroup,
"memberCount": null,
}
}});
const wrapper = mount(
);
expect(wrapper.find(ErrorIcon)).toHaveLength(1);
});
});
});