Fixes Array So No DefaultFactory is Created When no Default is Set and Field is Required

This commit is contained in:
2025-08-18 22:53:28 -03:00
parent 617f1aab2b
commit 7b9464f458
3 changed files with 46 additions and 6 deletions

View File

@@ -181,7 +181,7 @@ class TestSchemaConverter(TestCase):
self.assertEqual(model(is_active="true").is_active, True)
def test_validation_list(self):
def test_validation_list_with_valid_items(self):
schema = {
"title": "Person",
"description": "A person",
@@ -204,15 +204,52 @@ class TestSchemaConverter(TestCase):
model(friends=["John", "Jane", "John"]).friends, {"John", "Jane"}
)
with self.assertRaises(ValueError):
model()
with self.assertRaises(ValueError):
model(friends=[])
with self.assertRaises(ValueError):
model(friends=["John", "Jane", "Invalid"])
def test_validation_list_with_missing_items(self):
model = SchemaConverter.build(
{
"title": "Person",
"description": "A person",
"type": "object",
"properties": {
"friends": {
"type": "array",
"items": {"type": "string"},
"minItems": 1,
"maxItems": 2,
"default": ["John", "Jane"],
},
},
}
)
self.assertEqual(model().friends, ["John", "Jane"])
model = SchemaConverter.build(
{
"title": "Person",
"description": "A person",
"type": "object",
"properties": {
"friends": {
"type": "array",
"items": {"type": "string"},
"minItems": 1,
"maxItems": 2,
},
},
"required": ["friends"],
}
)
with self.assertRaises(ValueError):
model()
def test_validation_object(self):
schema = {
"title": "Person",
@@ -238,6 +275,9 @@ class TestSchemaConverter(TestCase):
self.assertEqual(obj.address.street, "123 Main St")
self.assertEqual(obj.address.city, "Springfield")
with self.assertRaises(ValueError):
model()
def test_default_for_string(self):
schema = {
"title": "Person",