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

UsosCfdi   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 43
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 26
c 1
b 0
f 0
dl 0
loc 43
ccs 17
cts 17
cp 1
rs 10
wmc 4

2 Methods

Rating   Name   Duplication   Size   Complexity  
A checkHeaders() 0 28 3
A dataTable() 0 10 1
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\BoolDataField;
9
use PhpCfdi\SatCatalogosPopulate\Database\DataFields;
10
use PhpCfdi\SatCatalogosPopulate\Database\DataTable;
11
use PhpCfdi\SatCatalogosPopulate\Database\DateDataField;
12
use PhpCfdi\SatCatalogosPopulate\Database\TextDataField;
13
use PhpCfdi\SatCatalogosPopulate\InjectorInterface;
14
use PhpCfdi\SatCatalogosPopulate\Utils\CsvFile;
15
use RuntimeException;
16
17
use function PhpCfdi\SatCatalogosPopulate\Utils\array_rtrim;
18
19
class UsosCfdi extends AbstractCsvInjector implements InjectorInterface
20
{
21 3
    public function checkHeaders(CsvFile $csv): void
22
    {
23 3
        $csv->move(3);
24 3
        $expectedLines = [
25
            [
26
                'c_UsoCFDI',
27
                'Descripción',
28
                'Aplica para tipo persona',
29
                '',
30
                'Fecha inicio de vigencia',
31
                'Fecha fin de vigencia',
32
                'Regímen Fiscal Receptor',
33
            ],
34
            [
35
                '',
36
                '',
37
                'Física',
38
                'Moral',
39
            ],
40
        ];
41
42 3
        foreach ($expectedLines as $expected) {
43 3
            $headers = array_rtrim($csv->readLine());
44
45 3
            if ($expected !== $headers) {
46 1
                throw new RuntimeException("The headers did not match on file {$this->sourceFile()}");
47
            }
48 2
            $csv->next();
49
        }
50
    }
51
52 8
    public function dataTable(): DataTable
53
    {
54 8
        return new DataTable('cfdi_40_usos_cfdi', new DataFields([
55 8
            new TextDataField('id'),
56 8
            new TextDataField('texto'),
57 8
            new BoolDataField('aplica_fisica', ['Sí']),
58 8
            new BoolDataField('aplica_moral', ['Sí']),
59 8
            new DateDataField('vigencia_desde'),
60 8
            new DateDataField('vigencia_hasta'),
61 8
            new TextDataField('regimenes_fiscales_receptores'), // TODO: use CsvListDataField
62
        ]));
63
    }
64
}
65