Passed
Push — master ( c090bb...e5cdcf )
by Carlos C
01:54 queued 12s
created

Exportaciones   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 22
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 12
c 1
b 0
f 0
dl 0
loc 22
ccs 13
cts 13
cp 1
rs 10
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A dataTable() 0 7 1
A checkHeaders() 0 11 2
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpCfdi\SatCatalogosPopulate\Importers\Cfdi40\Injectors;
6
7
use PhpCfdi\SatCatalogosPopulate\AbstractCsvInjector;
8
use PhpCfdi\SatCatalogosPopulate\Database\DataFields;
9
use PhpCfdi\SatCatalogosPopulate\Database\DataTable;
10
use PhpCfdi\SatCatalogosPopulate\Database\DateDataField;
11
use PhpCfdi\SatCatalogosPopulate\Database\PaddingDataField;
12
use PhpCfdi\SatCatalogosPopulate\Database\TextDataField;
13
use PhpCfdi\SatCatalogosPopulate\Utils\CsvFile;
14
use RuntimeException;
15
16
class Exportaciones extends AbstractCsvInjector
17
{
18 3
    public function checkHeaders(CsvFile $csv): void
19
    {
20 3
        $csv->move(3);
21 3
        $expected = ['c_Exportacion', 'Descripción', 'Fecha inicio de vigencia', 'Fecha fin de vigencia'];
22 3
        $headers = $csv->readLine();
23
24 3
        if ($expected !== $headers) {
25 1
            throw new RuntimeException("The headers did not match on file {$this->sourceFile()}");
26
        }
27
28 2
        $csv->next();
29
    }
30
31 2
    public function dataTable(): DataTable
32
    {
33 2
        return new DataTable('cfdi_40_exportaciones', new DataFields([
34 2
            new PaddingDataField('id', '0', 2),
35 2
            new TextDataField('texto'),
36 2
            new DateDataField('vigencia_desde'),
37 2
            new DateDataField('vigencia_hasta'),
38
        ]));
39
    }
40
}
41