Commit 8d390d16 authored by Lukas Eipert's avatar Lukas Eipert

Promotions now don't show unnecessary header

Previously promotion columns did show unnecessary headers (adding issues
and WIP config). This adds a check and proper tests.
parent d3d56f11
...@@ -80,7 +80,8 @@ export default { ...@@ -80,7 +80,8 @@ export default {
return ( return (
!this.disabled && !this.disabled &&
this.list.type !== ListType.closed && this.list.type !== ListType.closed &&
this.list.type !== ListType.blank this.list.type !== ListType.blank &&
this.list.type !== ListType.promotion
); );
}, },
issuesTooltip() { issuesTooltip() {
......
export default { export default {
computed: { computed: {
isWipLimitsOn() { isWipLimitsOn() {
return gon.features.wipLimits; return Boolean(gon?.features?.wipLimits);
}, },
}, },
}; };
import Vue from 'vue';
import { shallowMount } from '@vue/test-utils';
import AxiosMockAdapter from 'axios-mock-adapter';
import Board from 'ee/boards/components/board_column.vue';
import List from '~/boards/models/list';
import { ListType } from '~/boards/constants';
import axios from '~/lib/utils/axios_utils';
import { TEST_HOST } from 'helpers/test_constants';
import { listObj } from 'jest/boards/mock_data';
describe('Board Column Component', () => {
let wrapper;
let axiosMock;
beforeEach(() => {
window.gon = {};
axiosMock = new AxiosMockAdapter(axios);
axiosMock.onGet(`${TEST_HOST}/lists/1/issues`).reply(200, { issues: [] });
});
afterEach(() => {
axiosMock.restore();
wrapper.destroy();
localStorage.clear();
});
const createComponent = ({
listType = ListType.backlog,
collapsed = false,
withLocalStorage = true,
} = {}) => {
const boardId = '1';
const listMock = {
...listObj,
list_type: listType,
collapsed,
};
if (listType === ListType.assignee) {
delete listMock.label;
listMock.user = {};
}
// Making List reactive
const list = Vue.observable(new List(listMock));
if (withLocalStorage) {
localStorage.setItem(
`boards.${boardId}.${list.type}.${list.id}.expanded`,
(!collapsed).toString(),
);
}
wrapper = shallowMount(Board, {
propsData: {
boardId,
disabled: false,
issueLinkBase: '/',
rootPath: '/',
list,
},
});
};
const findSettingsButton = () => wrapper.find({ ref: 'settingsBtn' });
describe('Settings Button', () => {
it.each(Object.values(ListType))(
'when feature flag is off: does not render for List Type `%s`',
listType => {
window.gon = {
features: {
wipLimits: false,
},
};
createComponent({ listType });
expect(findSettingsButton().exists()).toBe(false);
},
);
describe('when feature flag is on', () => {
const hasSettings = [ListType.assignee, ListType.milestone, ListType.label];
const hasNoSettings = [ListType.backlog, ListType.blank, ListType.closed, ListType.promotion];
beforeEach(() => {
window.gon = {
features: {
wipLimits: true,
},
};
});
it.each(hasSettings)('does render for List Type `%s`', listType => {
createComponent({ listType });
expect(findSettingsButton().exists()).toBe(true);
});
it.each(hasNoSettings)('does not render for List Type `%s`', listType => {
createComponent({ listType });
expect(findSettingsButton().exists()).toBe(false);
});
it('has a test for each list type', () => {
Object.values(ListType).forEach(value => {
expect([...hasSettings, ...hasNoSettings]).toContain(value);
});
});
});
});
});
...@@ -4,6 +4,7 @@ import AxiosMockAdapter from 'axios-mock-adapter'; ...@@ -4,6 +4,7 @@ import AxiosMockAdapter from 'axios-mock-adapter';
import Board from '~/boards/components/board_column.vue'; import Board from '~/boards/components/board_column.vue';
import List from '~/boards/models/list'; import List from '~/boards/models/list';
import { ListType } from '~/boards/constants';
import axios from '~/lib/utils/axios_utils'; import axios from '~/lib/utils/axios_utils';
import { TEST_HOST } from 'helpers/test_constants'; import { TEST_HOST } from 'helpers/test_constants';
...@@ -28,20 +29,25 @@ describe('Board Column Component', () => { ...@@ -28,20 +29,25 @@ describe('Board Column Component', () => {
}); });
const createComponent = ({ const createComponent = ({
listType = 'backlog', listType = ListType.backlog,
collapsed = false, collapsed = false,
withLocalStorage = true, withLocalStorage = true,
} = {}) => { } = {}) => {
const boardId = '1'; const boardId = '1';
const listMock = {
...listObj,
list_type: listType,
collapsed,
};
if (listType === ListType.assignee) {
delete listMock.label;
listMock.user = {};
}
// Making List reactive // Making List reactive
const list = Vue.observable( const list = Vue.observable(new List(listMock));
new List({
...listObj,
list_type: listType,
collapsed,
}),
);
if (withLocalStorage) { if (withLocalStorage) {
localStorage.setItem( localStorage.setItem(
...@@ -64,23 +70,40 @@ describe('Board Column Component', () => { ...@@ -64,23 +70,40 @@ describe('Board Column Component', () => {
const isExpandable = () => wrapper.classes('is-expandable'); const isExpandable = () => wrapper.classes('is-expandable');
const isCollapsed = () => wrapper.classes('is-collapsed'); const isCollapsed = () => wrapper.classes('is-collapsed');
const findAddIssueButton = () => wrapper.find({ ref: 'newIssueBtn' });
describe('Add issue button', () => { describe('Add issue button', () => {
it('does not render when List Type is `blank`', () => { const hasNoAddButton = [ListType.promotion, ListType.blank, ListType.closed];
createComponent({ listType: 'blank' }); const hasAddButton = [ListType.backlog, ListType.label, ListType.milestone, ListType.assignee];
it.each(hasNoAddButton)('does not render when List Type is `%s`', listType => {
createComponent({ listType });
expect(wrapper.find('.issue-count-badge-add-button').exists()).toBe(false); expect(findAddIssueButton().exists()).toBe(false);
});
it.each(hasAddButton)('does render when List Type is `%s`', listType => {
createComponent({ listType });
expect(findAddIssueButton().exists()).toBe(true);
});
it('has a test for each list type', () => {
Object.values(ListType).forEach(value => {
expect([...hasAddButton, ...hasNoAddButton]).toContain(value);
});
}); });
it('does render when logged out', () => { it('does render when logged out', () => {
createComponent(); createComponent();
expect(wrapper.find('.issue-count-badge-add-button').exists()).toBe(true); expect(findAddIssueButton().exists()).toBe(true);
}); });
}); });
describe('Given different list types', () => { describe('Given different list types', () => {
it('is expandable when List Type is `backlog`', () => { it('is expandable when List Type is `backlog`', () => {
createComponent({ listType: 'backlog' }); createComponent({ listType: ListType.backlog });
expect(isExpandable()).toBe(true); expect(isExpandable()).toBe(true);
}); });
......
...@@ -56,7 +56,7 @@ describe('List model', () => { ...@@ -56,7 +56,7 @@ describe('List model', () => {
label: { label: {
id: 1, id: 1,
title: 'test', title: 'test',
color: 'red', color: '#ff0000',
text_color: 'white', text_color: 'white',
}, },
}); });
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment