94 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
| import { asyncExpect } from '@/tests/utils';
 | |
| import notification from '..';
 | |
| 
 | |
| describe('notification', () => {
 | |
|   beforeEach(() => {
 | |
|     document.body.outerHTML = '';
 | |
|   });
 | |
| 
 | |
|   afterEach(() => {
 | |
|     notification.destroy();
 | |
|   });
 | |
| 
 | |
|   it('should be able to hide manually', async () => {
 | |
|     notification.open({
 | |
|       message: 'Notification Title',
 | |
|       duration: 0,
 | |
|       key: '1',
 | |
|     });
 | |
|     await asyncExpect(() => {
 | |
|       notification.open({
 | |
|         message: 'Notification Title',
 | |
|         duration: 0,
 | |
|         key: '2',
 | |
|       });
 | |
|     });
 | |
|     await asyncExpect(() => {
 | |
|       expect(document.querySelectorAll('.ant-notification-notice').length).toBe(2);
 | |
|       notification.close('1');
 | |
|     }, 0);
 | |
|     await asyncExpect(() => {
 | |
|       expect(document.querySelectorAll('.ant-notification-notice').length).toBe(1);
 | |
|       notification.close('2');
 | |
|     }, 0);
 | |
|     await asyncExpect(() => {
 | |
|       expect(document.querySelectorAll('.ant-notification-notice').length).toBe(0);
 | |
|     }, 0);
 | |
|   });
 | |
| 
 | |
|   it('should be able to destroy globally', async () => {
 | |
|     notification.open({
 | |
|       message: 'Notification Title',
 | |
|       duration: 0,
 | |
|     });
 | |
|     await asyncExpect(() => {
 | |
|       notification.open({
 | |
|         message: 'Notification Title',
 | |
|         duration: 0,
 | |
|       });
 | |
|     });
 | |
|     await asyncExpect(() => {
 | |
|       expect(document.querySelectorAll('.ant-notification').length).toBe(1);
 | |
|       expect(document.querySelectorAll('.ant-notification-notice').length).toBe(2);
 | |
|       notification.destroy();
 | |
|     }, 0);
 | |
|     await asyncExpect(() => {
 | |
|       expect(document.querySelectorAll('.ant-notification').length).toBe(0);
 | |
|       expect(document.querySelectorAll('.ant-notification-notice').length).toBe(0);
 | |
|     }, 0);
 | |
|   });
 | |
| 
 | |
|   it('should be able to destroy after config', () => {
 | |
|     notification.config({
 | |
|       bottom: 100,
 | |
|     });
 | |
|     notification.destroy();
 | |
|   });
 | |
| 
 | |
|   it('should be able to open with icon', done => {
 | |
|     const openNotificationWithIcon = async type => {
 | |
|       const iconPrefix = '.ant-notification-notice-icon';
 | |
|       notification[type]({
 | |
|         message: 'Notification Title',
 | |
|         duration: 0,
 | |
|         description: 'This is the content of the notification.',
 | |
|       });
 | |
|       await asyncExpect(() => {
 | |
|         expect(document.querySelectorAll(`${iconPrefix}-${type}`).length).toBe(1);
 | |
|       }, 0);
 | |
|     };
 | |
|     ['success', 'info', 'warning', 'error'].forEach(type => {
 | |
|       openNotificationWithIcon(type);
 | |
|     });
 | |
|     done();
 | |
|   });
 | |
| 
 | |
|   it('trigger onClick', () => {
 | |
|     notification.open({
 | |
|       message: 'Notification Title',
 | |
|       duration: 0,
 | |
|     });
 | |
|     expect(document.querySelectorAll('.ant-notification').length).toBe(1);
 | |
|   });
 | |
| });
 |