2016-07-16 23:29:40 +02:00
|
|
|
<?php
|
|
|
|
|
2016-11-20 22:53:17 +01:00
|
|
|
declare(strict_types=1);
|
2016-07-16 23:29:40 +02:00
|
|
|
|
|
|
|
namespace tests\Phpml\Dataset;
|
|
|
|
|
|
|
|
use Phpml\Dataset\FilesDataset;
|
2017-02-03 12:58:25 +01:00
|
|
|
use PHPUnit\Framework\TestCase;
|
2016-07-16 23:29:40 +02:00
|
|
|
|
2017-02-03 12:58:25 +01:00
|
|
|
class FilesDatasetTest extends TestCase
|
2016-07-16 23:29:40 +02:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @expectedException \Phpml\Exception\DatasetException
|
|
|
|
*/
|
2017-11-14 21:21:23 +01:00
|
|
|
public function testThrowExceptionOnMissingRootFolder(): void
|
2016-07-16 23:29:40 +02:00
|
|
|
{
|
|
|
|
new FilesDataset('some/not/existed/path');
|
|
|
|
}
|
|
|
|
|
2017-11-14 21:21:23 +01:00
|
|
|
public function testLoadFilesDatasetWithBBCData(): void
|
2016-07-16 23:29:40 +02:00
|
|
|
{
|
|
|
|
$rootPath = dirname(__FILE__).'/Resources/bbc';
|
|
|
|
|
|
|
|
$dataset = new FilesDataset($rootPath);
|
|
|
|
|
2016-12-12 19:31:30 +01:00
|
|
|
$this->assertCount(50, $dataset->getSamples());
|
|
|
|
$this->assertCount(50, $dataset->getTargets());
|
2016-07-16 23:29:40 +02:00
|
|
|
|
|
|
|
$targets = ['business', 'entertainment', 'politics', 'sport', 'tech'];
|
|
|
|
$this->assertEquals($targets, array_values(array_unique($dataset->getTargets())));
|
|
|
|
|
|
|
|
$firstSample = file_get_contents($rootPath.'/business/001.txt');
|
|
|
|
$this->assertEquals($firstSample, $dataset->getSamples()[0][0]);
|
|
|
|
|
2016-07-16 23:56:52 +02:00
|
|
|
$firstTarget = 'business';
|
|
|
|
$this->assertEquals($firstTarget, $dataset->getTargets()[0]);
|
|
|
|
|
2016-07-16 23:29:40 +02:00
|
|
|
$lastSample = file_get_contents($rootPath.'/tech/010.txt');
|
|
|
|
$this->assertEquals($lastSample, $dataset->getSamples()[49][0]);
|
2016-07-16 23:56:52 +02:00
|
|
|
|
|
|
|
$lastTarget = 'tech';
|
|
|
|
$this->assertEquals($lastTarget, $dataset->getTargets()[49]);
|
2016-07-16 23:29:40 +02:00
|
|
|
}
|
|
|
|
}
|