mirror of
https://github.com/inventree/InvenTree
synced 2024-08-30 18:33:04 +00:00
Merge remote-tracking branch 'inventree/master'
This commit is contained in:
commit
f217650cec
@ -181,9 +181,77 @@ class TestPOReceive(OrderViewTestCase):
|
|||||||
super().setUp()
|
super().setUp()
|
||||||
|
|
||||||
self.po = PurchaseOrder.objects.get(pk=1)
|
self.po = PurchaseOrder.objects.get(pk=1)
|
||||||
|
self.po.status = OrderStatus.PLACED
|
||||||
|
self.po.save()
|
||||||
self.url = reverse('purchase-order-receive', args=(1,))
|
self.url = reverse('purchase-order-receive', args=(1,))
|
||||||
|
|
||||||
|
def post(self, data, validate=None):
|
||||||
|
|
||||||
|
response = self.client.post(self.url, data, HTTP_X_REQUESTED_WITH='XMLHttpRequest')
|
||||||
|
|
||||||
|
if validate is not None:
|
||||||
|
|
||||||
|
data = json.loads(response.content)
|
||||||
|
|
||||||
|
if validate:
|
||||||
|
self.assertTrue(data['form_valid'])
|
||||||
|
else:
|
||||||
|
self.assertFalse(data['form_valid'])
|
||||||
|
|
||||||
|
return response
|
||||||
|
|
||||||
|
def test_get_dialog(self):
|
||||||
|
|
||||||
|
data = {
|
||||||
|
}
|
||||||
|
|
||||||
|
self.client.get(self.url, data, HTTP_X_REQUESTED_WITH='XMLHttpRequest')
|
||||||
|
|
||||||
def test_receive_lines(self):
|
def test_receive_lines(self):
|
||||||
|
|
||||||
# TODO
|
post_data = {
|
||||||
pass
|
}
|
||||||
|
|
||||||
|
self.post(post_data, validate=False)
|
||||||
|
|
||||||
|
# Try with an invalid location
|
||||||
|
post_data['location'] = 12345
|
||||||
|
|
||||||
|
self.post(post_data, validate=False)
|
||||||
|
|
||||||
|
# Try with a valid location
|
||||||
|
post_data['location'] = 1
|
||||||
|
|
||||||
|
# Should fail due to invalid quantity
|
||||||
|
self.post(post_data, validate=False)
|
||||||
|
|
||||||
|
# Try to receive against an invalid line
|
||||||
|
post_data['line-800'] = 100
|
||||||
|
|
||||||
|
# Remove an invalid quantity of items
|
||||||
|
post_data['line-1'] = '7x5q'
|
||||||
|
|
||||||
|
self.post(post_data, validate=False)
|
||||||
|
|
||||||
|
# Receive negative number
|
||||||
|
post_data['line-1'] = -100
|
||||||
|
|
||||||
|
self.post(post_data, validate=False)
|
||||||
|
|
||||||
|
# Receive 75 items
|
||||||
|
post_data['line-1'] = 75
|
||||||
|
|
||||||
|
self.post(post_data, validate=True)
|
||||||
|
|
||||||
|
line = PurchaseOrderLineItem.objects.get(pk=1)
|
||||||
|
|
||||||
|
self.assertEqual(line.received, 75)
|
||||||
|
|
||||||
|
# Receive 30 more items
|
||||||
|
post_data['line-1'] = 30
|
||||||
|
|
||||||
|
self.post(post_data, validate=True)
|
||||||
|
|
||||||
|
line = PurchaseOrderLineItem.objects.get(pk=1)
|
||||||
|
|
||||||
|
self.assertEqual(line.received, 105)
|
||||||
|
@ -381,6 +381,10 @@ class PurchaseOrderReceive(AjaxUpdateView):
|
|||||||
line.receive_quantity = receive
|
line.receive_quantity = receive
|
||||||
self.lines.append(line)
|
self.lines.append(line)
|
||||||
|
|
||||||
|
if len(self.lines) == 0:
|
||||||
|
msg = _("No lines specified")
|
||||||
|
errors = True
|
||||||
|
|
||||||
# No errors? Receive the submitted parts!
|
# No errors? Receive the submitted parts!
|
||||||
if errors is False:
|
if errors is False:
|
||||||
self.receive_parts()
|
self.receive_parts()
|
||||||
|
Loading…
Reference in New Issue
Block a user