wiki.techinc.nl/tests/phpunit/includes/libs/stats/PrefixingStatsdDataFactoryProxyTest.php
Max Semenik fb06e4cd85 Update tests to use PHPUnit 6 class names
Bug: T192167
Change-Id: I42b0c8908b4968b95b08f861a40af18dc79fa0a1
2019-10-06 01:01:28 -07:00

57 lines
1.6 KiB
PHP

<?php
use Liuggio\StatsdClient\Factory\StatsdDataFactoryInterface;
use PHPUnit\Framework\MockObject\MockObject;
/**
* @covers PrefixingStatsdDataFactoryProxy
*/
class PrefixingStatsdDataFactoryProxyTest extends PHPUnit\Framework\TestCase {
public function provideMethodNames() {
return [
[ 'timing' ],
[ 'gauge' ],
[ 'set' ],
[ 'increment' ],
[ 'decrement' ],
[ 'updateCount' ],
[ 'produceStatsdData' ],
];
}
/**
* @dataProvider provideMethodNames
*/
public function testPrefixingAndPassthrough( $method ) {
/** @var StatsdDataFactoryInterface|MockObject $innerFactory */
$innerFactory = $this->createMock(
\Liuggio\StatsdClient\Factory\StatsdDataFactoryInterface::class
);
$innerFactory->expects( $this->once() )
->method( $method )
->with( 'testprefix.metricname' );
$proxy = new PrefixingStatsdDataFactoryProxy( $innerFactory, 'testprefix' );
// 1,2,3,4 simply makes sure we provide enough parameters, without caring what they are
$proxy->$method( 'metricname', 1, 2, 3, 4 );
}
/**
* @dataProvider provideMethodNames
*/
public function testPrefixIsTrimmed( $method ) {
/** @var StatsdDataFactoryInterface|MockObject $innerFactory */
$innerFactory = $this->createMock(
\Liuggio\StatsdClient\Factory\StatsdDataFactoryInterface::class
);
$innerFactory->expects( $this->once() )
->method( $method )
->with( 'testprefix.metricname' );
$proxy = new PrefixingStatsdDataFactoryProxy( $innerFactory, 'testprefix...' );
// 1,2,3,4 simply makes sure we provide enough parameters, without caring what they are
$proxy->$method( 'metricname', 1, 2, 3, 4 );
}
}