diff options
Diffstat (limited to 'www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/Exporter/Element/ExpNsResourceTest.php')
-rw-r--r-- | www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/Exporter/Element/ExpNsResourceTest.php | 259 |
1 files changed, 259 insertions, 0 deletions
diff --git a/www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/Exporter/Element/ExpNsResourceTest.php b/www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/Exporter/Element/ExpNsResourceTest.php new file mode 100644 index 00000000..3bac57cb --- /dev/null +++ b/www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/Exporter/Element/ExpNsResourceTest.php @@ -0,0 +1,259 @@ +<?php + +namespace SMW\Tests\Exporter\Element; + +use SMW\DIWikiPage; +use SMW\Exporter\Element\ExpElement; +use SMW\Exporter\Element\ExpNsResource; +use SMWDataItem as DataItem; +use SMW\Tests\PHPUnitCompat; + +/** + * @covers \SMW\Exporter\Element\ExpNsResource + * @group semantic-mediawiki + * + * @license GNU GPL v2+ + * @since 2.2 + * + * @author mwjames + */ +class ExpNsResourceTest extends \PHPUnit_Framework_TestCase { + + use PHPUnitCompat; + + public function testCanConstruct() { + + $this->assertInstanceOf( + '\SMW\Exporter\Element\ExpNsResource', + new ExpNsResource( '', '', '', null ) + ); + + // Legacy + $this->assertInstanceOf( + '\SMWExpNsResource', + new \SMWExpNsResource( '', '', '', null ) + ); + } + + /** + * @dataProvider constructorProvider + */ + public function testAccessToMethods( $localName, $namespace, $namespaceId, $dataItem ) { + + $instance = new ExpNsResource( + $localName, + $namespace, + $namespaceId, + $dataItem + ); + + $this->assertEquals( + $namespaceId . ':' . $localName, + $instance->getQName() + ); + + $this->assertEquals( + $namespace . $localName, + $instance->getUri() + ); + + $this->assertEquals( + $localName, + $instance->getLocalName() + ); + + $this->assertEquals( + $namespace, + $instance->getNamespace() + ); + + $this->assertEquals( + $namespaceId, + $instance->getNamespaceId() + ); + + $this->assertEquals( + $dataItem, + $instance->getDataItem() + ); + } + + /** + * @dataProvider constructorProvider + */ + public function testSerializiation( $localName, $namespace, $namespaceId, $dataItem, $expected ) { + + $instance = new ExpNsResource( + $localName, + $namespace, + $namespaceId, + $dataItem + ); + + $this->assertEquals( + $expected, + $instance->getSerialization() + ); + + $this->assertEquals( + $instance, + ExpElement::newFromSerialization( $instance->getSerialization() ) + ); + } + + /** + * @dataProvider invalidConstructorProvider + */ + public function testInvalidConstructorThrowsException( $localName, $namespace, $namespaceId, $dataItem ) { + + $this->setExpectedException( 'InvalidArgumentException' ); + + $instance = new ExpNsResource( + $localName, + $namespace, + $namespaceId, + $dataItem + ); + } + + /** + * @dataProvider serializationMissingElementProvider + */ + public function testDeserializiationForMissingElementThrowsException( $serialization ) { + + $this->setExpectedException( 'RuntimeException' ); + + ExpElement::newFromSerialization( + $serialization + ); + } + + public function constructorProvider() { + + #0 + $provider[] = [ + '', '', '', null, + [ + 'type' => ExpNsResource::TYPE_NSRESOURCE, + 'uri' => '||', + 'dataitem' => null + ] + ]; + + #1 + $provider[] = [ + 'Foo', '', '', null, + [ + 'type' => ExpNsResource::TYPE_NSRESOURCE, + 'uri' => 'Foo||', + 'dataitem' => null + ] + ]; + + #2 + $provider[] = [ + 'Foo', 'Bar', '', null, + [ + 'type' => ExpNsResource::TYPE_NSRESOURCE, + 'uri' => 'Foo|Bar|', + 'dataitem' => null + ] + ]; + + #3 + $provider[] = [ + 'Foo', 'Bar', 'Fum', null, + [ + 'type' => ExpNsResource::TYPE_NSRESOURCE, + 'uri' => 'Foo|Bar|Fum', + 'dataitem' => null + ] + ]; + + #4 + $provider[] = [ + 'Foo', 'Bar', 'Fum', new DIWikiPage( 'Foo', NS_MAIN ), + [ + 'type' => ExpNsResource::TYPE_NSRESOURCE, + 'uri' => 'Foo|Bar|Fum', + 'dataitem' => [ + 'type' => DataItem::TYPE_WIKIPAGE, + 'item' => 'Foo#0##' + ] + ] + ]; + + return $provider; + } + + public function invalidConstructorProvider() { + + #0 + $provider[] = [ + [], '', '', null + ]; + + #1 + $provider[] = [ + '', [], '', null + ]; + + #2 + $provider[] = [ + '', '', [], null + ]; + + return $provider; + } + + public function serializationMissingElementProvider() { + + #0 + $provider[] = [ + [] + ]; + + #1 + $provider[] = [ + [ + 'type' => ExpNsResource::TYPE_NSRESOURCE + ] + ]; + + #2 + $provider[] = [ + [ + 'type' => 'BogusType' + ] + ]; + + #3 + $provider[] = [ + [ + 'type' => ExpNsResource::TYPE_NSRESOURCE, + 'dataitem' => null + ] + ]; + + #4 + $provider[] = [ + [ + 'type' => ExpNsResource::TYPE_NSRESOURCE, + 'uri' => '', + 'dataitem' => null + ] + ]; + + #5 + $provider[] = [ + [ + 'type' => ExpNsResource::TYPE_NSRESOURCE, + 'uri' => '|', + 'dataitem' => null + ] + ]; + + return $provider; + } + +} |