diff options
Diffstat (limited to 'www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/SQLStore/PropertyTableIdReferenceFinderTest.php')
-rw-r--r-- | www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/SQLStore/PropertyTableIdReferenceFinderTest.php | 209 |
1 files changed, 209 insertions, 0 deletions
diff --git a/www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/SQLStore/PropertyTableIdReferenceFinderTest.php b/www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/SQLStore/PropertyTableIdReferenceFinderTest.php new file mode 100644 index 00000000..6a5fa782 --- /dev/null +++ b/www/wiki/extensions/SemanticMediaWiki/tests/phpunit/Unit/SQLStore/PropertyTableIdReferenceFinderTest.php @@ -0,0 +1,209 @@ +<?php + +namespace SMW\Tests\SQLStore; + +use SMW\DIProperty; +use SMW\SQLStore\PropertyTableIdReferenceFinder; +use SMW\SQLStore\SQLStore; + +/** + * @covers \SMW\SQLStore\PropertyTableIdReferenceFinder + * @group semantic-mediawiki + * + * @license GNU GPL v2+ + * @since 2.4 + * + * @author mwjames + */ +class PropertyTableIdReferenceFinderTest extends \PHPUnit_Framework_TestCase { + + private $store; + + protected function setUp() { + parent::setUp(); + + $this->store = $this->getMockBuilder( '\SMW\SQLStore\SQLStore' ) + ->disableOriginalConstructor() + ->getMock(); + } + + public function testCanConstruct() { + + $this->assertInstanceOf( + '\SMW\SQLStore\PropertyTableIdReferenceFinder', + new PropertyTableIdReferenceFinder( $this->store ) + ); + } + + public function testFindAtLeastOneActiveReferenceById() { + + $tableDefinition = $this->getMockBuilder( '\SMW\SQLStore\TableDefinition' ) + ->disableOriginalConstructor() + ->getMock(); + + $tableDefinition->expects( $this->atLeastOnce() ) + ->method( 'getFields' ) + ->will( $this->returnValue( [ 'o_id' => 42 ] ) ); + + $connection = $this->getMockBuilder( '\SMW\MediaWiki\Database' ) + ->disableOriginalConstructor() + ->getMock(); + + $connection->expects( $this->any() ) + ->method( 'selectRow' ) + ->will( $this->returnValue( false ) ); + + $this->store->expects( $this->any() ) + ->method( 'getConnection' ) + ->will( $this->returnValue( $connection ) ); + + $this->store->expects( $this->any() ) + ->method( 'getPropertyTables' ) + ->will( $this->returnValue( [ $tableDefinition ] ) ); + + $instance = new PropertyTableIdReferenceFinder( + $this->store + ); + + $this->assertFalse( + $instance->findAtLeastOneActiveReferenceById( 42 ) + ); + } + + public function testTryToFindAtLeastOneReferenceForProperty() { + + $idTable = $this->getMockBuilder( '\SMWSql3SmwIds' ) + ->disableOriginalConstructor() + ->getMock(); + + $tableDefinition = $connection = $this->getMockBuilder( '\SMW\SQLStore\TableDefinition' ) + ->disableOriginalConstructor() + ->getMock(); + + $tableDefinition->expects( $this->once() ) + ->method( 'usesIdSubject' ) + ->will( $this->returnValue( true ) ); + + $connection = $this->getMockBuilder( '\SMW\MediaWiki\Database' ) + ->disableOriginalConstructor() + ->getMock(); + + $connection->expects( $this->any() ) + ->method( 'selectRow' ) + ->will( $this->returnValue( false ) ); + + $this->store->expects( $this->any() ) + ->method( 'getConnection' ) + ->will( $this->returnValue( $connection ) ); + + $this->store->expects( $this->any() ) + ->method( 'getObjectIds' ) + ->will( $this->returnValue( $idTable ) ); + + $this->store->expects( $this->any() ) + ->method( 'getPropertyTables' ) + ->will( $this->returnValue( [ $tableDefinition ] ) ); + + $instance = new PropertyTableIdReferenceFinder( + $this->store + ); + + $instance->tryToFindAtLeastOneReferenceForProperty( new DIProperty( 'Foo' ) ); + } + + public function testHasResidualPropertyTableReference() { + + $connection = $this->getMockBuilder( '\SMW\MediaWiki\Database' ) + ->disableOriginalConstructor() + ->getMock(); + + $connection->expects( $this->any() ) + ->method( 'selectRow' ) + ->will( $this->returnValue( false ) ); + + $this->store->expects( $this->any() ) + ->method( 'getConnection' ) + ->will( $this->returnValue( $connection ) ); + + $this->store->expects( $this->any() ) + ->method( 'getPropertyTables' ) + ->will( $this->returnValue( [] ) ); + + $instance = new PropertyTableIdReferenceFinder( + $this->store + ); + + $this->assertInternalType( + 'boolean', + $instance->hasResidualPropertyTableReference( 42 ) + ); + } + + public function testHasResidualReferenceFor() { + + $connection = $this->getMockBuilder( '\SMW\MediaWiki\Database' ) + ->disableOriginalConstructor() + ->getMock(); + + $connection->expects( $this->any() ) + ->method( 'selectRow' ) + ->will( $this->returnValue( false ) ); + + $this->store->expects( $this->any() ) + ->method( 'getConnection' ) + ->will( $this->returnValue( $connection ) ); + + $this->store->expects( $this->any() ) + ->method( 'getPropertyTables' ) + ->will( $this->returnValue( [] ) ); + + $instance = new PropertyTableIdReferenceFinder( + $this->store + ); + + $this->assertInternalType( + 'boolean', + $instance->hasResidualReferenceForId( 42 ) + ); + } + + public function testSearchAllTablesToFindAtLeastOneReferenceById() { + + $connection = $this->getMockBuilder( '\SMW\MediaWiki\Database' ) + ->disableOriginalConstructor() + ->getMock(); + + $connection->expects( $this->any() ) + ->method( 'selectRow' ) + ->will( $this->returnValue( false ) ); + + $this->store->expects( $this->any() ) + ->method( 'getConnection' ) + ->will( $this->returnValue( $connection ) ); + + $this->store->expects( $this->any() ) + ->method( 'getPropertyTables' ) + ->will( $this->returnValue( [] ) ); + + $instance = new PropertyTableIdReferenceFinder( + $this->store + ); + + $this->assertInternalType( + 'array', + $instance->searchAllTablesToFindAtLeastOneReferenceById( 42 ) + ); + } + + public function testConfirmBorderId() { + + $instance = new PropertyTableIdReferenceFinder( + $this->store + ); + + $this->assertTrue( + $instance->hasResidualReferenceForId( SQLStore::FIXED_PROPERTY_ID_UPPERBOUND ) + ); + } + +} |