mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-10-31 02:57:57 +00:00 
			
		
		
		
	 9de8c27368
			
		
	
	9de8c27368
	
	
	
		
			
			Due to the pattern `**/specs/*.spec.js` defined in CircleCI, none of the frontend spec in the folders such as `specs/<domain-name>/getters.spec.js` were not executed in Circle CI. This PR fixes the issue, along with the following changes: - Use vitest instead of jest - Remove jest dependancies - Update tests to work with vitest --------- Co-authored-by: Muhsin Keloth <muhsinkeramam@gmail.com>
		
			
				
	
	
		
			65 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import axios from 'axios';
 | |
| import { actions } from '../../csat';
 | |
| import types from '../../../mutation-types';
 | |
| 
 | |
| const commit = vi.fn();
 | |
| global.axios = axios;
 | |
| vi.mock('axios');
 | |
| 
 | |
| describe('#actions', () => {
 | |
|   describe('#get', () => {
 | |
|     it('sends correct mutations if API is success', async () => {
 | |
|       axios.get.mockResolvedValue({
 | |
|         data: [{ id: 1, rating: 1, feedback_text: 'Bad' }],
 | |
|       });
 | |
|       await actions.get({ commit }, { page: 1 });
 | |
|       expect(commit.mock.calls).toEqual([
 | |
|         [types.SET_CSAT_RESPONSE_UI_FLAG, { isFetching: true }],
 | |
|         [types.SET_CSAT_RESPONSE, [{ id: 1, rating: 1, feedback_text: 'Bad' }]],
 | |
|         [types.SET_CSAT_RESPONSE_UI_FLAG, { isFetching: false }],
 | |
|       ]);
 | |
|     });
 | |
|     it('sends correct actions if API is error', async () => {
 | |
|       axios.get.mockRejectedValue({ message: 'Incorrect header' });
 | |
|       await actions.get({ commit }, { page: 1 });
 | |
|       expect(commit.mock.calls).toEqual([
 | |
|         [types.SET_CSAT_RESPONSE_UI_FLAG, { isFetching: true }],
 | |
|         [types.SET_CSAT_RESPONSE_UI_FLAG, { isFetching: false }],
 | |
|       ]);
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   describe('#getMetrics', () => {
 | |
|     it('sends correct mutations if API is success', async () => {
 | |
|       axios.get.mockResolvedValue({
 | |
|         data: {
 | |
|           total_count: 29,
 | |
|           ratings_count: { 1: 10, 2: 10, 3: 3, 4: 3, 5: 3 },
 | |
|           total_sent_messages_count: 120,
 | |
|         },
 | |
|       });
 | |
|       await actions.getMetrics({ commit }, { page: 1 });
 | |
|       expect(commit.mock.calls).toEqual([
 | |
|         [types.SET_CSAT_RESPONSE_UI_FLAG, { isFetchingMetrics: true }],
 | |
|         [
 | |
|           types.SET_CSAT_RESPONSE_METRICS,
 | |
|           {
 | |
|             total_count: 29,
 | |
|             ratings_count: { 1: 10, 2: 10, 3: 3, 4: 3, 5: 3 },
 | |
|             total_sent_messages_count: 120,
 | |
|           },
 | |
|         ],
 | |
|         [types.SET_CSAT_RESPONSE_UI_FLAG, { isFetchingMetrics: false }],
 | |
|       ]);
 | |
|     });
 | |
|     it('sends correct actions if API is error', async () => {
 | |
|       axios.get.mockRejectedValue({ message: 'Incorrect header' });
 | |
|       await actions.getMetrics({ commit }, { page: 1 });
 | |
|       expect(commit.mock.calls).toEqual([
 | |
|         [types.SET_CSAT_RESPONSE_UI_FLAG, { isFetchingMetrics: true }],
 | |
|         [types.SET_CSAT_RESPONSE_UI_FLAG, { isFetchingMetrics: false }],
 | |
|       ]);
 | |
|     });
 | |
|   });
 | |
| });
 |