skeleton_loading_container_spec.js 1.2 KB
Newer Older
1 2
import Vue from 'vue';
import skeletonLoadingContainer from '~/vue_shared/components/skeleton_loading_container.vue';
3
import mountComponent from 'spec/helpers/vue_mount_component_helper';
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

describe('Skeleton loading container', () => {
  let vm;

  beforeEach(() => {
    const component = Vue.extend(skeletonLoadingContainer);
    vm = mountComponent(component);
  });

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

  it('renders 6 skeleton lines by default', () => {
    expect(vm.$el.querySelector('.skeleton-line-6')).not.toBeNull();
  });

  it('renders in full mode by default', () => {
    expect(vm.$el.classList.contains('animation-container-small')).toBeFalsy();
  });

  describe('small', () => {
    beforeEach((done) => {
      vm.small = true;

      Vue.nextTick(done);
    });

    it('renders in small mode', () => {
      expect(vm.$el.classList.contains('animation-container-small')).toBeTruthy();
    });
  });

  describe('lines', () => {
    beforeEach((done) => {
      vm.lines = 5;

      Vue.nextTick(done);
    });

    it('renders 5 lines', () => {
      expect(vm.$el.querySelector('.skeleton-line-5')).not.toBeNull();
      expect(vm.$el.querySelector('.skeleton-line-6')).toBeNull();
    });
  });
});