mirror of
https://github.com/inventree/InvenTree.git
synced 2025-05-04 22:38:49 +00:00
* Squashed commit of the following: commit 52d7ff0f650bbcfa2d93ac96562b44269d3812a7 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 23:03:20 2024 +0100 fixed lookup commit 0d076eaea89dce24f08af247479b3b4dff1b4df3 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 23:03:08 2024 +0100 switched to pathlib for lookup commit 473e75eda205793769946e923748356ffd7e5b4b Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 22:52:30 2024 +0100 fix wrong url response commit fd74f8d703399c19cb3616ea3b2656a50cd7a6e5 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 21:14:38 2024 +0100 switched to ruff for import sorting commit f83fedbbb8de261ff8c706e179519e58e7a91064 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 21:03:14 2024 +0100 switched to single quotes everywhere commit a92442e60e23be0ff5dcf42d222b0d95823ecb9b Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:58:23 2024 +0100 added autofixes commit cc66c93136fcae8a701810a4f4f38ef3b570be61 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:56:47 2024 +0100 enable autoformat commit 1f343606ec1f2a99acf8a37b9900d78a8fb37282 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:42:14 2024 +0100 Squashed commit of the following: commit f5cf7b2e7872fc19633321713965763d1890b495 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:36:57 2024 +0100 fixed reqs commit 9d845bee98befa4e53c2ac3c783bd704369e3ad2 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:32:35 2024 +0100 disable autofix/format commit aff5f271484c3500df7ddde043767c008ce4af21 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:28:50 2024 +0100 adjust checks commit 47271cf1efa848ec8374a0d83b5646d06fffa6e7 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:28:22 2024 +0100 reorder order of operations commit e1bf178b40b3f0d2d59ba92209156c43095959d2 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:01:09 2024 +0100 adapted ruff settings to better fit code base commit ad7d88a6f4f15c9552522131c4e207256fc2bbf6 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:59:45 2024 +0100 auto fixed docstring commit a2e54a760e17932dbbc2de0dec23906107f2cda9 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:46:35 2024 +0100 fix getattr useage commit cb80c73bc6c0be7f5d2ed3cc9b2ac03fdefd5c41 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:25:09 2024 +0100 fix requirements file commit b7780bbd21a32007f3b0ce495b519bf59bb19bf5 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:42:28 2024 +0100 fix removed sections commit 71f1681f55c15f62c16c1d7f30a745adc496db97 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:41:21 2024 +0100 fix djlint syntax commit a0bcf1bccef8a8ffd482f38e2063bc9066e1d759 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:35:28 2024 +0100 remove flake8 from code base commit 22475b31cc06919785be046e007915e43f356793 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:34:56 2024 +0100 remove flake8 from code base commit 0413350f14773ac6161473e0cfb069713c13c691 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:24:39 2024 +0100 moved ruff section commit d90c48a0bf98befdfacbbb093ee56cdb28afb40d Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:24:24 2024 +0100 move djlint config to pyproject commit c5ce55d5119bf2e35e429986f62f875c86178ae1 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:20:39 2024 +0100 added isort again commit 42a41d23afc280d4ee6f0e640148abc6f460f05a Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:19:02 2024 +0100 move config section commit 85692331816348cb1145570340d1f6488a8265cc Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:17:52 2024 +0100 fix codespell error commit 2897c6704d1311a800ce5aa47878d96d6980b377 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 17:29:21 2024 +0100 replaced flake8 with ruff mostly for speed improvements * enable docstring checks * fix docstrings * fixed D417 Missing argument description * Squashed commit of the following: commit d3b795824b5d6d1c0eda67150b45b5cd672b3f6b Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 22:56:17 2024 +0100 fixed source path commit 0bac0c19b88897a19d5c995e4ff50427718b827e Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 22:47:53 2024 +0100 fixed req commit 9f61f01d9cc01f1fb7123102f3658c890469b8ce Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 22:45:18 2024 +0100 added missing toml req commit 91b71ed24a6761b629768d0ad8829fec2819a966 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:49:50 2024 +0100 moved isort config commit 12460b04196b12d0272d40552402476d5492fea5 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:43:22 2024 +0100 remove flake8 section from setup.cfg commit f5cf7b2e7872fc19633321713965763d1890b495 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:36:57 2024 +0100 fixed reqs commit 9d845bee98befa4e53c2ac3c783bd704369e3ad2 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:32:35 2024 +0100 disable autofix/format commit aff5f271484c3500df7ddde043767c008ce4af21 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:28:50 2024 +0100 adjust checks commit 47271cf1efa848ec8374a0d83b5646d06fffa6e7 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:28:22 2024 +0100 reorder order of operations commit e1bf178b40b3f0d2d59ba92209156c43095959d2 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:01:09 2024 +0100 adapted ruff settings to better fit code base commit ad7d88a6f4f15c9552522131c4e207256fc2bbf6 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:59:45 2024 +0100 auto fixed docstring commit a2e54a760e17932dbbc2de0dec23906107f2cda9 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:46:35 2024 +0100 fix getattr useage commit cb80c73bc6c0be7f5d2ed3cc9b2ac03fdefd5c41 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:25:09 2024 +0100 fix requirements file commit b7780bbd21a32007f3b0ce495b519bf59bb19bf5 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:42:28 2024 +0100 fix removed sections commit 71f1681f55c15f62c16c1d7f30a745adc496db97 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:41:21 2024 +0100 fix djlint syntax commit a0bcf1bccef8a8ffd482f38e2063bc9066e1d759 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:35:28 2024 +0100 remove flake8 from code base commit 22475b31cc06919785be046e007915e43f356793 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:34:56 2024 +0100 remove flake8 from code base commit 0413350f14773ac6161473e0cfb069713c13c691 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:24:39 2024 +0100 moved ruff section commit d90c48a0bf98befdfacbbb093ee56cdb28afb40d Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:24:24 2024 +0100 move djlint config to pyproject commit c5ce55d5119bf2e35e429986f62f875c86178ae1 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:20:39 2024 +0100 added isort again commit 42a41d23afc280d4ee6f0e640148abc6f460f05a Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:19:02 2024 +0100 move config section commit 85692331816348cb1145570340d1f6488a8265cc Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:17:52 2024 +0100 fix codespell error commit 2897c6704d1311a800ce5aa47878d96d6980b377 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 17:29:21 2024 +0100 replaced flake8 with ruff mostly for speed improvements * fix pyproject * make docstrings more uniform * auto-format * fix order * revert url change
371 lines
12 KiB
Python
371 lines
12 KiB
Python
"""Tests for the company model database migrations."""
|
|
|
|
from django_test_migrations.contrib.unittest_case import MigratorTestCase
|
|
|
|
from InvenTree import unit_test
|
|
|
|
|
|
class TestForwardMigrations(MigratorTestCase):
|
|
"""Unit testing class for testing 'company' app migrations."""
|
|
|
|
migrate_from = ('company', unit_test.getOldestMigrationFile('company'))
|
|
migrate_to = ('company', unit_test.getNewestMigrationFile('company'))
|
|
|
|
def prepare(self):
|
|
"""Create some simple Company data, and ensure that it migrates OK."""
|
|
Company = self.old_state.apps.get_model('company', 'company')
|
|
|
|
Company.objects.create(
|
|
name='MSPC', description='Michael Scotts Paper Company', is_supplier=True
|
|
)
|
|
|
|
def test_migrations(self):
|
|
"""Test the database state after applying all migrations."""
|
|
Company = self.new_state.apps.get_model('company', 'company')
|
|
|
|
self.assertEqual(Company.objects.count(), 1)
|
|
|
|
|
|
class TestManufacturerField(MigratorTestCase):
|
|
"""Tests for migration 0019 which migrates from old 'manufacturer_name' field to new 'manufacturer' field."""
|
|
|
|
migrate_from = ('company', '0018_supplierpart_manufacturer')
|
|
migrate_to = ('company', '0019_auto_20200413_0642')
|
|
|
|
def prepare(self):
|
|
"""Prepare the database by adding some test data 'before' the change.
|
|
|
|
Changes:
|
|
- Part object
|
|
- Company object (supplier)
|
|
- SupplierPart object
|
|
"""
|
|
Part = self.old_state.apps.get_model('part', 'part')
|
|
Company = self.old_state.apps.get_model('company', 'company')
|
|
SupplierPart = self.old_state.apps.get_model('company', 'supplierpart')
|
|
|
|
# Create an initial part
|
|
part = Part.objects.create(
|
|
name='Screw',
|
|
description='A single screw',
|
|
level=0,
|
|
tree_id=0,
|
|
lft=0,
|
|
rght=0,
|
|
)
|
|
|
|
# Create a company to act as the supplier
|
|
supplier = Company.objects.create(
|
|
name='Supplier',
|
|
description='A supplier of parts',
|
|
is_supplier=True,
|
|
is_customer=False,
|
|
)
|
|
|
|
# Add some SupplierPart objects
|
|
SupplierPart.objects.create(
|
|
part=part, supplier=supplier, SKU='SCREW.001', manufacturer_name='ACME'
|
|
)
|
|
|
|
SupplierPart.objects.create(
|
|
part=part, supplier=supplier, SKU='SCREW.002', manufacturer_name='Zero Corp'
|
|
)
|
|
|
|
self.assertEqual(Company.objects.count(), 1)
|
|
|
|
def test_company_objects(self):
|
|
"""Test that the new companies have been created successfully."""
|
|
# Two additional company objects should have been created
|
|
Company = self.new_state.apps.get_model('company', 'company')
|
|
self.assertEqual(Company.objects.count(), 3)
|
|
|
|
# The new company/ies must be marked as "manufacturers"
|
|
acme = Company.objects.get(name='ACME')
|
|
self.assertTrue(acme.is_manufacturer)
|
|
|
|
SupplierPart = self.new_state.apps.get_model('company', 'supplierpart')
|
|
parts = SupplierPart.objects.filter(manufacturer=acme)
|
|
self.assertEqual(parts.count(), 1)
|
|
part = parts.first()
|
|
|
|
# Checks on the SupplierPart object
|
|
self.assertEqual(part.manufacturer_name, 'ACME')
|
|
self.assertEqual(part.manufacturer.name, 'ACME')
|
|
|
|
|
|
class TestManufacturerPart(MigratorTestCase):
|
|
"""Tests for migration 0034-0037 which added and transitioned to the ManufacturerPart model."""
|
|
|
|
migrate_from = ('company', '0033_auto_20210410_1528')
|
|
migrate_to = ('company', '0037_supplierpart_update_3')
|
|
|
|
def prepare(self):
|
|
"""Prepare the database by adding some test data 'before' the change.
|
|
|
|
Changes:
|
|
- Part object
|
|
- Company object (supplier)
|
|
- SupplierPart object
|
|
"""
|
|
Part = self.old_state.apps.get_model('part', 'part')
|
|
Company = self.old_state.apps.get_model('company', 'company')
|
|
SupplierPart = self.old_state.apps.get_model('company', 'supplierpart')
|
|
|
|
# Create an initial part
|
|
part = Part.objects.create(
|
|
name='CAP CER 0.1UF 10V X5R 0402',
|
|
description='CAP CER 0.1UF 10V X5R 0402',
|
|
purchaseable=True,
|
|
level=0,
|
|
tree_id=0,
|
|
lft=0,
|
|
rght=0,
|
|
)
|
|
|
|
# Create a manufacturer
|
|
manufacturer = Company.objects.create(
|
|
name='Murata',
|
|
description='Makes capacitors',
|
|
is_manufacturer=True,
|
|
is_supplier=False,
|
|
is_customer=False,
|
|
)
|
|
|
|
# Create suppliers
|
|
supplier_1 = Company.objects.create(
|
|
name='Digi-Key',
|
|
description='A supplier of components',
|
|
is_manufacturer=False,
|
|
is_supplier=True,
|
|
is_customer=False,
|
|
)
|
|
|
|
supplier_2 = Company.objects.create(
|
|
name='Mouser',
|
|
description='We sell components',
|
|
is_manufacturer=False,
|
|
is_supplier=True,
|
|
is_customer=False,
|
|
)
|
|
|
|
# Add some SupplierPart objects
|
|
SupplierPart.objects.create(
|
|
part=part,
|
|
supplier=supplier_1,
|
|
SKU='DK-MUR-CAP-123456-ND',
|
|
manufacturer=manufacturer,
|
|
MPN='MUR-CAP-123456',
|
|
)
|
|
|
|
SupplierPart.objects.create(
|
|
part=part,
|
|
supplier=supplier_1,
|
|
SKU='DK-MUR-CAP-987654-ND',
|
|
manufacturer=manufacturer,
|
|
MPN='MUR-CAP-987654',
|
|
)
|
|
|
|
SupplierPart.objects.create(
|
|
part=part,
|
|
supplier=supplier_2,
|
|
SKU='CAP-CER-01UF',
|
|
manufacturer=manufacturer,
|
|
MPN='MUR-CAP-123456',
|
|
)
|
|
|
|
# No MPN
|
|
SupplierPart.objects.create(
|
|
part=part,
|
|
supplier=supplier_2,
|
|
SKU='CAP-CER-01UF-1',
|
|
manufacturer=manufacturer,
|
|
)
|
|
|
|
# No Manufacturer
|
|
SupplierPart.objects.create(
|
|
part=part, supplier=supplier_2, SKU='CAP-CER-01UF-2', MPN='MUR-CAP-123456'
|
|
)
|
|
|
|
# No Manufacturer data
|
|
SupplierPart.objects.create(
|
|
part=part, supplier=supplier_2, SKU='CAP-CER-01UF-3'
|
|
)
|
|
|
|
def test_manufacturer_part_objects(self):
|
|
"""Test that the new companies have been created successfully."""
|
|
# Check on the SupplierPart objects
|
|
SupplierPart = self.new_state.apps.get_model('company', 'supplierpart')
|
|
|
|
supplier_parts = SupplierPart.objects.all()
|
|
self.assertEqual(supplier_parts.count(), 6)
|
|
|
|
supplier_parts = SupplierPart.objects.filter(supplier__name='Mouser')
|
|
self.assertEqual(supplier_parts.count(), 4)
|
|
|
|
# Check on the ManufacturerPart objects
|
|
ManufacturerPart = self.new_state.apps.get_model('company', 'manufacturerpart')
|
|
|
|
manufacturer_parts = ManufacturerPart.objects.all()
|
|
self.assertEqual(manufacturer_parts.count(), 4)
|
|
|
|
manufacturer_part = manufacturer_parts.first()
|
|
self.assertEqual(manufacturer_part.MPN, 'MUR-CAP-123456')
|
|
|
|
|
|
class TestCurrencyMigration(MigratorTestCase):
|
|
"""Tests for upgrade from basic currency support to django-money."""
|
|
|
|
migrate_from = ('company', '0025_auto_20201110_1001')
|
|
migrate_to = ('company', '0026_auto_20201110_1011')
|
|
|
|
def prepare(self):
|
|
"""Prepare some data.
|
|
|
|
Changes:
|
|
- A part to buy
|
|
- A supplier to buy from
|
|
- A supplier part
|
|
- Multiple currency objects
|
|
- Multiple supplier price breaks
|
|
"""
|
|
Part = self.old_state.apps.get_model('part', 'part')
|
|
|
|
part = Part.objects.create(
|
|
name='PART',
|
|
description='A purchaseable part',
|
|
purchaseable=True,
|
|
level=0,
|
|
tree_id=0,
|
|
lft=0,
|
|
rght=0,
|
|
)
|
|
|
|
Company = self.old_state.apps.get_model('company', 'company')
|
|
|
|
supplier = Company.objects.create(
|
|
name='Supplier', description='A supplier', is_supplier=True
|
|
)
|
|
|
|
SupplierPart = self.old_state.apps.get_model('company', 'supplierpart')
|
|
|
|
sp = SupplierPart.objects.create(part=part, supplier=supplier, SKU='12345')
|
|
|
|
Currency = self.old_state.apps.get_model('common', 'currency')
|
|
|
|
aud = Currency.objects.create(
|
|
symbol='$', suffix='AUD', description='Australian Dollars', value=1.0
|
|
)
|
|
usd = Currency.objects.create(
|
|
symbol='$', suffix='USD', description='US Dollars', value=1.0
|
|
)
|
|
|
|
PB = self.old_state.apps.get_model('company', 'supplierpricebreak')
|
|
|
|
PB.objects.create(part=sp, quantity=10, cost=5, currency=aud)
|
|
PB.objects.create(part=sp, quantity=20, cost=3, currency=aud)
|
|
PB.objects.create(part=sp, quantity=30, cost=2, currency=aud)
|
|
|
|
PB.objects.create(part=sp, quantity=40, cost=2, currency=usd)
|
|
PB.objects.create(part=sp, quantity=50, cost=2, currency=usd)
|
|
|
|
for pb in PB.objects.all():
|
|
self.assertIsNone(pb.price)
|
|
|
|
def test_currency_migration(self):
|
|
"""Test database state after applying migrations."""
|
|
PB = self.new_state.apps.get_model('company', 'supplierpricebreak')
|
|
|
|
for pb in PB.objects.all():
|
|
# Test that a price has been assigned
|
|
self.assertIsNotNone(pb.price)
|
|
|
|
|
|
class TestAddressMigration(MigratorTestCase):
|
|
"""Test moving address data into Address model."""
|
|
|
|
migrate_from = ('company', '0063_auto_20230502_1956')
|
|
migrate_to = ('company', '0064_move_address_field_to_address_model')
|
|
|
|
# Setting up string values for reuse
|
|
short_l1 = 'Less than 50 characters long address'
|
|
long_l1 = 'More than 50 characters long address testing line '
|
|
l2 = 'splitting functionality'
|
|
|
|
def prepare(self):
|
|
"""Set up some companies with addresses."""
|
|
Company = self.old_state.apps.get_model('company', 'company')
|
|
|
|
Company.objects.create(name='Company 1', address=self.short_l1)
|
|
Company.objects.create(name='Company 2', address=self.long_l1 + self.l2)
|
|
|
|
def test_address_migration(self):
|
|
"""Test database state after applying the migration."""
|
|
Address = self.new_state.apps.get_model('company', 'address')
|
|
Company = self.new_state.apps.get_model('company', 'company')
|
|
|
|
c1 = Company.objects.filter(name='Company 1').first()
|
|
c2 = Company.objects.filter(name='Company 2').first()
|
|
|
|
self.assertEqual(len(Address.objects.all()), 2)
|
|
|
|
a1 = Address.objects.filter(company=c1.pk).first()
|
|
a2 = Address.objects.filter(company=c2.pk).first()
|
|
|
|
self.assertEqual(a1.line1, self.short_l1)
|
|
self.assertEqual(a1.line2, '')
|
|
self.assertEqual(a2.line1, self.long_l1)
|
|
self.assertEqual(a2.line2, self.l2)
|
|
self.assertEqual(c1.address, '')
|
|
self.assertEqual(c2.address, '')
|
|
|
|
|
|
class TestSupplierPartQuantity(MigratorTestCase):
|
|
"""Test that the supplier part quantity is correctly migrated."""
|
|
|
|
migrate_from = ('company', '0058_auto_20230515_0004')
|
|
migrate_to = ('company', unit_test.getNewestMigrationFile('company'))
|
|
|
|
def prepare(self):
|
|
"""Prepare a number of SupplierPart objects."""
|
|
Part = self.old_state.apps.get_model('part', 'part')
|
|
Company = self.old_state.apps.get_model('company', 'company')
|
|
SupplierPart = self.old_state.apps.get_model('company', 'supplierpart')
|
|
|
|
self.part = Part.objects.create(
|
|
name='PART',
|
|
description='A purchaseable part',
|
|
purchaseable=True,
|
|
level=0,
|
|
tree_id=0,
|
|
lft=0,
|
|
rght=0,
|
|
)
|
|
|
|
self.supplier = Company.objects.create(
|
|
name='Supplier', description='A supplier', is_supplier=True
|
|
)
|
|
|
|
self.supplier_parts = []
|
|
|
|
for i in range(10):
|
|
self.supplier_parts.append(
|
|
SupplierPart.objects.create(
|
|
part=self.part,
|
|
supplier=self.supplier,
|
|
SKU=f'SKU-{i}',
|
|
pack_size=i + 1,
|
|
)
|
|
)
|
|
|
|
def test_supplier_part_quantity(self):
|
|
"""Test that the supplier part quantity is correctly migrated."""
|
|
SupplierPart = self.new_state.apps.get_model('company', 'supplierpart')
|
|
|
|
for i, sp in enumerate(SupplierPart.objects.all()):
|
|
self.assertEqual(sp.pack_quantity, str(i + 1))
|
|
self.assertEqual(sp.pack_quantity_native, i + 1)
|
|
|
|
# And the 'pack_size' attribute has been removed
|
|
with self.assertRaises(AttributeError):
|
|
sp.pack_size
|