2018-12-05 23:21:45 +05:30
|
|
|
import Vue from 'vue';
|
|
|
|
import sidebarDetailsBlock from '~/jobs/components/sidebar.vue';
|
|
|
|
import createStore from '~/jobs/store';
|
2019-09-04 21:01:54 +05:30
|
|
|
import job, { jobsInStage } from '../mock_data';
|
2018-12-05 23:21:45 +05:30
|
|
|
import { mountComponentWithStore } from '../../helpers/vue_mount_component_helper';
|
2019-09-04 21:01:54 +05:30
|
|
|
import { trimText } from '../../helpers/text_helper';
|
2018-12-05 23:21:45 +05:30
|
|
|
|
|
|
|
describe('Sidebar details block', () => {
|
|
|
|
const SidebarComponent = Vue.extend(sidebarDetailsBlock);
|
|
|
|
let vm;
|
|
|
|
let store;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
store = createStore();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
vm.$destroy();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when there is no retry path retry', () => {
|
|
|
|
it('should not render a retry button', () => {
|
2020-05-24 23:13:21 +05:30
|
|
|
const copy = { ...job };
|
2018-12-05 23:21:45 +05:30
|
|
|
delete copy.retry_path;
|
|
|
|
|
|
|
|
store.dispatch('receiveJobSuccess', copy);
|
|
|
|
vm = mountComponentWithStore(SidebarComponent, {
|
|
|
|
store,
|
|
|
|
});
|
|
|
|
|
2019-03-02 22:35:43 +05:30
|
|
|
expect(vm.$el.querySelector('.js-retry-button')).toBeNull();
|
2018-12-05 23:21:45 +05:30
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('without terminal path', () => {
|
|
|
|
it('does not render terminal link', () => {
|
|
|
|
store.dispatch('receiveJobSuccess', job);
|
|
|
|
vm = mountComponentWithStore(SidebarComponent, { store });
|
|
|
|
|
|
|
|
expect(vm.$el.querySelector('.js-terminal-link')).toBeNull();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('with terminal path', () => {
|
|
|
|
it('renders terminal link', () => {
|
2020-05-24 23:13:21 +05:30
|
|
|
store.dispatch('receiveJobSuccess', { ...job, terminal_path: 'job/43123/terminal' });
|
2018-12-05 23:21:45 +05:30
|
|
|
vm = mountComponentWithStore(SidebarComponent, {
|
|
|
|
store,
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(vm.$el.querySelector('.js-terminal-link')).not.toBeNull();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
store.dispatch('receiveJobSuccess', job);
|
|
|
|
vm = mountComponentWithStore(SidebarComponent, { store });
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('actions', () => {
|
|
|
|
it('should render link to new issue', () => {
|
|
|
|
expect(vm.$el.querySelector('.js-new-issue').getAttribute('href')).toEqual(
|
|
|
|
job.new_issue_path,
|
|
|
|
);
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2018-12-05 23:21:45 +05:30
|
|
|
expect(vm.$el.querySelector('.js-new-issue').textContent.trim()).toEqual('New issue');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render link to retry job', () => {
|
2019-03-02 22:35:43 +05:30
|
|
|
expect(vm.$el.querySelector('.js-retry-button').getAttribute('href')).toEqual(job.retry_path);
|
2018-12-05 23:21:45 +05:30
|
|
|
});
|
|
|
|
|
|
|
|
it('should render link to cancel job', () => {
|
|
|
|
expect(vm.$el.querySelector('.js-cancel-job').getAttribute('href')).toEqual(job.cancel_path);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('information', () => {
|
|
|
|
it('should render job duration', () => {
|
|
|
|
expect(trimText(vm.$el.querySelector('.js-job-duration').textContent)).toEqual(
|
|
|
|
'Duration: 6 seconds',
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render erased date', () => {
|
|
|
|
expect(trimText(vm.$el.querySelector('.js-job-erased').textContent)).toEqual(
|
|
|
|
'Erased: 3 weeks ago',
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render finished date', () => {
|
|
|
|
expect(trimText(vm.$el.querySelector('.js-job-finished').textContent)).toEqual(
|
|
|
|
'Finished: 3 weeks ago',
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render queued date', () => {
|
|
|
|
expect(trimText(vm.$el.querySelector('.js-job-queued').textContent)).toEqual(
|
|
|
|
'Queued: 9 seconds',
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render runner ID', () => {
|
|
|
|
expect(trimText(vm.$el.querySelector('.js-job-runner').textContent)).toEqual(
|
|
|
|
'Runner: local ci runner (#1)',
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render timeout information', () => {
|
|
|
|
expect(trimText(vm.$el.querySelector('.js-job-timeout').textContent)).toEqual(
|
|
|
|
'Timeout: 1m 40s (from runner)',
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render coverage', () => {
|
|
|
|
expect(trimText(vm.$el.querySelector('.js-job-coverage').textContent)).toEqual(
|
|
|
|
'Coverage: 20%',
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render tags', () => {
|
|
|
|
expect(trimText(vm.$el.querySelector('.js-job-tags').textContent)).toEqual('Tags: tag');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('stages dropdown', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
store.dispatch('receiveJobSuccess', job);
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('with stages', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
vm = mountComponentWithStore(SidebarComponent, { store });
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders value provided as selectedStage as selected', () => {
|
|
|
|
expect(vm.$el.querySelector('.js-selected-stage').textContent.trim()).toEqual(
|
|
|
|
vm.selectedStage,
|
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('without jobs for stages', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
store.dispatch('receiveJobSuccess', job);
|
|
|
|
vm = mountComponentWithStore(SidebarComponent, { store });
|
|
|
|
});
|
|
|
|
|
|
|
|
it('does not render job container', () => {
|
|
|
|
expect(vm.$el.querySelector('.js-jobs-container')).toBeNull();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('with jobs for stages', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
store.dispatch('receiveJobSuccess', job);
|
|
|
|
store.dispatch('receiveJobsForStageSuccess', jobsInStage.latest_statuses);
|
|
|
|
vm = mountComponentWithStore(SidebarComponent, { store });
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders list of jobs', () => {
|
|
|
|
expect(vm.$el.querySelector('.js-jobs-container')).not.toBeNull();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|