98 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| import { nextTick } from 'vue';
 | |
| import { alertVariantOptions } from '@gitlab/ui/dist/utils/constants';
 | |
| import { setHTMLFixture, resetHTMLFixture } from 'helpers/fixtures';
 | |
| import { TEST_HOST } from 'helpers/test_constants';
 | |
| import initVueAlerts from '~/vue_alerts';
 | |
| 
 | |
| describe('VueAlerts', () => {
 | |
|   const alerts = [
 | |
|     {
 | |
|       title: 'Lorem',
 | |
|       html: 'Lorem <strong>Ipsum</strong>',
 | |
|       dismissible: true,
 | |
|       primaryButtonText: 'Okay!',
 | |
|       primaryButtonLink: `${TEST_HOST}/okay`,
 | |
|       variant: 'tip',
 | |
|     },
 | |
|     {
 | |
|       title: 'Hello',
 | |
|       html: 'Hello <strong>World</strong>',
 | |
|       dismissible: false,
 | |
|       primaryButtonText: 'No!',
 | |
|       primaryButtonLink: `${TEST_HOST}/no`,
 | |
|       variant: 'info',
 | |
|     },
 | |
|   ];
 | |
| 
 | |
|   beforeEach(() => {
 | |
|     setHTMLFixture(
 | |
|       alerts
 | |
|         .map(
 | |
|           (x) => `
 | |
|     <div class="js-vue-alert"
 | |
|       data-dismissible="${x.dismissible}"
 | |
|       data-title="${x.title}"
 | |
|       data-primary-button-text="${x.primaryButtonText}"
 | |
|       data-primary-button-link="${x.primaryButtonLink}"
 | |
|       data-variant="${x.variant}">${x.html}</div>
 | |
|     `,
 | |
|         )
 | |
|         .join('\n'),
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   afterEach(() => {
 | |
|     resetHTMLFixture();
 | |
|   });
 | |
| 
 | |
|   const findJsHooks = () => document.querySelectorAll('.js-vue-alert');
 | |
|   const findAlerts = () => document.querySelectorAll('.gl-alert');
 | |
|   const findAlertDismiss = (alert) => alert.querySelector('.gl-dismiss-btn');
 | |
| 
 | |
|   const serializeAlert = (alert) => ({
 | |
|     title: alert.querySelector('.gl-alert-title').textContent.trim(),
 | |
|     html: alert.querySelector('.gl-alert-body div').innerHTML,
 | |
|     dismissible: Boolean(alert.querySelector('.gl-dismiss-btn')),
 | |
|     primaryButtonText: alert.querySelector('.gl-alert-action').textContent.trim(),
 | |
|     primaryButtonLink: alert.querySelector('.gl-alert-action').href,
 | |
|     variant: [...alert.classList]
 | |
|       .find((cssClass) => {
 | |
|         return Object.values(alertVariantOptions).some(
 | |
|           (variant) => cssClass === `gl-alert-${variant}`,
 | |
|         );
 | |
|       })
 | |
|       .replace('gl-alert-', ''),
 | |
|   });
 | |
| 
 | |
|   it('starts with only JsHooks', () => {
 | |
|     expect(findJsHooks()).toHaveLength(alerts.length);
 | |
|     expect(findAlerts()).toHaveLength(0);
 | |
|   });
 | |
| 
 | |
|   describe('when mounted', () => {
 | |
|     beforeEach(() => {
 | |
|       initVueAlerts();
 | |
|     });
 | |
| 
 | |
|     it('replaces JsHook with GlAlert', () => {
 | |
|       expect(findJsHooks()).toHaveLength(0);
 | |
|       expect(findAlerts()).toHaveLength(alerts.length);
 | |
|     });
 | |
| 
 | |
|     it('passes along props to gl-alert', () => {
 | |
|       expect([...findAlerts()].map(serializeAlert)).toEqual(alerts);
 | |
|     });
 | |
| 
 | |
|     describe('when dismissed', () => {
 | |
|       beforeEach(async () => {
 | |
|         findAlertDismiss(findAlerts()[0]).click();
 | |
|         await nextTick();
 | |
|       });
 | |
| 
 | |
|       it('hides the alert', () => {
 | |
|         expect(findAlerts()).toHaveLength(alerts.length - 1);
 | |
|       });
 | |
|     });
 | |
|   });
 | |
| });
 |