mirror of
https://github.com/inventree/InvenTree.git
synced 2025-06-17 20:45:44 +00:00
* Add pre-commit to the stack * exclude static * Add locales to excludes * fix style errors * rename pipeline steps * also wait on precommit * make template matching simpler * Use the same code for python setup everywhere * use step and cache for python setup * move regular settings up into general envs * just use full update * Use invoke instead of static references * make setup actions more similar * use python3 * refactor names to be similar * fix runner version * fix references * remove incidential change * use matrix for os * Github can't do this right now * ignore docstyle errors * Add seperate docstring test * update flake call * do not fail on docstring * refactor setup into workflow * update reference * switch to action * resturcture * add bash statements * remove os from cache * update input checks * make code cleaner * fix boolean * no relative paths * install wheel by python * switch to install * revert back to simple wheel * refactor import export tests * move setup keys back to not disturbe tests * remove docstyle till that is fixed * update references * continue on error * add docstring test * use relativ action references * Change step / job docstrings * update to merge * reformat comments 1 * fix docstrings 2 * fix docstrings 3 * fix docstrings 4 * fix docstrings 5 * fix docstrings 6 * fix docstrings 7 * fix docstrings 8 * fix docstirns 9 * fix docstrings 10 * docstring adjustments * update the remaining docstrings * small docstring changes * fix function name * update support files for docstrings * Add missing args to docstrings * Remove outdated function * Add docstrings for the 'build' app * Make API code cleaner * add more docstrings for plugin app * Remove dead code for plugin settings No idea what that was even intended for * ignore __init__ files for docstrings * More docstrings * Update docstrings for the 'part' directory * Fixes for related_part functionality * Fix removed stuff from merge99676ee
* make more consistent * Show statistics for docstrings * add more docstrings * move specific register statements to make them clearer to understant * More docstrings for common * and more docstrings * and more * simpler call * docstrings for notifications * docstrings for common/tests * Add docs for common/models * Revert "move specific register statements to make them clearer to understant" This reverts commitca96654622
. * use typing here * Revert "Make API code cleaner" This reverts commit24fb68bd3e
. * docstring updates for the 'users' app * Add generic Meta info to simple Meta classes * remove unneeded unique_together statements * More simple metas * Remove unnecessary format specifier * Remove extra json format specifiers * Add docstrings for the 'plugin' app * Docstrings for the 'label' app * Add missing docstrings for the 'report' app * Fix build test regression * Fix top-level files * docstrings for InvenTree/InvenTree * reduce unneeded code * add docstrings * and more docstrings * more docstrings * more docstrings for stock * more docstrings * docstrings for order/views * Docstrings for various files in the 'order' app * Docstrings for order/test_api.py * Docstrings for order/serializers.py * Docstrings for order/admin.py * More docstrings for the order app * Add docstrings for the 'company' app * Add unit tests for rebuilding the reference fields * Prune out some more dead code * remove more dead code Co-authored-by: Oliver Walters <oliver.henry.walters@gmail.com>
193 lines
6.6 KiB
Python
193 lines
6.6 KiB
Python
"""Unit tests for the 'order' model data migrations."""
|
|
|
|
from django_test_migrations.contrib.unittest_case import MigratorTestCase
|
|
|
|
from InvenTree.status_codes import SalesOrderStatus
|
|
|
|
|
|
class TestRefIntMigrations(MigratorTestCase):
|
|
"""Test entire schema migration."""
|
|
|
|
migrate_from = ('order', '0040_salesorder_target_date')
|
|
migrate_to = ('order', '0061_merge_0054_auto_20211201_2139_0060_auto_20211129_1339')
|
|
|
|
def prepare(self):
|
|
"""Create initial data set."""
|
|
# Create a purchase order from a supplier
|
|
Company = self.old_state.apps.get_model('company', 'company')
|
|
|
|
supplier = Company.objects.create(
|
|
name='Supplier A',
|
|
description='A great supplier!',
|
|
is_supplier=True,
|
|
is_customer=True,
|
|
)
|
|
|
|
PurchaseOrder = self.old_state.apps.get_model('order', 'purchaseorder')
|
|
SalesOrder = self.old_state.apps.get_model('order', 'salesorder')
|
|
|
|
# Create some orders
|
|
for ii in range(10):
|
|
|
|
order = PurchaseOrder.objects.create(
|
|
supplier=supplier,
|
|
reference=f"{ii}-abcde",
|
|
description="Just a test order"
|
|
)
|
|
|
|
# Initially, the 'reference_int' field is unavailable
|
|
with self.assertRaises(AttributeError):
|
|
print(order.reference_int)
|
|
|
|
sales_order = SalesOrder.objects.create(
|
|
customer=supplier,
|
|
reference=f"{ii}-xyz",
|
|
description="A test sales order",
|
|
)
|
|
|
|
# Initially, the 'reference_int' field is unavailable
|
|
with self.assertRaises(AttributeError):
|
|
print(sales_order.reference_int)
|
|
|
|
def test_ref_field(self):
|
|
"""Test that the 'reference_int' field has been created and is filled out correctly."""
|
|
PurchaseOrder = self.new_state.apps.get_model('order', 'purchaseorder')
|
|
SalesOrder = self.new_state.apps.get_model('order', 'salesorder')
|
|
|
|
for ii in range(10):
|
|
|
|
po = PurchaseOrder.objects.get(reference=f"{ii}-abcde")
|
|
so = SalesOrder.objects.get(reference=f"{ii}-xyz")
|
|
|
|
# The integer reference field must have been correctly updated
|
|
self.assertEqual(po.reference_int, ii)
|
|
self.assertEqual(so.reference_int, ii)
|
|
|
|
|
|
class TestShipmentMigration(MigratorTestCase):
|
|
"""Test data migration for the "SalesOrderShipment" model."""
|
|
|
|
migrate_from = ('order', '0051_auto_20211014_0623')
|
|
migrate_to = ('order', '0055_auto_20211025_0645')
|
|
|
|
def prepare(self):
|
|
"""Create an initial SalesOrder."""
|
|
Company = self.old_state.apps.get_model('company', 'company')
|
|
|
|
customer = Company.objects.create(
|
|
name='My customer',
|
|
description='A customer we sell stuff too',
|
|
is_customer=True
|
|
)
|
|
|
|
SalesOrder = self.old_state.apps.get_model('order', 'salesorder')
|
|
|
|
for ii in range(5):
|
|
order = SalesOrder.objects.create(
|
|
reference=f'SO{ii}',
|
|
customer=customer,
|
|
description='A sales order for stuffs',
|
|
status=SalesOrderStatus.PENDING,
|
|
)
|
|
|
|
order.save()
|
|
|
|
# The "shipment" model does not exist yet
|
|
with self.assertRaises(LookupError):
|
|
self.old_state.apps.get_model('order', 'salesordershipment')
|
|
|
|
def test_shipment_creation(self):
|
|
"""Check that a SalesOrderShipment has been created."""
|
|
SalesOrder = self.new_state.apps.get_model('order', 'salesorder')
|
|
Shipment = self.new_state.apps.get_model('order', 'salesordershipment')
|
|
|
|
# Check that the correct number of Shipments have been created
|
|
self.assertEqual(SalesOrder.objects.count(), 5)
|
|
self.assertEqual(Shipment.objects.count(), 5)
|
|
|
|
|
|
class TestAdditionalLineMigration(MigratorTestCase):
|
|
"""Test entire schema migration."""
|
|
|
|
migrate_from = ('order', '0063_alter_purchaseorderlineitem_unique_together')
|
|
migrate_to = ('order', '0064_purchaseorderextraline_salesorderextraline')
|
|
|
|
def prepare(self):
|
|
"""Create initial data set."""
|
|
# Create a purchase order from a supplier
|
|
Company = self.old_state.apps.get_model('company', 'company')
|
|
PurchaseOrder = self.old_state.apps.get_model('order', 'purchaseorder')
|
|
Part = self.old_state.apps.get_model('part', 'part')
|
|
Supplierpart = self.old_state.apps.get_model('company', 'supplierpart')
|
|
# TODO @matmair fix this test!!!
|
|
# SalesOrder = self.old_state.apps.get_model('order', 'salesorder')
|
|
|
|
supplier = Company.objects.create(
|
|
name='Supplier A',
|
|
description='A great supplier!',
|
|
is_supplier=True,
|
|
is_customer=True,
|
|
)
|
|
|
|
part = Part.objects.create(
|
|
name='Bob',
|
|
description='Can we build it?',
|
|
assembly=True,
|
|
salable=True,
|
|
purchaseable=False,
|
|
tree_id=0,
|
|
level=0,
|
|
lft=0,
|
|
rght=0,
|
|
)
|
|
supplierpart = Supplierpart.objects.create(
|
|
part=part,
|
|
supplier=supplier
|
|
)
|
|
|
|
# Create some orders
|
|
for ii in range(10):
|
|
|
|
order = PurchaseOrder.objects.create(
|
|
supplier=supplier,
|
|
reference=f"{ii}-abcde",
|
|
description="Just a test order"
|
|
)
|
|
order.lines.create(
|
|
part=supplierpart,
|
|
quantity=12,
|
|
received=1
|
|
)
|
|
order.lines.create(
|
|
quantity=12,
|
|
received=1
|
|
)
|
|
|
|
# TODO @matmair fix this test!!!
|
|
# sales_order = SalesOrder.objects.create(
|
|
# customer=supplier,
|
|
# reference=f"{ii}-xyz",
|
|
# description="A test sales order",
|
|
# )
|
|
# sales_order.lines.create(
|
|
# part=part,
|
|
# quantity=12,
|
|
# received=1
|
|
# )
|
|
|
|
def test_po_migration(self):
|
|
"""Test that the the PO lines where converted correctly."""
|
|
PurchaseOrder = self.new_state.apps.get_model('order', 'purchaseorder')
|
|
for ii in range(10):
|
|
|
|
po = PurchaseOrder.objects.get(reference=f"{ii}-abcde")
|
|
self.assertEqual(po.extra_lines.count(), 1)
|
|
self.assertEqual(po.lines.count(), 1)
|
|
|
|
# TODO @matmair fix this test!!!
|
|
# SalesOrder = self.new_state.apps.get_model('order', 'salesorder')
|
|
# for ii in range(10):
|
|
# so = SalesOrder.objects.get(reference=f"{ii}-xyz")
|
|
# self.assertEqual(so.extra_lines, 1)
|
|
# self.assertEqual(so.lines.count(), 1)
|