diff options
author | Matthew Lemon <lemon@matthewlemon.com> | 2020-01-21 18:03:43 +0000 |
---|---|---|
committer | Matthew Lemon <lemon@matthewlemon.com> | 2020-01-21 18:04:15 +0000 |
commit | 5f06e5559c00db759574467c3884a4645346b224 (patch) | |
tree | 8fcd68579d7441823da3e90d913a0694fc65855e | |
parent | 490fc024506c9ed9f9c0b5a4cfbcdecc95127dbe (diff) |
reconfigured Address and Organisation relationship
Diffstat (limited to '')
-rw-r--r-- | ctrack/organisations/admin.py | 19 | ||||
-rw-r--r-- | ctrack/organisations/migrations/0006_auto_20200121_1732.py | 24 | ||||
-rw-r--r-- | ctrack/organisations/models.py | 24 | ||||
-rw-r--r-- | ctrack/organisations/tests/test_models.py | 12 | ||||
-rw-r--r-- | ctrack/users/tests/factories.py | 17 |
5 files changed, 65 insertions, 31 deletions
diff --git a/ctrack/organisations/admin.py b/ctrack/organisations/admin.py index 8890f15..1f36699 100644 --- a/ctrack/organisations/admin.py +++ b/ctrack/organisations/admin.py @@ -1,6 +1,21 @@ from django.contrib import admin -from .models import Organisation +from .models import Organisation, Address, AddressType + + +class OrganisationAdmin(admin.ModelAdmin): + pass + + +class AddressTypeAdmin(admin.ModelAdmin): + pass + + +class AddressAdmin(admin.ModelAdmin): + pass + # Register your models here. -admin.site.register(Organisation) +admin.site.register(Organisation, OrganisationAdmin) +admin.site.register(AddressType, AddressTypeAdmin) +admin.site.register(Address, AddressAdmin) diff --git a/ctrack/organisations/migrations/0006_auto_20200121_1732.py b/ctrack/organisations/migrations/0006_auto_20200121_1732.py new file mode 100644 index 0000000..48a0636 --- /dev/null +++ b/ctrack/organisations/migrations/0006_auto_20200121_1732.py @@ -0,0 +1,24 @@ +# Generated by Django 2.2.9 on 2020-01-21 17:32 + +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + dependencies = [ + ('organisations', '0005_auto_20200121_1028'), + ] + + operations = [ + migrations.RemoveField( + model_name='organisation', + name='address', + ), + migrations.AddField( + model_name='address', + name='organisation', + field=models.ForeignKey(default=1, on_delete=django.db.models.deletion.CASCADE, to='organisations.Organisation'), + preserve_default=False, + ), + ] diff --git a/ctrack/organisations/models.py b/ctrack/organisations/models.py index cf8e7de..6bd1249 100644 --- a/ctrack/organisations/models.py +++ b/ctrack/organisations/models.py @@ -9,7 +9,20 @@ class AddressType(models.Model): descriptor = models.CharField(max_length=50) +class Organisation(models.Model): + name = models.CharField(max_length=255, blank=False) + + def get_absolute_url(self): + return reverse("organisations:detail", kwargs={"name": self.slugify_name()}) + + def slugify_name(self): + return slugify(self.name) + + class Address(models.Model): + organisation = models.ForeignKey( + Organisation, related_name="addresses", on_delete=models.CASCADE, blank=False + ) type = models.ForeignKey(AddressType, on_delete=models.CASCADE, default=1) line1 = models.CharField(max_length=255) line2 = models.CharField(max_length=255) @@ -19,14 +32,3 @@ class Address(models.Model): postcode = models.CharField(max_length=10) country = models.CharField(max_length=100) other_details = models.CharField(max_length=255) - - -class Organisation(models.Model): - name = models.CharField(max_length=255, blank=False) - address = models.ForeignKey(Address, on_delete=models.CASCADE, blank=True, null=True) - - def get_absolute_url(self): - return reverse("organisations:detail", kwargs={"name": self.slugify_name()}) - - def slugify_name(self): - return slugify(self.name) diff --git a/ctrack/organisations/tests/test_models.py b/ctrack/organisations/tests/test_models.py index d070a84..946fda5 100644 --- a/ctrack/organisations/tests/test_models.py +++ b/ctrack/organisations/tests/test_models.py @@ -1,7 +1,7 @@ import pytest from slugify import slugify -from ..models import Organisation, Address +from ..models import Organisation pytestmark = pytest.mark.django_db @@ -11,12 +11,10 @@ def test_organisation_get_absolute_url(org: Organisation): assert org.get_absolute_url() == f"/organisations/{slug}/" -def test_create_organisation(addr: Address): - Organisation(name="Big Bad OES Corporation", address=addr).save() +def test_create_organisation(): + Organisation(name="Big Bad OES Corporation").save() # The organisation is saved in the db assert Organisation.objects.get(name="Big Bad OES Corporation") - # The organisation has the correct address - assert Organisation.objects.get(name="Big Bad OES Corporation").address.type.descriptor == "Primary Address" def test_delete_organisation(org: Organisation): @@ -30,9 +28,5 @@ def test_delete_organisation(org: Organisation): def test_update_organisation(org: Organisation): # Change the name of the organisation org.name = "Tonkers Ltd" - # Get current value of line1 of the address - addr_line1 = org.address.line1 org.save() assert org.name == "Tonkers Ltd" - # Assert that the address hasn't changed - assert addr_line1 == org.address.line1 diff --git a/ctrack/users/tests/factories.py b/ctrack/users/tests/factories.py index 9907945..53584b7 100644 --- a/ctrack/users/tests/factories.py +++ b/ctrack/users/tests/factories.py @@ -6,15 +6,22 @@ from factory import DjangoModelFactory, Faker, post_generation, SubFactory class AddressTypeFactory(DjangoModelFactory): - descriptor = "Primary Address" class Meta: model = AddressType +class OrganisationFactory(DjangoModelFactory): + name = Faker("company", locale="en_GB") + + class Meta: + model = Organisation + + class AddressFactory(DjangoModelFactory): type = SubFactory(AddressTypeFactory) + organisation = SubFactory(OrganisationFactory) line1 = Faker("secondary_address", locale="en_GB") line2 = Faker("street_name", locale="en_GB") line3 = Faker("secondary_address", locale="en_GB") @@ -28,14 +35,6 @@ class AddressFactory(DjangoModelFactory): model = Address -class OrganisationFactory(DjangoModelFactory): - name = Faker("company", locale="en_GB") - address = SubFactory(AddressFactory) - - class Meta: - model = Organisation - - class UserFactory(DjangoModelFactory): username = Faker("user_name") email = Faker("email") |