commit_pipeline_status_component_spec.js 1.64 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
import Vue from 'vue';
import MockAdapter from 'axios-mock-adapter';
import axios from '~/lib/utils/axios_utils';
import commitPipelineStatus from '~/pages/projects/tree/components/commit_pipeline_status_component.vue';
import mountComponent from '../helpers/vue_mount_component_helper';

describe('Commit pipeline status component', () => {
  let vm;
  let component;
  let mock;
  const mockCiStatus = {
    details_path: '/root/hello-world/pipelines/1',
    favicon: 'canceled.ico',
    group: 'canceled',
    has_details: true,
    icon: 'status_canceled',
    label: 'canceled',
    text: 'canceled',
  };

  beforeEach(() => {
    mock = new MockAdapter(axios);
    mock.onGet('/dummy/endpoint').reply(() => {
      const res = Promise.resolve([200, {
        pipelines: [
          {
            details: {
              status: mockCiStatus,
            },
          },
        ],
      }]);
      return res;
    });
    component = Vue.extend(commitPipelineStatus);
  });

  afterEach(() => {
    mock.reset();
  });

  describe('While polling pipeline data', () => {
    beforeEach(() => {
      vm = mountComponent(component, {
        endpoint: '/dummy/endpoint',
      });
    });

    afterEach(() => {
      vm.poll.stop();
      vm.$destroy();
    });

    it('contains a ciStatus when the polling is succesful ', (done) => {
      setTimeout(() => {
        expect(vm.ciStatus).toEqual(mockCiStatus);
        done();
      }, 1000);
    });

    it('contains a ci-status icon when polling is succesful', (done) => {
      setTimeout(() => {
        expect(vm.$el.querySelector('.ci-status-icon')).not.toBe(null);
        done();
      });
    });
  });
});