createNoOpMock() method for PHPUnit tests
[lhc/web/wiklou.git] / tests / phpunit / unit / includes / filebackend / lockmanager / LockManagerGroupFactoryTest.php
1 <?php
2
3 use MediaWiki\FileBackend\LockManager\LockManagerGroupFactory;
4 use Wikimedia\Rdbms\LBFactory;
5
6 /**
7 * @covers MediaWiki\FileBackend\LockManager\LockManagerGroupFactory
8 * @todo Should we somehow test that the LockManagerGroup objects are as we expect? How do we do
9 * that without getting into testing LockManagerGroup itself?
10 */
11 class LockManagerGroupFactoryTest extends MediaWikiUnitTestCase {
12 public function testGetLockManagerGroup() {
13 $mockLbFactory = $this->createNoOpMock( LBFactory::class );
14
15 $factory = new LockManagerGroupFactory( 'defaultDomain', [], $mockLbFactory );
16 $lbmUnspecified = $factory->getLockManagerGroup();
17 $lbmFalse = $factory->getLockManagerGroup( false );
18 $lbmDefault = $factory->getLockManagerGroup( 'defaultDomain' );
19 $lbmOther = $factory->getLockManagerGroup( 'otherDomain' );
20
21 $this->assertSame( $lbmUnspecified, $lbmFalse );
22 $this->assertSame( $lbmFalse, $lbmDefault );
23 $this->assertSame( $lbmDefault, $lbmUnspecified );
24 $this->assertNotEquals( $lbmUnspecified, $lbmOther );
25 $this->assertNotEquals( $lbmFalse, $lbmOther );
26 $this->assertNotEquals( $lbmDefault, $lbmOther );
27
28 $this->assertSame( $lbmUnspecified, $factory->getLockManagerGroup() );
29 $this->assertSame( $lbmFalse, $factory->getLockManagerGroup( false ) );
30 $this->assertSame( $lbmDefault, $factory->getLockManagerGroup( 'defaultDomain' ) );
31 $this->assertSame( $lbmOther, $factory->getLockManagerGroup( 'otherDomain' ) );
32 }
33 }