124 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| import Vue from 'vue';
 | |
| 
 | |
| import mountComponent from 'helpers/vue_mount_component_helper';
 | |
| import stackedProgressBarComponent from '~/vue_shared/components/stacked_progress_bar.vue';
 | |
| 
 | |
| const createComponent = (config) => {
 | |
|   const Component = Vue.extend(stackedProgressBarComponent);
 | |
|   const defaultConfig = {
 | |
|     successLabel: 'Synced',
 | |
|     failureLabel: 'Failed',
 | |
|     neutralLabel: 'Out of sync',
 | |
|     successCount: 25,
 | |
|     failureCount: 10,
 | |
|     totalCount: 5000,
 | |
|     ...config,
 | |
|   };
 | |
| 
 | |
|   return mountComponent(Component, defaultConfig);
 | |
| };
 | |
| 
 | |
| describe('StackedProgressBarComponent', () => {
 | |
|   let vm;
 | |
| 
 | |
|   beforeEach(() => {
 | |
|     vm = createComponent();
 | |
|   });
 | |
| 
 | |
|   afterEach(() => {
 | |
|     vm.$destroy();
 | |
|   });
 | |
| 
 | |
|   const findSuccessBarText = (wrapper) =>
 | |
|     wrapper.$el.querySelector('.status-green').innerText.trim();
 | |
|   const findNeutralBarText = (wrapper) =>
 | |
|     wrapper.$el.querySelector('.status-neutral').innerText.trim();
 | |
|   const findFailureBarText = (wrapper) => wrapper.$el.querySelector('.status-red').innerText.trim();
 | |
|   const findUnavailableBarText = (wrapper) =>
 | |
|     wrapper.$el.querySelector('.status-unavailable').innerText.trim();
 | |
| 
 | |
|   describe('computed', () => {
 | |
|     describe('neutralCount', () => {
 | |
|       it('returns neutralCount based on totalCount, successCount and failureCount', () => {
 | |
|         expect(vm.neutralCount).toBe(4965); // 5000 - 25 - 10
 | |
|       });
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   describe('template', () => {
 | |
|     it('renders container element', () => {
 | |
|       expect(vm.$el.classList.contains('stacked-progress-bar')).toBeTruthy();
 | |
|     });
 | |
| 
 | |
|     it('renders empty state when count is unavailable', () => {
 | |
|       const vmX = createComponent({ totalCount: 0, successCount: 0, failureCount: 0 });
 | |
| 
 | |
|       expect(findUnavailableBarText(vmX)).not.toBeUndefined();
 | |
|     });
 | |
| 
 | |
|     it('renders bar elements when count is available', () => {
 | |
|       expect(findSuccessBarText(vm)).not.toBeUndefined();
 | |
|       expect(findNeutralBarText(vm)).not.toBeUndefined();
 | |
|       expect(findFailureBarText(vm)).not.toBeUndefined();
 | |
|     });
 | |
| 
 | |
|     describe('getPercent', () => {
 | |
|       it('returns correct percentages from provided count based on `totalCount`', () => {
 | |
|         vm = createComponent({ totalCount: 100, successCount: 25, failureCount: 10 });
 | |
| 
 | |
|         expect(findSuccessBarText(vm)).toBe('25%');
 | |
|         expect(findNeutralBarText(vm)).toBe('65%');
 | |
|         expect(findFailureBarText(vm)).toBe('10%');
 | |
|       });
 | |
| 
 | |
|       it('returns percentage with decimal place when decimal is greater than 1', () => {
 | |
|         vm = createComponent({ successCount: 67 });
 | |
| 
 | |
|         expect(findSuccessBarText(vm)).toBe('1.3%');
 | |
|       });
 | |
| 
 | |
|       it('returns percentage as `< 1%` from provided count based on `totalCount` when evaluated value is less than 1', () => {
 | |
|         vm = createComponent({ successCount: 10 });
 | |
| 
 | |
|         expect(findSuccessBarText(vm)).toBe('< 1%');
 | |
|       });
 | |
| 
 | |
|       it('returns not available if totalCount is falsy', () => {
 | |
|         vm = createComponent({ totalCount: 0 });
 | |
| 
 | |
|         expect(findUnavailableBarText(vm)).toBe('Not available');
 | |
|       });
 | |
| 
 | |
|       it('returns 99.9% when numbers are extreme decimals', () => {
 | |
|         vm = createComponent({ totalCount: 1000000 });
 | |
| 
 | |
|         expect(findNeutralBarText(vm)).toBe('99.9%');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     describe('barStyle', () => {
 | |
|       it('returns style string based on percentage provided', () => {
 | |
|         expect(vm.barStyle(50)).toBe('width: 50%;');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     describe('getTooltip', () => {
 | |
|       describe('when hideTooltips is false', () => {
 | |
|         it('returns label string based on label and count provided', () => {
 | |
|           expect(vm.getTooltip('Synced', 10)).toBe('Synced: 10');
 | |
|         });
 | |
|       });
 | |
| 
 | |
|       describe('when hideTooltips is true', () => {
 | |
|         beforeEach(() => {
 | |
|           vm = createComponent({ hideTooltips: true });
 | |
|         });
 | |
| 
 | |
|         it('returns an empty string', () => {
 | |
|           expect(vm.getTooltip('Synced', 10)).toBe('');
 | |
|         });
 | |
|       });
 | |
|     });
 | |
|   });
 | |
| });
 |