diff options
Diffstat (limited to 'spec/frontend/flash_spec.js')
-rw-r--r-- | spec/frontend/flash_spec.js | 276 |
1 files changed, 0 insertions, 276 deletions
diff --git a/spec/frontend/flash_spec.js b/spec/frontend/flash_spec.js deleted file mode 100644 index 17d6cea23df..00000000000 --- a/spec/frontend/flash_spec.js +++ /dev/null @@ -1,276 +0,0 @@ -import * as Sentry from '@sentry/browser'; -import { setHTMLFixture, resetHTMLFixture } from 'helpers/fixtures'; -import { createAlert, VARIANT_WARNING } from '~/flash'; - -jest.mock('@sentry/browser'); - -describe('Flash', () => { - const findTextContent = (containerSelector = '.flash-container') => - document.querySelector(containerSelector).textContent.replace(/\s+/g, ' ').trim(); - - describe('createAlert', () => { - const mockMessage = 'a message'; - let alert; - - describe('no flash-container', () => { - it('does not add to the DOM', () => { - alert = createAlert({ message: mockMessage }); - - expect(alert).toBeNull(); - expect(document.querySelector('.gl-alert')).toBeNull(); - }); - }); - - describe('with flash-container', () => { - beforeEach(() => { - setHTMLFixture('<div class="flash-container"></div>'); - }); - - afterEach(() => { - if (alert) { - alert.$destroy(); - } - resetHTMLFixture(); - }); - - it('adds alert element into the document by default', () => { - alert = createAlert({ message: mockMessage }); - - expect(findTextContent()).toBe(mockMessage); - expect(document.querySelector('.flash-container .gl-alert')).not.toBeNull(); - }); - - it('adds flash of a warning type', () => { - alert = createAlert({ message: mockMessage, variant: VARIANT_WARNING }); - - expect( - document.querySelector('.flash-container .gl-alert.gl-alert-warning'), - ).not.toBeNull(); - }); - - it('escapes text', () => { - alert = createAlert({ message: '<script>alert("a");</script>' }); - - const html = document.querySelector('.flash-container').innerHTML; - - expect(html).toContain('<script>alert("a");</script>'); - expect(html).not.toContain('<script>alert("a");</script>'); - }); - - it('adds alert into specified container', () => { - setHTMLFixture(` - <div class="my-alert-container"></div> - <div class="my-other-container"></div> - `); - - alert = createAlert({ message: mockMessage, containerSelector: '.my-alert-container' }); - - expect(document.querySelector('.my-alert-container .gl-alert')).not.toBeNull(); - expect(document.querySelector('.my-alert-container').innerText.trim()).toBe(mockMessage); - - expect(document.querySelector('.my-other-container .gl-alert')).toBeNull(); - expect(document.querySelector('.my-other-container').innerText.trim()).toBe(''); - }); - - it('adds alert into specified parent', () => { - setHTMLFixture(` - <div id="my-parent"> - <div class="flash-container"></div> - </div> - <div id="my-other-parent"> - <div class="flash-container"></div> - </div> - `); - - alert = createAlert({ message: mockMessage, parent: document.getElementById('my-parent') }); - - expect(document.querySelector('#my-parent .flash-container .gl-alert')).not.toBeNull(); - expect(document.querySelector('#my-parent .flash-container').innerText.trim()).toBe( - mockMessage, - ); - - expect(document.querySelector('#my-other-parent .flash-container .gl-alert')).toBeNull(); - expect(document.querySelector('#my-other-parent .flash-container').innerText.trim()).toBe( - '', - ); - }); - - it('removes element after clicking', () => { - alert = createAlert({ message: mockMessage }); - - expect(document.querySelector('.flash-container .gl-alert')).not.toBeNull(); - - document.querySelector('.gl-dismiss-btn').click(); - - expect(document.querySelector('.flash-container .gl-alert')).toBeNull(); - }); - - it('does not capture error using Sentry', () => { - alert = createAlert({ - message: mockMessage, - captureError: false, - error: new Error('Error!'), - }); - - expect(Sentry.captureException).not.toHaveBeenCalled(); - }); - - it('captures error using Sentry', () => { - alert = createAlert({ - message: mockMessage, - captureError: true, - error: new Error('Error!'), - }); - - expect(Sentry.captureException).toHaveBeenCalledWith(expect.any(Error)); - expect(Sentry.captureException).toHaveBeenCalledWith( - expect.objectContaining({ - message: 'Error!', - }), - ); - }); - - describe('with title', () => { - const mockTitle = 'my title'; - - it('shows title and message', () => { - createAlert({ - title: mockTitle, - message: mockMessage, - }); - - expect(findTextContent()).toBe(`${mockTitle} ${mockMessage}`); - }); - }); - - describe('with buttons', () => { - const findAlertAction = () => document.querySelector('.flash-container .gl-alert-action'); - - it('adds primary button', () => { - alert = createAlert({ - message: mockMessage, - primaryButton: { - text: 'Ok', - }, - }); - - expect(findAlertAction().textContent.trim()).toBe('Ok'); - }); - - it('creates link with href', () => { - alert = createAlert({ - message: mockMessage, - primaryButton: { - link: '/url', - text: 'Ok', - }, - }); - - const action = findAlertAction(); - - expect(action.textContent.trim()).toBe('Ok'); - expect(action.nodeName).toBe('A'); - expect(action.getAttribute('href')).toBe('/url'); - }); - - it('create button as href when no href is present', () => { - alert = createAlert({ - message: mockMessage, - primaryButton: { - text: 'Ok', - }, - }); - - const action = findAlertAction(); - - expect(action.nodeName).toBe('BUTTON'); - expect(action.getAttribute('href')).toBe(null); - }); - - it('escapes the title text', () => { - alert = createAlert({ - message: mockMessage, - primaryButton: { - text: '<script>alert("a")</script>', - }, - }); - - const html = findAlertAction().innerHTML; - - expect(html).toContain('<script>alert("a")</script>'); - expect(html).not.toContain('<script>alert("a")</script>'); - }); - - it('calls actionConfig clickHandler on click', () => { - const clickHandler = jest.fn(); - - alert = createAlert({ - message: mockMessage, - primaryButton: { - text: 'Ok', - clickHandler, - }, - }); - - expect(clickHandler).toHaveBeenCalledTimes(0); - - findAlertAction().click(); - - expect(clickHandler).toHaveBeenCalledTimes(1); - expect(clickHandler).toHaveBeenCalledWith(expect.any(MouseEvent)); - }); - }); - - describe('Alert API', () => { - describe('dismiss', () => { - it('dismiss programmatically with .dismiss()', () => { - expect(document.querySelector('.gl-alert')).toBeNull(); - - alert = createAlert({ message: mockMessage }); - - expect(document.querySelector('.gl-alert')).not.toBeNull(); - - alert.dismiss(); - - expect(document.querySelector('.gl-alert')).toBeNull(); - }); - - it('does not crash if calling .dismiss() twice', () => { - alert = createAlert({ message: mockMessage }); - - alert.dismiss(); - expect(() => alert.dismiss()).not.toThrow(); - }); - - it('calls onDismiss when dismissed', () => { - const dismissHandler = jest.fn(); - - alert = createAlert({ message: mockMessage, onDismiss: dismissHandler }); - - expect(dismissHandler).toHaveBeenCalledTimes(0); - - alert.dismiss(); - - expect(dismissHandler).toHaveBeenCalledTimes(1); - }); - }); - }); - - describe('when called multiple times', () => { - it('clears previous alerts', () => { - createAlert({ message: 'message 1' }); - createAlert({ message: 'message 2' }); - - expect(findTextContent()).toBe('message 2'); - }); - - it('preserves alerts when `preservePrevious` is true', () => { - createAlert({ message: 'message 1' }); - createAlert({ message: 'message 2', preservePrevious: true }); - - expect(findTextContent()).toBe('message 1 message 2'); - }); - }); - }); - }); -}); |