summaryrefslogtreecommitdiff
path: root/spec/javascripts/boards/components/issue_card_inner_scoped_label_spec.js
blob: c62c5b9962de274d810da971611f609f685d8940 (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
import Vue from 'vue';
import IssueCardInnerScopedLabel from '~/boards/components/issue_card_inner_scoped_label.vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper';

describe('IssueCardInnerScopedLabel Component', () => {
  let vm;
  const Component = Vue.extend(IssueCardInnerScopedLabel);
  const props = {
    label: { title: 'Foo::Bar', description: 'Some Random Description' },
    labelStyle: { background: 'white', color: 'black' },
    scopedLabelsDocumentationLink: '/docs-link',
  };
  const createComponent = () => mountComponent(Component, { ...props });

  beforeEach(() => {
    vm = createComponent();
  });

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

  it('should render label title', () => {
    expect(vm.$el.querySelector('.color-label').textContent.trim()).toEqual('Foo::Bar');
  });

  it('should render question mark symbol', () => {
    expect(vm.$el.querySelector('.fa-question-circle')).not.toBeNull();
  });

  it('should render label style provided', () => {
    const node = vm.$el.querySelector('.color-label');

    expect(node.style.background).toEqual(props.labelStyle.background);
    expect(node.style.color).toEqual(props.labelStyle.color);
  });

  it('should render the docs link', () => {
    expect(vm.$el.querySelector('a.scoped-label').href).toContain(
      props.scopedLabelsDocumentationLink,
    );
  });
});