import Vue from 'vue'; import pipelineUrlComp from '~/pipelines/components/pipeline_url.vue'; describe('Pipeline Url Component', () => { let PipelineUrlComponent; beforeEach(() => { PipelineUrlComponent = Vue.extend(pipelineUrlComp); }); it('should render a table cell', () => { const component = new PipelineUrlComponent({ propsData: { pipeline: { id: 1, path: 'foo', flags: {}, }, autoDevopsHelpPath: 'foo', }, }).$mount(); expect(component.$el.getAttribute('class')).toContain('table-section'); }); it('should render a link the provided path and id', () => { const component = new PipelineUrlComponent({ propsData: { pipeline: { id: 1, path: 'foo', flags: {}, }, autoDevopsHelpPath: 'foo', }, }).$mount(); expect(component.$el.querySelector('.js-pipeline-url-link').getAttribute('href')).toEqual('foo'); expect(component.$el.querySelector('.js-pipeline-url-link span').textContent).toEqual('#1'); }); it('should render user information when a user is provided', () => { const mockData = { pipeline: { id: 1, path: 'foo', flags: {}, user: { web_url: '/', name: 'foo', avatar_url: '/', path: '/', }, }, autoDevopsHelpPath: 'foo', }; const component = new PipelineUrlComponent({ propsData: mockData, }).$mount(); const image = component.$el.querySelector('.js-pipeline-url-user img'); expect( component.$el.querySelector('.js-pipeline-url-user').getAttribute('href'), ).toEqual(mockData.pipeline.user.web_url); expect(image.getAttribute('data-original-title')).toEqual(mockData.pipeline.user.name); expect(image.getAttribute('src')).toEqual(mockData.pipeline.user.avatar_url); }); it('should render "API" when no user is provided', () => { const component = new PipelineUrlComponent({ propsData: { pipeline: { id: 1, path: 'foo', flags: {}, }, autoDevopsHelpPath: 'foo', }, }).$mount(); expect(component.$el.querySelector('.js-pipeline-url-api').textContent).toContain('API'); }); it('should render latest, yaml invalid and stuck flags when provided', () => { const component = new PipelineUrlComponent({ propsData: { pipeline: { id: 1, path: 'foo', flags: { latest: true, yaml_errors: true, stuck: true, }, }, autoDevopsHelpPath: 'foo', }, }).$mount(); expect(component.$el.querySelector('.js-pipeline-url-latest').textContent).toContain('latest'); expect(component.$el.querySelector('.js-pipeline-url-yaml').textContent).toContain('yaml invalid'); expect(component.$el.querySelector('.js-pipeline-url-stuck').textContent).toContain('stuck'); }); it('should render a badge for autodevops', () => { const component = new PipelineUrlComponent({ propsData: { pipeline: { id: 1, path: 'foo', flags: { latest: true, yaml_errors: true, stuck: true, auto_devops: true, }, }, autoDevopsHelpPath: 'foo', }, }).$mount(); expect( component.$el.querySelector('.js-pipeline-url-autodevops').textContent.trim(), ).toEqual('Auto DevOps'); }); it('should render error badge when pipeline has a failure reason set', () => { const component = new PipelineUrlComponent({ propsData: { pipeline: { id: 1, path: 'foo', flags: { failure_reason: true, }, failure_reason: 'some reason', }, autoDevopsHelpPath: 'foo', }, }).$mount(); expect(component.$el.querySelector('.js-pipeline-url-failure').textContent).toContain('error'); expect(component.$el.querySelector('.js-pipeline-url-failure').getAttribute('data-original-title')).toContain('some reason'); }); });