issue_note_awards_list_spec.js 1.6 KB
Newer Older
1 2 3
import Vue from 'vue';
import store from '~/notes/stores';
import awardsNote from '~/notes/components/issue_note_awards_list.vue';
S
Simon Knox 已提交
4
import { noteableDataMock, notesDataMock } from '../mock_data';
5

F
Filipa Lacerda 已提交
6
describe('issue_note_awards_list component', () => {
7 8 9 10 11 12
  let vm;
  let awardsMock;

  beforeEach(() => {
    const Component = Vue.extend(awardsNote);

S
Simon Knox 已提交
13
    store.dispatch('setNoteableData', noteableDataMock);
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
    store.dispatch('setNotesData', notesDataMock);
    awardsMock = [
      {
        name: 'flag_tz',
        user: { id: 1, name: 'Administrator', username: 'root' },
      },
      {
        name: 'cartwheel_tone3',
        user: { id: 12, name: 'Bobbie Stehr', username: 'erin' },
      },
    ];

    vm = new Component({
      store,
      propsData: {
        awards: awardsMock,
        noteAuthorId: 2,
        noteId: 545,
        toggleAwardPath: '/gitlab-org/gitlab-ce/notes/545/toggle_award_emoji',
      },
    }).$mount();
  });
F
Filipa Lacerda 已提交
36

37 38 39 40 41
  afterEach(() => {
    vm.$destroy();
  });

  it('should render awarded emojis', () => {
F
Filipa Lacerda 已提交
42 43
    expect(vm.$el.querySelector('.js-awards-block button [data-name="flag_tz"]')).toBeDefined();
    expect(vm.$el.querySelector('.js-awards-block button [data-name="cartwheel_tone3"]')).toBeDefined();
F
Filipa Lacerda 已提交
44 45 46
  });

  it('should be possible to remove awareded emoji', () => {
47 48
    spyOn(vm, 'handleAward').and.callThrough();
    vm.$el.querySelector('.js-awards-block button').click();
F
Filipa Lacerda 已提交
49

50
    expect(vm.handleAward).toHaveBeenCalledWith('flag_tz');
F
Filipa Lacerda 已提交
51 52 53
  });

  it('should be possible to add new emoji', () => {
54
    expect(vm.$el.querySelector('.js-add-award')).toBeDefined();
F
Filipa Lacerda 已提交
55
  });
56
});