summaryrefslogtreecommitdiff
path: root/spec/frontend/environments/environment_external_url_spec.js
blob: 5966993166b5ad54161b00757ba46b058de45c19 (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
import { mount } from '@vue/test-utils';
import { s__, __ } from '~/locale';
import ExternalUrlComp from '~/environments/components/environment_external_url.vue';
import ModalCopyButton from '~/vue_shared/components/modal_copy_button.vue';

describe('External URL Component', () => {
  let wrapper;
  let externalUrl;

  describe('with safe link', () => {
    beforeEach(() => {
      externalUrl = 'https://gitlab.com';
      wrapper = mount(ExternalUrlComp, { propsData: { externalUrl } });
    });

    it('should link to the provided externalUrl prop', () => {
      expect(wrapper.attributes('href')).toBe(externalUrl);
      expect(wrapper.find('a').exists()).toBe(true);
    });
  });

  describe('with unsafe link', () => {
    beforeEach(() => {
      externalUrl = 'postgres://gitlab';
      wrapper = mount(ExternalUrlComp, { propsData: { externalUrl } });
    });

    it('should show a copy button instead', () => {
      const button = wrapper.findComponent(ModalCopyButton);
      expect(button.props('text')).toBe(externalUrl);
      expect(button.text()).toBe(__('Copy URL'));
      expect(button.props('title')).toBe(s__('Environments|Copy live environment URL'));
    });
  });
});