Implement unit fields for numeric fields
This commit is contained in:
parent
a268625d80
commit
de6794046d
3 changed files with 67 additions and 37 deletions
|
|
@ -8,28 +8,7 @@ from servala.core.crd import generate_custom_form_class
|
|||
from servala.core.crd.forms import DEFAULT_FIELD_CONFIGS, MANDATORY_FIELDS
|
||||
from servala.core.forms import ServiceDefinitionAdminForm
|
||||
from servala.core.models import ControlPlaneCRD
|
||||
|
||||
|
||||
def test_custom_model_form_class_is_none_when_no_form_config():
|
||||
crd = Mock(spec=ControlPlaneCRD)
|
||||
service_def = Mock()
|
||||
service_def.form_config = None
|
||||
crd.service_definition = service_def
|
||||
crd.django_model = Mock()
|
||||
|
||||
if not (
|
||||
crd.django_model
|
||||
and crd.service_definition
|
||||
and crd.service_definition.form_config
|
||||
and crd.service_definition.form_config.get("fieldsets")
|
||||
):
|
||||
result = None
|
||||
else:
|
||||
result = generate_custom_form_class(
|
||||
crd.service_definition.form_config, crd.django_model
|
||||
)
|
||||
|
||||
assert result is None
|
||||
from servala.frontend.forms.widgets import NumberInputWithAddon
|
||||
|
||||
|
||||
def test_custom_model_form_class_returns_class_when_form_config_exists():
|
||||
|
|
@ -60,18 +39,9 @@ def test_custom_model_form_class_returns_class_when_form_config_exists():
|
|||
app_label = "test"
|
||||
|
||||
crd.django_model = TestModel
|
||||
|
||||
if not (
|
||||
crd.django_model
|
||||
and crd.service_definition
|
||||
and crd.service_definition.form_config
|
||||
and crd.service_definition.form_config.get("fieldsets")
|
||||
):
|
||||
result = None
|
||||
else:
|
||||
result = generate_custom_form_class(
|
||||
crd.service_definition.form_config, crd.django_model
|
||||
)
|
||||
result = generate_custom_form_class(
|
||||
crd.service_definition.form_config, crd.django_model
|
||||
)
|
||||
|
||||
assert result is not None
|
||||
assert hasattr(result, "form_config")
|
||||
|
|
@ -1084,3 +1054,43 @@ def test_empty_values_dont_override_default_configs():
|
|||
assert name_field.max_length == DEFAULT_FIELD_CONFIGS["name"]["max_length"]
|
||||
|
||||
assert name_field.required is False # Was overridden by explicit False
|
||||
|
||||
|
||||
def test_number_field_with_addon_text_roundtrip():
|
||||
class TestModel(models.Model):
|
||||
name = models.CharField(max_length=100)
|
||||
disk_size = models.IntegerField()
|
||||
|
||||
class Meta:
|
||||
app_label = "test"
|
||||
|
||||
form_config = {
|
||||
"fieldsets": [
|
||||
{
|
||||
"fields": [
|
||||
{
|
||||
"type": "text",
|
||||
"label": "Name",
|
||||
"controlplane_field_mapping": "name",
|
||||
"required": True,
|
||||
},
|
||||
{
|
||||
"type": "number",
|
||||
"label": "Disk Size",
|
||||
"controlplane_field_mapping": "disk_size",
|
||||
"addon_text": "Gi",
|
||||
},
|
||||
],
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
form_class = generate_custom_form_class(form_config, TestModel)
|
||||
form = form_class(initial={"name": "test-instance", "disk_size": "25Gi"})
|
||||
|
||||
assert form.initial["disk_size"] == 25
|
||||
form = form_class(data={"name": "test-instance", "disk_size": "25"})
|
||||
form.fields["context"].required = False
|
||||
assert form.is_valid(), f"Form should be valid but has errors: {form.errors}"
|
||||
nested_data = form.get_nested_data()
|
||||
assert nested_data["disk_size"] == "25Gi"
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue