Welcome to mirror list, hosted at ThFree Co, Russian Federation.

action_btn_spec.js « components « deploy_keys « frontend « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 6ac68061518626a3213088f506c2994bf9989e31 (plain)
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
import { GlButton } from '@gitlab/ui';
import { shallowMount } from '@vue/test-utils';
import data from 'test_fixtures/deploy_keys/keys.json';
import actionBtn from '~/deploy_keys/components/action_btn.vue';
import eventHub from '~/deploy_keys/eventhub';

describe('Deploy keys action btn', () => {
  const deployKey = data.enabled_keys[0];
  let wrapper;

  const findButton = () => wrapper.findComponent(GlButton);

  beforeEach(() => {
    wrapper = shallowMount(actionBtn, {
      propsData: {
        deployKey,
        type: 'enable',
        category: 'primary',
        variant: 'confirm',
        icon: 'edit',
      },
      slots: {
        default: 'Enable',
      },
    });
  });

  it('renders the default slot', () => {
    expect(wrapper.text()).toBe('Enable');
  });

  it('passes the button props on', () => {
    expect(findButton().props()).toMatchObject({
      category: 'primary',
      variant: 'confirm',
      icon: 'edit',
    });
  });

  it('sends eventHub event with btn type', () => {
    jest.spyOn(eventHub, '$emit').mockImplementation(() => {});

    findButton().vm.$emit('click');

    return wrapper.vm.$nextTick().then(() => {
      expect(eventHub.$emit).toHaveBeenCalledWith('enable.key', deployKey, expect.anything());
    });
  });

  it('shows loading spinner after click', () => {
    findButton().vm.$emit('click');

    return wrapper.vm.$nextTick().then(() => {
      expect(findButton().props('loading')).toBe(true);
    });
  });
});