repo_file_spec.js 3.5 KB
Newer Older
L
Luke "Jared" Bennett 已提交
1
import Vue from 'vue';
2
import repoFile from '~/repo/components/repo_file.vue';
L
Luke "Jared" Bennett 已提交
3

L
Luke "Jared" Bennett 已提交
4
describe('RepoFile', () => {
L
Luke "Jared" Bennett 已提交
5
  const updated = 'updated';
L
Luke "Jared" Bennett 已提交
6 7 8 9 10
  const file = {
    icon: 'icon',
    url: 'url',
    name: 'name',
    lastCommitMessage: 'message',
L
Luke "Jared" Bennett 已提交
11
    lastCommitUpdate: Date.now(),
L
Luke "Jared" Bennett 已提交
12 13 14 15 16 17 18
    level: 10,
  };
  const activeFile = {
    url: 'url',
  };

  function createComponent(propsData) {
L
Luke "Jared" Bennett 已提交
19 20
    const RepoFile = Vue.extend(repoFile);

L
Luke "Jared" Bennett 已提交
21 22 23 24 25
    return new RepoFile({
      propsData,
    }).$mount();
  }

L
Luke "Jared" Bennett 已提交
26 27 28 29
  beforeEach(() => {
    spyOn(repoFile.mixins[0].methods, 'timeFormated').and.returnValue(updated);
  });

L
Luke "Jared" Bennett 已提交
30
  it('renders link, icon, name and last commit details', () => {
L
Luke "Jared" Bennett 已提交
31 32 33 34 35
    const vm = createComponent({
      file,
      activeFile,
    });
    const name = vm.$el.querySelector('.repo-file-name');
36
    const fileIcon = vm.$el.querySelector('.file-icon');
L
Luke "Jared" Bennett 已提交
37 38

    expect(vm.$el.classList.contains('active')).toBeTruthy();
L
Luke "Jared" Bennett 已提交
39
    expect(vm.$el.querySelector(`.${file.icon}`).style.marginLeft).toEqual('100px');
L
Luke "Jared" Bennett 已提交
40 41
    expect(name.title).toEqual(file.url);
    expect(name.href).toMatch(`/${file.url}`);
J
Jacob Schatz 已提交
42 43 44
    expect(name.textContent.trim()).toEqual(file.name);
    expect(vm.$el.querySelector('.commit-message').textContent.trim()).toBe(file.lastCommitMessage);
    expect(vm.$el.querySelector('.commit-update').textContent.trim()).toBe(updated);
45 46
    expect(fileIcon.classList.contains(file.icon)).toBeTruthy();
    expect(fileIcon.style.marginLeft).toEqual(`${file.level * 10}px`);
L
Luke "Jared" Bennett 已提交
47 48
  });

L
Luke "Jared" Bennett 已提交
49 50 51 52 53 54 55 56 57 58 59
  it('does render if hasFiles is true and is loading tree', () => {
    const vm = createComponent({
      file,
      activeFile,
      loading: {
        tree: true,
      },
      hasFiles: true,
    });

    expect(vm.$el.innerHTML).toBeTruthy();
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
    expect(vm.$el.querySelector('.fa-spin.fa-spinner')).toBeFalsy();
  });

  it('renders a spinner if the file is loading', () => {
    file.loading = true;
    const vm = createComponent({
      file,
      activeFile,
      loading: {
        tree: true,
      },
      hasFiles: true,
    });

    expect(vm.$el.innerHTML).toBeTruthy();
    expect(vm.$el.querySelector('.fa-spin.fa-spinner').style.marginLeft).toEqual(`${file.level * 10}px`);
L
Luke "Jared" Bennett 已提交
76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
  });

  it('does not render if loading tree', () => {
    const vm = createComponent({
      file,
      activeFile,
      loading: {
        tree: true,
      },
    });

    expect(vm.$el.innerHTML).toBeFalsy();
  });

  it('does not render commit message and datetime if mini', () => {
    const vm = createComponent({
      file,
      activeFile,
      isMini: true,
    });

L
Luke "Jared" Bennett 已提交
97 98
    expect(vm.$el.querySelector('.commit-message')).toBeFalsy();
    expect(vm.$el.querySelector('.commit-update')).toBeFalsy();
L
Luke "Jared" Bennett 已提交
99 100 101 102 103 104 105
  });

  it('does not set active class if file is active file', () => {
    const vm = createComponent({
      file,
      activeFile: {},
    });
L
Luke "Jared" Bennett 已提交
106

L
Luke "Jared" Bennett 已提交
107 108
    expect(vm.$el.classList.contains('active')).toBeFalsy();
  });
L
Luke "Jared" Bennett 已提交
109

L
Luke "Jared" Bennett 已提交
110 111 112 113 114 115 116 117 118 119
  it('fires linkClicked when the link is clicked', () => {
    const vm = createComponent({
      file,
      activeFile,
    });

    spyOn(vm, 'linkClicked');

    vm.$el.querySelector('.repo-file-name').click();

120
    expect(vm.linkClicked).toHaveBeenCalledWith(file);
L
Luke "Jared" Bennett 已提交
121
  });
122 123 124 125 126 127 128 129 130 131 132 133 134 135

  describe('methods', () => {
    describe('linkClicked', () => {
      const vm = jasmine.createSpyObj('vm', ['$emit']);

      it('$emits linkclicked with file obj', () => {
        const theFile = {};

        repoFile.methods.linkClicked.call(vm, theFile);

        expect(vm.$emit).toHaveBeenCalledWith('linkclicked', theFile);
      });
    });
  });
L
Luke "Jared" Bennett 已提交
136
});