From ce0dad5c81923448d1ee32434f1480d152975a85 Mon Sep 17 00:00:00 2001 From: Toon Verwerft Date: Wed, 5 Jun 2024 08:35:22 +0200 Subject: [PATCH] Inherit default qualification from schema when not set --- src/SchemaReader.php | 19 +++++++++++++------ tests/AttributesTest.php | 30 ++++++++++++++++++++++++++++++ tests/ElementsTest.php | 34 ++++++++++++++++++++++++++++++++++ 3 files changed, 77 insertions(+), 6 deletions(-) diff --git a/src/SchemaReader.php b/src/SchemaReader.php index 8642865..abf709d 100644 --- a/src/SchemaReader.php +++ b/src/SchemaReader.php @@ -231,9 +231,13 @@ private function fillAttribute(AttributeSingle $attribute, \DOMElement $node): v if ($node->hasAttribute('nillable')) { $attribute->setNil('true' === $node->getAttribute('nillable')); } - if ($node->hasAttribute('form')) { - $attribute->setQualified('qualified' === $node->getAttribute('form')); - } + + $attribute->setQualified( + $node->hasAttribute('form') + ? 'qualified' === $node->getAttribute('form') + : $attribute->getSchema()->getAttributesQualification() + ); + if ($node->hasAttribute('use')) { $attribute->setUse($node->getAttribute('use')); } @@ -1466,9 +1470,12 @@ private function fillElement(AbstractElementSingle $element, \DOMElement $node): if ($node->hasAttribute('nillable')) { $element->setNil('true' === $node->getAttribute('nillable')); } - if ($node->hasAttribute('form')) { - $element->setQualified('qualified' === $node->getAttribute('form')); - } + + $element->setQualified( + $node->hasAttribute('form') + ? 'qualified' === $node->getAttribute('form') + : $element->getSchema()->getElementsQualification() + ); $parentNode = $node->parentNode; if ('schema' !== $parentNode->localName || self::XSD_NS !== $parentNode->namespaceURI) { diff --git a/tests/AttributesTest.php b/tests/AttributesTest.php index 90ab0f3..d0b4ebb 100644 --- a/tests/AttributesTest.php +++ b/tests/AttributesTest.php @@ -9,6 +9,7 @@ use GoetasWebservices\XML\XSDReader\Schema\Attribute\AttributeRef; use GoetasWebservices\XML\XSDReader\Schema\Attribute\AttributeSingle; use GoetasWebservices\XML\XSDReader\Schema\Attribute\Group; +use GoetasWebservices\XML\XSDReader\Schema\Element\ElementSingle; use GoetasWebservices\XML\XSDReader\Schema\Type\ComplexType; use GoetasWebservices\XML\XSDReader\Schema\Type\SimpleType; @@ -222,4 +223,33 @@ public function testExternalSchemaReferencingCustomAttributesInformationUnprefix $refAttr = $schema->findAttribute('customAttributesType', 'http://www.ref.com'); self::assertSame($refAttr->getSchema()->getTargetNamespace(), $customAttributes[0]->getNamespaceURI()); } + + public function testDefaultSchemaQualificationInheritance(): void + { + $schema = $this->reader->readString( + ' + + + + + + + + ' + ); + + $myType = $schema->findType('root', 'http://www.example.com'); + self::assertInstanceOf(ComplexType::class, $myType); + self::assertTrue($schema->getAttributesQualification()); + + $attribute = $myType->getAttributes()[0]; + self::assertTrue($attribute->isQualified()); + + $attribute = $myType->getAttributes()[1]; + self::assertFalse($attribute->isQualified()); + + $attribute = $myType->getAttributes()[2]; + self::assertTrue($attribute->isQualified()); + } } diff --git a/tests/ElementsTest.php b/tests/ElementsTest.php index 2c9ca08..990d207 100644 --- a/tests/ElementsTest.php +++ b/tests/ElementsTest.php @@ -163,6 +163,40 @@ public function testNotQualifiedTargetQualifiedElement(): void self::assertTrue($element->isQualified()); } + public function testDefaultSchemaQualificationInheritance(): void + { + $schema = $this->reader->readString( + ' + + + + + + + + + + ' + ); + + $myType = $schema->findType('root', 'http://www.example.com'); + self::assertInstanceOf(ComplexType::class, $myType); + self::assertTrue($schema->getElementsQualification()); + + /** + * @var $element ElementSingle + */ + $element = $myType->getElements()[0]; + self::assertTrue($element->isQualified()); + + $element = $myType->getElements()[1]; + self::assertFalse($element->isQualified()); + + $element = $myType->getElements()[2]; + self::assertTrue($element->isQualified()); + } + public function testGroupRefOccurrences(): void { $schema = $this->reader->readString(