قرینه از
https://github.com/matomo-org/matomo.git
synced 2025-08-25 00:17:37 +00:00

* [Coding Style] Enable rule PSR1.Methods.CamelCapsMethodName.NotCamelCaps * [Coding Style] Use camel case for method names in API plugin tests (#22145) * [Coding Style] Use camel case for method names in Core* plugin tests (#22147) * [Coding Style] Use camel case for method names in core Unit tests (#22149) * [Coding Style] Use camel case for method names in Actions and BulkTracking plugin tests (#22146) * [Coding Style] Use camel case for method names in CustomDimensions and CustomJSTracker plugin tests (#22148) * [Coding Style] Use camel case for method names in core Integration tests (#22151) * [Coding Style] Use camel case for method names in more core plugin tests (#22153) * [Coding Style] Use camel case for method names in more core plugin tests (#22157) * [Coding Style] Use camel case for method names in more core plugin tests * Update plugins/Monolog/tests/Unit/Processor/ExceptionToTextProcessorTest.php Co-authored-by: Michal Kleiner <michal@innocraft.com> --------- Co-authored-by: Michal Kleiner <michal@innocraft.com> * [Coding Style] Use camel case for method names in more core plugin tests (#22159) * [Coding Style] Use camel case for method names in remaining tests (#22160) * [Coding Style] Use camel case for method names in remaining tests * rename expected test files --------- Co-authored-by: Michal Kleiner <michal@innocraft.com>
131 خطوط
4.8 KiB
PHP
131 خطوط
4.8 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Matomo - free/libre analytics platform
|
|
*
|
|
* @link https://matomo.org
|
|
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
|
|
*/
|
|
|
|
namespace Piwik\Tests\Unit\Archive;
|
|
|
|
use Piwik\Archive\Chunk;
|
|
|
|
/**
|
|
* @group ChunkTest
|
|
* @group Archive
|
|
*/
|
|
class ChunkTest extends \PHPUnit\Framework\TestCase
|
|
{
|
|
/**
|
|
* @var Chunk
|
|
*/
|
|
private $chunk;
|
|
|
|
private $recordName = 'Actions_ActionsUrl';
|
|
|
|
public function setUp(): void
|
|
{
|
|
$this->chunk = new Chunk();
|
|
}
|
|
|
|
/**
|
|
* @dataProvider getRecordNameForTableIdDataProvider
|
|
*/
|
|
public function testGetRecordNameForTableIdShouldSplitChunksIntoBitsOf100($expectedChunk, $tableId)
|
|
{
|
|
$this->assertEquals($this->recordName . '_chunk_' . $expectedChunk, $this->chunk->getRecordNameForTableId($this->recordName, $tableId));
|
|
}
|
|
|
|
public function getRecordNameForTableIdDataProvider()
|
|
{
|
|
return array(
|
|
array($expectedChunk = '0_99', $tableId = 0),
|
|
array('0_99', 1),
|
|
array('0_99', 45),
|
|
array('0_99', 99),
|
|
array('100_199', 100),
|
|
array('100_199', 101),
|
|
array('100_199', 134),
|
|
array('100_199', 199),
|
|
array('200_299', 200),
|
|
array('1000_1099', 1000),
|
|
array('9900_9999', 9999),
|
|
array('10000_10099', 10000),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider isRecordNameAChunkDataProvider
|
|
*/
|
|
public function testIsRecordNameAChunkShouldSplitChunksIntoBitsOf100($isChunk, $recordName)
|
|
{
|
|
$this->assertSame($isChunk, $this->chunk->isRecordNameAChunk($recordName));
|
|
}
|
|
|
|
public function isRecordNameAChunkDataProvider()
|
|
{
|
|
return array(
|
|
array($isChunk = true, $recordName = 'Actions_ActionsUrl_chunk_0_99'),
|
|
array(true, 'Actions_ActionsUrl_chunk_100_199'),
|
|
array(true, 'Actions_ActionsUrl_chunk_1000_1099'),
|
|
array(false, 'Actions_ActionsUrl_chunk_0'), // it is no range, should contain something after "chunk_0" eg "chunk_0_99"
|
|
array(false, 'Actions_ActionsUrl_chunk_9999'),
|
|
array(false, 'Actions_ActionsUrl_chunk_4'),
|
|
array(false, 'Actions_ActionsUrl_chunk_ActionsTest_4'), // should end with _chunk_NUMERIC
|
|
array(false, 'Actions_ActionsUrl_chunk_4_ActionsTest'), // should end with _chunk_NUMERIC
|
|
array(false, 'Actions_ActionsUrl_chunk9999'),
|
|
array(false, 'Actions_ActionsUrlchunk_9999'),
|
|
array(false, 'chunk_9999'),
|
|
array(false, 'chunk_9999'),
|
|
);
|
|
}
|
|
|
|
public function testMoveArchiveBlobsIntoChunksNoChunksGiven()
|
|
{
|
|
$this->assertSame(array(), $this->chunk->moveArchiveBlobsIntoChunks($this->recordName, array()));
|
|
}
|
|
|
|
/**
|
|
* @dataProvider isRecordNameAChunkDataProvider
|
|
*/
|
|
public function testMoveArchiveBlobsIntoChunksShouldSplitBlobsIntoChunks()
|
|
{
|
|
$array = array_fill(0, 245, 'test');
|
|
$expected = array(
|
|
$this->recordName . '_chunk_0_99' => array_fill(0, Chunk::NUM_TABLES_IN_CHUNK, 'test'),
|
|
$this->recordName . '_chunk_100_199' => array_fill(100, Chunk::NUM_TABLES_IN_CHUNK, 'test'),
|
|
$this->recordName . '_chunk_200_299' => array_fill(200, 45, 'test'),
|
|
);
|
|
|
|
$this->assertSame($expected, $this->chunk->moveArchiveBlobsIntoChunks($this->recordName, $array));
|
|
}
|
|
|
|
/**
|
|
* @dataProvider getRecordNameWithoutChunkAppendixDataProvider
|
|
*/
|
|
public function testGetRecordNameWithoutChunkAppendixShouldSplitChunksIntoBitsOf100($realName, $recordName)
|
|
{
|
|
$this->assertSame($realName, $this->chunk->getRecordNameWithoutChunkAppendix($recordName));
|
|
}
|
|
|
|
public function getRecordNameWithoutChunkAppendixDataProvider()
|
|
{
|
|
return array(
|
|
array($isChunk = 'Actions_ActionsUrl', $recordName = 'Actions_ActionsUrl_chunk_0_99'),
|
|
array('Actions_ActionsUrl', 'Actions_ActionsUrl_chunk_9900_9999'),
|
|
array('Actions_ActionsUrl', 'Actions_ActionsUrl_chunk_400_499'),
|
|
// the following are not chunks so we do return the full record name
|
|
array('Actions_ActionsUrl_chunk_0', 'Actions_ActionsUrl_chunk_0'),
|
|
array('Actions_ActionsUrl_chunk_9999', 'Actions_ActionsUrl_chunk_9999'),
|
|
array('Actions_ActionsUrl_chunk_4', 'Actions_ActionsUrl_chunk_4'),
|
|
array('Actions_ActionsUrl_chunk_ActionsTest_4', 'Actions_ActionsUrl_chunk_ActionsTest_4'),
|
|
array('Actions_ActionsUrl_chunk_4_ActionsTest', 'Actions_ActionsUrl_chunk_4_ActionsTest'),
|
|
array('Actions_ActionsUrl_chunk9999', 'Actions_ActionsUrl_chunk9999'),
|
|
array('Actions_ActionsUrlchunk_9999', 'Actions_ActionsUrlchunk_9999'),
|
|
array('chunk_9999', 'chunk_9999'),
|
|
array('chunk_9999', 'chunk_9999'),
|
|
);
|
|
}
|
|
}
|