181 lines
5.5 KiB
JavaScript
181 lines
5.5 KiB
JavaScript
import { GlIcon } from '@gitlab/ui';
|
|
import { mount } from '@vue/test-utils';
|
|
import { trimText } from 'helpers/text_helper';
|
|
import { TEST_HOST } from 'helpers/test_constants';
|
|
import Reviewer from '~/sidebar/components/reviewers/reviewers.vue';
|
|
|
|
const usersMock = (id = 1) => ({
|
|
id,
|
|
name: 'Root',
|
|
state: 'active',
|
|
username: 'root',
|
|
webUrl: `${TEST_HOST}/root`,
|
|
avatarUrl: `${TEST_HOST}/avatar/root.png`,
|
|
mergeRequestInteraction: {
|
|
canMerge: true,
|
|
canUpdate: true,
|
|
reviewed: true,
|
|
approved: false,
|
|
},
|
|
});
|
|
|
|
describe('Reviewer component', () => {
|
|
const getDefaultProps = () => ({
|
|
rootPath: 'http://localhost:3000',
|
|
users: [],
|
|
editable: false,
|
|
});
|
|
let wrapper;
|
|
|
|
const createWrapper = (propsData = getDefaultProps()) => {
|
|
wrapper = mount(Reviewer, {
|
|
propsData,
|
|
});
|
|
};
|
|
|
|
const findCollapsedChildren = () => wrapper.findAll('.sidebar-collapsed-icon > *');
|
|
|
|
afterEach(() => {
|
|
wrapper.destroy();
|
|
});
|
|
|
|
describe('No reviewers/users', () => {
|
|
it('displays no reviewer icon when collapsed', () => {
|
|
createWrapper();
|
|
const collapsedChildren = findCollapsedChildren();
|
|
const userIcon = collapsedChildren.at(0).find(GlIcon);
|
|
|
|
expect(collapsedChildren.length).toBe(1);
|
|
expect(collapsedChildren.at(0).attributes('aria-label')).toBe('None');
|
|
expect(userIcon.exists()).toBe(true);
|
|
expect(userIcon.props('name')).toBe('user');
|
|
});
|
|
});
|
|
|
|
describe('One reviewer/user', () => {
|
|
it('displays one reviewer icon when collapsed', () => {
|
|
createWrapper({
|
|
...getDefaultProps(),
|
|
users: [usersMock()],
|
|
});
|
|
|
|
const collapsedChildren = findCollapsedChildren();
|
|
const reviewer = collapsedChildren.at(0);
|
|
|
|
expect(collapsedChildren.length).toBe(1);
|
|
expect(reviewer.find('.avatar').attributes('src')).toContain('avatar/root.png');
|
|
expect(reviewer.find('.avatar').attributes('alt')).toBe(`Root's avatar`);
|
|
|
|
expect(trimText(reviewer.find('.author').text())).toBe('Root');
|
|
});
|
|
});
|
|
|
|
describe('Two or more reviewers/users', () => {
|
|
it('displays two reviewer icons when collapsed', () => {
|
|
const users = [usersMock(), usersMock(2)];
|
|
createWrapper({
|
|
...getDefaultProps(),
|
|
users,
|
|
});
|
|
|
|
const collapsedChildren = findCollapsedChildren();
|
|
|
|
expect(collapsedChildren.length).toBe(2);
|
|
|
|
const first = collapsedChildren.at(0);
|
|
|
|
expect(first.find('.avatar').attributes('src')).toBe(users[0].avatarUrl);
|
|
expect(first.find('.avatar').attributes('alt')).toBe(`${users[0].name}'s avatar`);
|
|
|
|
expect(trimText(first.find('.author').text())).toBe(users[0].name);
|
|
|
|
const second = collapsedChildren.at(1);
|
|
|
|
expect(second.find('.avatar').attributes('src')).toBe(users[1].avatarUrl);
|
|
expect(second.find('.avatar').attributes('alt')).toBe(`${users[1].name}'s avatar`);
|
|
|
|
expect(trimText(second.find('.author').text())).toBe(users[1].name);
|
|
});
|
|
|
|
it('displays one reviewer icon and counter when collapsed', () => {
|
|
const users = [usersMock(), usersMock(2), usersMock(3)];
|
|
createWrapper({
|
|
...getDefaultProps(),
|
|
users,
|
|
});
|
|
|
|
const collapsedChildren = findCollapsedChildren();
|
|
|
|
expect(collapsedChildren.length).toBe(2);
|
|
|
|
const first = collapsedChildren.at(0);
|
|
|
|
expect(first.find('.avatar').attributes('src')).toBe(users[0].avatarUrl);
|
|
expect(first.find('.avatar').attributes('alt')).toBe(`${users[0].name}'s avatar`);
|
|
|
|
expect(trimText(first.find('.author').text())).toBe(users[0].name);
|
|
|
|
const second = collapsedChildren.at(1);
|
|
|
|
expect(trimText(second.find('.avatar-counter').text())).toBe('+2');
|
|
});
|
|
|
|
it('Shows two reviewers', () => {
|
|
const users = [usersMock(), usersMock(2)];
|
|
createWrapper({
|
|
...getDefaultProps(),
|
|
users,
|
|
editable: true,
|
|
});
|
|
|
|
expect(wrapper.findAll('[data-testid="reviewer"]').length).toBe(users.length);
|
|
});
|
|
|
|
it('shows sorted reviewer where "can merge" users are sorted first', () => {
|
|
const users = [usersMock(), usersMock(2), usersMock(3)];
|
|
users[0].mergeRequestInteraction.canMerge = false;
|
|
users[1].mergeRequestInteraction.canMerge = false;
|
|
users[2].mergeRequestInteraction.canMerge = true;
|
|
|
|
createWrapper({
|
|
...getDefaultProps(),
|
|
users,
|
|
editable: true,
|
|
});
|
|
|
|
expect(wrapper.vm.sortedReviewers[0].mergeRequestInteraction.canMerge).toBe(true);
|
|
});
|
|
|
|
it('passes the sorted reviewers to the uncollapsed-reviewer-list', () => {
|
|
const users = [usersMock(), usersMock(2), usersMock(3)];
|
|
users[0].mergeRequestInteraction.canMerge = false;
|
|
users[1].mergeRequestInteraction.canMerge = false;
|
|
users[2].mergeRequestInteraction.canMerge = true;
|
|
|
|
createWrapper({
|
|
...getDefaultProps(),
|
|
users,
|
|
});
|
|
|
|
const userItems = wrapper.findAll('[data-testid="reviewer"]');
|
|
|
|
expect(userItems.length).toBe(3);
|
|
});
|
|
|
|
it('passes the sorted reviewers to the collapsed-reviewer-list', () => {
|
|
const users = [usersMock(), usersMock(2), usersMock(3)];
|
|
users[0].mergeRequestInteraction.canMerge = false;
|
|
users[1].mergeRequestInteraction.canMerge = false;
|
|
users[2].mergeRequestInteraction.canMerge = true;
|
|
|
|
createWrapper({
|
|
...getDefaultProps(),
|
|
users,
|
|
});
|
|
|
|
const collapsedButton = wrapper.find('.sidebar-collapsed-user button');
|
|
|
|
expect(trimText(collapsedButton.text())).toBe(users[2].name);
|
|
});
|
|
});
|
|
});
|