mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-10-31 19:17:48 +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>
		
			
				
	
	
		
			88 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import messageAPI, { buildCreatePayload } from '../../inbox/message';
 | |
| import ApiClient from '../../ApiClient';
 | |
| 
 | |
| describe('#ConversationAPI', () => {
 | |
|   it('creates correct instance', () => {
 | |
|     expect(messageAPI).toBeInstanceOf(ApiClient);
 | |
|     expect(messageAPI).toHaveProperty('get');
 | |
|     expect(messageAPI).toHaveProperty('show');
 | |
|     expect(messageAPI).toHaveProperty('create');
 | |
|     expect(messageAPI).toHaveProperty('update');
 | |
|     expect(messageAPI).toHaveProperty('delete');
 | |
|     expect(messageAPI).toHaveProperty('getPreviousMessages');
 | |
|   });
 | |
| 
 | |
|   describe('API calls', () => {
 | |
|     const originalAxios = window.axios;
 | |
|     const axiosMock = {
 | |
|       post: vi.fn(() => Promise.resolve()),
 | |
|       get: vi.fn(() => Promise.resolve()),
 | |
|       patch: vi.fn(() => Promise.resolve()),
 | |
|       delete: vi.fn(() => Promise.resolve()),
 | |
|     };
 | |
| 
 | |
|     beforeEach(() => {
 | |
|       window.axios = axiosMock;
 | |
|     });
 | |
| 
 | |
|     afterEach(() => {
 | |
|       window.axios = originalAxios;
 | |
|     });
 | |
| 
 | |
|     it('#getPreviousMessages', () => {
 | |
|       messageAPI.getPreviousMessages({
 | |
|         conversationId: 12,
 | |
|         before: 4573,
 | |
|       });
 | |
|       expect(axiosMock.get).toHaveBeenCalledWith(
 | |
|         `/api/v1/conversations/12/messages`,
 | |
|         {
 | |
|           params: {
 | |
|             before: 4573,
 | |
|           },
 | |
|         }
 | |
|       );
 | |
|     });
 | |
|   });
 | |
|   describe('#buildCreatePayload', () => {
 | |
|     it('builds form payload if file is available', () => {
 | |
|       const formPayload = buildCreatePayload({
 | |
|         message: 'test content',
 | |
|         echoId: 12,
 | |
|         isPrivate: true,
 | |
|         contentAttributes: { in_reply_to: 12 },
 | |
|         files: [new Blob(['test-content'], { type: 'application/pdf' })],
 | |
|       });
 | |
|       expect(formPayload).toBeInstanceOf(FormData);
 | |
|       expect(formPayload.get('content')).toEqual('test content');
 | |
|       expect(formPayload.get('echo_id')).toEqual('12');
 | |
|       expect(formPayload.get('private')).toEqual('true');
 | |
|       expect(formPayload.get('cc_emails')).toEqual('');
 | |
|       expect(formPayload.get('bcc_emails')).toEqual('');
 | |
|       expect(formPayload.get('content_attributes')).toEqual(
 | |
|         '{"in_reply_to":12}'
 | |
|       );
 | |
|     });
 | |
| 
 | |
|     it('builds object payload if file is not available', () => {
 | |
|       expect(
 | |
|         buildCreatePayload({
 | |
|           message: 'test content',
 | |
|           isPrivate: false,
 | |
|           echoId: 12,
 | |
|           contentAttributes: { in_reply_to: 12 },
 | |
|         })
 | |
|       ).toEqual({
 | |
|         content: 'test content',
 | |
|         private: false,
 | |
|         echo_id: 12,
 | |
|         content_attributes: { in_reply_to: 12 },
 | |
|         cc_emails: '',
 | |
|         bcc_emails: '',
 | |
|         to_emails: '',
 | |
|         template_params: undefined,
 | |
|       });
 | |
|     });
 | |
|   });
 | |
| });
 |