Codebase list pyexcel-ods / a6cdbbc tests / base.py
a6cdbbc

Tree @a6cdbbc (Download .tar.gz)

base.py @a6cdbbcraw · history · blame

import os  # noqa
import datetime  # noqa

import pyexcel

from nose.tools import eq_, raises  # noqa


def create_sample_file1(file):
    data = ["a", "b", "c", "d", "e", "f", "g", "h", "i", "j", 1.1, 1]
    table = []
    table.append(data[:4])
    table.append(data[4:8])
    table.append(data[8:12])
    pyexcel.save_as(array=table, dest_file_name=file)


class PyexcelHatWriterBase:
    """
    Abstract functional test for hat writers
    """

    content = {
        "X": [1, 2, 3, 4, 5],
        "Y": [6, 7, 8, 9, 10],
        "Z": [11, 12, 13, 14, 15],
    }

    def test_series_table(self):
        pyexcel.save_as(adict=self.content, dest_file_name=self.testfile)
        r = pyexcel.get_sheet(file_name=self.testfile, name_columns_by_row=0)
        eq_(r.dict, self.content)


class PyexcelWriterBase:
    """
    Abstract functional test for writers

    testfile and testfile2 have to be initialized before
    it is used for testing
    """

    content = [
        [1, 2, 3, 4, 5],
        [1, 2, 3, 4, 5],
        [1, 2, 3, 4, 5],
        [1, 2, 3, 4, 5],
    ]

    def _create_a_file(self, file):
        pyexcel.save_as(dest_file_name=file, array=self.content)

    def test_write_array(self):
        self._create_a_file(self.testfile)
        r = pyexcel.get_sheet(file_name=self.testfile)
        actual = list(r.rows())
        assert actual == self.content


class PyexcelMultipleSheetBase:
    def _write_test_file(self, filename):
        pyexcel.save_book_as(bookdict=self.content, dest_file_name=filename)

    def _clean_up(self):
        if os.path.exists(self.testfile2):
            os.unlink(self.testfile2)
        if os.path.exists(self.testfile):
            os.unlink(self.testfile)

    def test_sheet_names(self):
        r = pyexcel.BookReader(self.testfile)
        expected = ["Sheet1", "Sheet2", "Sheet3"]
        sheet_names = r.sheet_names()
        for name in sheet_names:
            assert name in expected

    def test_reading_through_sheets(self):
        b = pyexcel.BookReader(self.testfile)
        data = list(b["Sheet1"].rows())
        expected = [[1, 1, 1, 1], [2, 2, 2, 2], [3, 3, 3, 3]]
        assert data == expected
        data = list(b["Sheet2"].rows())
        expected = [[4, 4, 4, 4], [5, 5, 5, 5], [6, 6, 6, 6]]
        assert data == expected
        data = list(b["Sheet3"].rows())
        expected = [[u"X", u"Y", u"Z"], [1, 4, 7], [2, 5, 8], [3, 6, 9]]
        assert data == expected
        sheet3 = b["Sheet3"]
        sheet3.name_columns_by_row(0)
        data = list(b["Sheet3"].rows())
        expected = [[1, 4, 7], [2, 5, 8], [3, 6, 9]]
        assert data == expected


class ODSCellTypes:
    def test_formats(self):
        # date formats
        date_format = "%d/%m/%Y"
        eq_(self.data["Sheet1"][0][0], "Date")
        eq_(self.data["Sheet1"][1][0].strftime(date_format), "11/11/2014")
        eq_(self.data["Sheet1"][2][0].strftime(date_format), "01/01/2001")
        eq_(self.data["Sheet1"][3][0], "")
        # time formats
        time_format = "%S:%M:%H"
        eq_(self.data["Sheet1"][0][1], "Time")
        eq_(self.data["Sheet1"][1][1].strftime(time_format), "12:12:11")
        eq_(self.data["Sheet1"][2][1].strftime(time_format), "12:00:00")
        eq_(self.data["Sheet1"][3][1], 0)
        eq_(
            self.data["Sheet1"][4][1],
            datetime.timedelta(hours=27, minutes=17, seconds=54),
        )
        eq_(self.data["Sheet1"][5][1], "Other")
        # boolean
        eq_(self.data["Sheet1"][0][2], "Boolean")
        eq_(self.data["Sheet1"][1][2], True)
        eq_(self.data["Sheet1"][2][2], False)
        # Float
        eq_(self.data["Sheet1"][0][3], "Float")
        eq_(self.data["Sheet1"][1][3], 11.11)
        # Currency
        eq_(self.data["Sheet1"][0][4], "Currency")
        eq_(self.data["Sheet1"][1][4], "1 GBP")
        eq_(self.data["Sheet1"][2][4], "-10000 GBP")
        # Percentage
        eq_(self.data["Sheet1"][0][5], "Percentage")
        eq_(self.data["Sheet1"][1][5], 2)
        # int
        eq_(self.data["Sheet1"][0][6], "Int")
        eq_(self.data["Sheet1"][1][6], 3)
        eq_(self.data["Sheet1"][4][6], 11)
        # Scientifed not supported
        eq_(self.data["Sheet1"][1][7], 100000)
        # Fraction
        eq_(self.data["Sheet1"][1][8], 1.25)
        # Text
        eq_(self.data["Sheet1"][1][9], "abc")

        @raises(IndexError)
        def test_no_excessive_trailing_columns(self):
            eq_(self.data["Sheet1"][2][6], "")