Compare commits
	
		
			6 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| a265b94460 | |||
| 253fcbae27 | |||
| d127609508 | |||
| 604bbd3ab9 | |||
| e17b8f6973 | |||
| e3f571afc5 | 
| @@ -194,12 +194,18 @@ class SalesToTrytonView(APIView): | ||||
|  | ||||
|         sales = Sale.objects.filter(external_id=None) | ||||
|         for sale in sales: | ||||
|             try: | ||||
|                 lines = SaleLine.objects.filter(sale=sale.id) | ||||
|                 tryton_params = self.__to_tryton_params(sale, lines, tryton_context) | ||||
|                 external_ids = tryton_client.call(method, tryton_params) | ||||
|                 sale.external_id = external_ids[0] | ||||
|                 sale.save() | ||||
|                 successful.append(sale.id) | ||||
|             except Exception as e: | ||||
|                 print(f"Error al enviar la venta: {e}" | ||||
|                       f"venta_id: {sale.id}") | ||||
|                 failed.append(sale.id) | ||||
|                 continue | ||||
|  | ||||
|         return Response( | ||||
|             {'successful': successful, 'failed': failed}, | ||||
|   | ||||
| @@ -15,7 +15,7 @@ class SaleSerializer(serializers.ModelSerializer): | ||||
|     class Meta: | ||||
|         model = Sale | ||||
|         fields = ['id', 'customer', 'date', 'saleline_set', | ||||
|                   'total', 'payment_method'] | ||||
|                   'total', 'payment_method', 'external_id'] | ||||
|  | ||||
|  | ||||
| class ProductSerializer(serializers.ModelSerializer): | ||||
| @@ -27,7 +27,7 @@ class ProductSerializer(serializers.ModelSerializer): | ||||
| class CustomerSerializer(serializers.ModelSerializer): | ||||
|     class Meta: | ||||
|         model = Customer | ||||
|         fields = ['id', 'name', 'address', 'email', 'phone'] | ||||
|         fields = ['id', 'name', 'address', 'email', 'phone', 'external_id'] | ||||
|  | ||||
|  | ||||
| class ReconciliationJarSerializer(serializers.ModelSerializer): | ||||
|   | ||||
| @@ -16,7 +16,8 @@ class TestAPI(APITestCase): | ||||
|             measuring_unit='UNIT' | ||||
|         ) | ||||
|         self.customer = Customer.objects.create( | ||||
|             name='Camilo' | ||||
|             name='Camilo', | ||||
|             external_id='18' | ||||
|         ) | ||||
|  | ||||
|     def test_create_sale(self): | ||||
| @@ -67,6 +68,23 @@ class TestAPI(APITestCase): | ||||
|         json_response = json.loads(response.content.decode('utf-8')) | ||||
|         self.assertEqual(response.status_code, 200) | ||||
|         self.assertEqual(self.customer.name, json_response[0]['name']) | ||||
|         self.assertEqual( | ||||
|             self.customer.external_id, | ||||
|             json_response[0]['external_id'] | ||||
|         ) | ||||
|  | ||||
|     def test_get_sales(self): | ||||
|         url = '/don_confiao/api/sales/' | ||||
|         self._create_sale() | ||||
|  | ||||
|         response = self.client.get(url) | ||||
|         json_response = json.loads(response.content.decode('utf-8')) | ||||
|         self.assertEqual(response.status_code, 200) | ||||
|         self.assertEqual(self.customer.id, json_response[0]['customer']) | ||||
|         self.assertEqual( | ||||
|             None, | ||||
|             json_response[0]['external_id'] | ||||
|         ) | ||||
|  | ||||
|     def test_get_sales_for_tryton(self): | ||||
|         url = '/don_confiao/api/sales/for_tryton' | ||||
|   | ||||
		Reference in New Issue
	
	Block a user