40 lines
1.2 KiB
JavaScript
40 lines
1.2 KiB
JavaScript
import { shallowMount } from '@vue/test-utils';
|
|
import LinkedPipelinesColumn from '~/pipelines/components/graph/linked_pipelines_column.vue';
|
|
import LinkedPipeline from '~/pipelines/components/graph/linked_pipeline.vue';
|
|
import { UPSTREAM } from '~/pipelines/components/graph/constants';
|
|
import mockData from './linked_pipelines_mock_data';
|
|
|
|
describe('Linked Pipelines Column', () => {
|
|
const propsData = {
|
|
columnTitle: 'Upstream',
|
|
linkedPipelines: mockData.triggered,
|
|
graphPosition: 'right',
|
|
projectId: 19,
|
|
type: UPSTREAM,
|
|
};
|
|
let wrapper;
|
|
|
|
beforeEach(() => {
|
|
wrapper = shallowMount(LinkedPipelinesColumn, { propsData });
|
|
});
|
|
|
|
afterEach(() => {
|
|
wrapper.destroy();
|
|
});
|
|
|
|
it('renders the pipeline orientation', () => {
|
|
const titleElement = wrapper.find('.linked-pipelines-column-title');
|
|
|
|
expect(titleElement.text()).toBe(propsData.columnTitle);
|
|
});
|
|
|
|
it('renders the correct number of linked pipelines', () => {
|
|
const linkedPipelineElements = wrapper.findAll(LinkedPipeline);
|
|
|
|
expect(linkedPipelineElements.length).toBe(propsData.linkedPipelines.length);
|
|
});
|
|
|
|
it('renders cross project triangle when column is upstream', () => {
|
|
expect(wrapper.find('.cross-project-triangle').exists()).toBe(true);
|
|
});
|
|
});
|