init project tests

This commit is contained in:
Maximilian 2025-06-07 19:24:41 +02:00
parent d0ff728224
commit 7c9318c778
44 changed files with 4431 additions and 49 deletions

View file

@ -11,16 +11,10 @@ class DateInput(forms.DateInput):
class CostsForm(forms.ModelForm):
class Meta:
widgets = {
"created": DateInput(
format="%Y-%m-%d", attrs={"value": date.today}
)
}
model = Costs
fields = ["id_bird", "costs", "comment", "created"]
fields = ["id_bird", "costs", "comment"]
labels = {
"id_bird": _("Patient"),
"costs": _("Betrag [€]"),
"comment": _("Bemerkung"),
"created": _("Gebucht am"),
}

View file

@ -0,0 +1,74 @@
# Generated by Django 5.2.2 on 2025-06-07 16:07
import django.core.validators
import django.db.models.deletion
from decimal import Decimal
from django.conf import settings
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('bird', '0004_expand_costs_model'),
('costs', '0001_initial'),
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
]
operations = [
migrations.AddField(
model_name='costs',
name='amount',
field=models.DecimalField(decimal_places=2, default=Decimal('0.00'), max_digits=10, validators=[django.core.validators.MinValueValidator(Decimal('0.00'))], verbose_name='Betrag'),
),
migrations.AddField(
model_name='costs',
name='bird',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='costs', to='bird.bird', verbose_name='Vogel'),
),
migrations.AddField(
model_name='costs',
name='category',
field=models.CharField(choices=[('medical', 'Medizinisch'), ('food', 'Nahrung'), ('equipment', 'Ausrüstung'), ('transport', 'Transport'), ('other', 'Sonstiges')], default='other', max_length=20, verbose_name='Kategorie'),
),
migrations.AddField(
model_name='costs',
name='cost_date',
field=models.DateField(blank=True, null=True, verbose_name='Kostendatum'),
),
migrations.AddField(
model_name='costs',
name='created_by',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='costs_created', to=settings.AUTH_USER_MODEL, verbose_name='Erstellt von'),
),
migrations.AddField(
model_name='costs',
name='description',
field=models.CharField(default='', max_length=512, verbose_name='Beschreibung'),
),
migrations.AddField(
model_name='costs',
name='invoice_number',
field=models.CharField(blank=True, max_length=100, null=True, verbose_name='Rechnungsnummer'),
),
migrations.AddField(
model_name='costs',
name='notes',
field=models.TextField(blank=True, null=True, verbose_name='Notizen'),
),
migrations.AddField(
model_name='costs',
name='vendor',
field=models.CharField(blank=True, max_length=256, null=True, verbose_name='Anbieter'),
),
migrations.AlterField(
model_name='costs',
name='costs',
field=models.DecimalField(decimal_places=2, default='0.00', max_digits=5, verbose_name='Betrag (legacy)'),
),
migrations.AlterField(
model_name='costs',
name='id_bird',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='costs', to='bird.fallenbird', verbose_name='Patient'),
),
]

View file

@ -0,0 +1,18 @@
# Generated by Django 5.2.2 on 2025-06-07 17:06
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('costs', '0002_expand_costs_model'),
]
operations = [
migrations.AlterField(
model_name='costs',
name='created',
field=models.DateField(auto_now_add=True, verbose_name='Gebucht am'),
),
]

View file

@ -3,36 +3,121 @@ from uuid import uuid4
from django.db import models
from django.conf import settings
from django.utils.translation import gettext_lazy as _
from django.core.validators import MinValueValidator, ValidationError
from decimal import Decimal
from bird.models import FallenBird
from bird.models import Bird
CHOICE_CATEGORY = [
("medical", _("Medizinisch")),
("food", _("Nahrung")),
("equipment", _("Ausrüstung")),
("transport", _("Transport")),
("other", _("Sonstiges")),
]
class Costs(models.Model):
id = models.UUIDField(primary_key=True, default=uuid4, editable=False)
# Main relationship - could be to Bird or FallenBird
bird = models.ForeignKey(
Bird,
on_delete=models.SET_NULL,
blank=True,
null=True,
verbose_name=_("Vogel"),
related_name='costs'
)
id_bird = models.ForeignKey(
FallenBird,
"bird.FallenBird",
on_delete=models.SET_NULL,
blank=True,
null=True,
verbose_name=_("Patient"),
related_name='costs'
)
# Cost details
description = models.CharField(
max_length=512,
default="",
verbose_name=_("Beschreibung")
)
amount = models.DecimalField(
max_digits=10,
decimal_places=2,
validators=[MinValueValidator(Decimal('0.00'))],
default=Decimal('0.00'),
verbose_name=_("Betrag")
)
cost_date = models.DateField(
null=True,
blank=True,
verbose_name=_("Kostendatum")
)
category = models.CharField(
max_length=20,
choices=CHOICE_CATEGORY,
default="other",
verbose_name=_("Kategorie")
)
# Additional fields expected by tests
invoice_number = models.CharField(
max_length=100,
blank=True,
null=True,
verbose_name=_("Rechnungsnummer")
)
vendor = models.CharField(
max_length=256,
blank=True,
null=True,
verbose_name=_("Anbieter")
)
notes = models.TextField(
blank=True,
null=True,
verbose_name=_("Notizen")
)
# Legacy field for backwards compatibility
costs = models.DecimalField(
max_digits=5,
decimal_places=2,
default="0.00",
verbose_name=_("Betrag"))
verbose_name=_("Betrag (legacy)"))
created = models.DateField(
auto_now_add=True,
verbose_name=_("Gebucht am"))
comment = models.CharField(
max_length=512,
blank=True,
null=True,
verbose_name=_("Bemerkungen"))
user = models.ForeignKey(
settings.AUTH_USER_MODEL,
on_delete=models.CASCADE,
verbose_name=_("Benutzer"))
created_by = models.ForeignKey(
settings.AUTH_USER_MODEL,
on_delete=models.CASCADE,
related_name='costs_created',
null=True,
blank=True,
verbose_name=_("Erstellt von"))
class Meta:
verbose_name = _("Kosten")
verbose_name_plural = _("Kosten")
def clean(self):
"""Validate that amount is not negative."""
if self.amount and self.amount < 0:
raise ValidationError(_("Betrag kann nicht negativ sein."))
def __str__(self):
return f"{self.description} - €{self.amount}"

View file

@ -1,9 +1,10 @@
from django.test import TestCase
from aviary.models import Aviary
# Write costs tests here
class AviaryTestCase(TestCase):
def setUp(self):
Aviary.objects.create(
self.aviary = Aviary.objects.create(
description="Voliere 1",
condition="Offen",
last_ward_round="2021-01-01",
@ -20,7 +21,7 @@ class AviaryTestCase(TestCase):
def test_aviary_last_ward_round(self):
aviary = Aviary.objects.get(description="Voliere 1")
self.assertEqual(aviary.last_ward_round, "2021-01-01")
self.assertEqual(str(aviary.last_ward_round), "2021-01-01")
def test_aviary_comment(self):
aviary = Aviary.objects.get(description="Voliere 1")