ExcelReaderTest::testMultiSheet()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 9
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 9
rs 9.6666
c 0
b 0
f 0
cc 1
eloc 6
nc 1
nop 0
1
<?php
2
3
namespace Ddeboer\DataImport\Tests\Reader;
4
5
use Ddeboer\DataImport\Reader\ExcelReader;
6
7
class ExcelReaderTest extends \PHPUnit_Framework_TestCase
8
{
9
    public function setUp()
10
    {
11
        if (!extension_loaded('zip')) {
12
            $this->markTestSkipped();
13
        }
14
    }
15
16
    public function testGetFields()
17
    {
18
        $file = new \SplFileObject(__DIR__.'/../Fixtures/data_column_headers.xlsx');
19
        $reader = new ExcelReader($file, 0);
20
        $this->assertEquals(array('id', 'number', 'description'), $reader->getFields());
21
        $this->assertEquals(array('id', 'number', 'description'), $reader->getColumnHeaders());
22
    }
23
24
    public function testCountWithoutHeaders()
25
    {
26
        $file = new \SplFileObject(__DIR__.'/../Fixtures/data_no_column_headers.xls');
27
        $reader = new ExcelReader($file);
28
        $this->assertEquals(3, $reader->count());
29
    }
30
31
    public function testCountWithHeaders()
32
    {
33
        $file = new \SplFileObject(__DIR__.'/../Fixtures/data_column_headers.xlsx');
34
        $reader = new ExcelReader($file, 0);
35
        $this->assertEquals(3, $reader->count());
36
    }
37
38
    public function testIterate()
39
    {
40
        $file = new \SplFileObject(__DIR__.'/../Fixtures/data_column_headers.xlsx');
41
        $reader = new ExcelReader($file, 0);
42
        foreach ($reader as $row) {
43
            $this->assertInternalType('array', $row);
44
            $this->assertEquals(array('id', 'number', 'description'), array_keys($row));
45
        }
46
    }
47
48
    public function testMultiSheet()
49
    {
50
        $file = new \SplFileObject(__DIR__.'/../Fixtures/data_multi_sheet.xls');
51
        $sheet1reader = new ExcelReader($file, null, 0);
52
        $this->assertEquals(3, $sheet1reader->count());
53
54
        $sheet2reader = new ExcelReader($file, null, 1);
55
        $this->assertEquals(2, $sheet2reader->count());
56
    }
57
}
58