Ejemplo n.º 1
0
    def test_raise_exception_if_field_names_and_types_are_not_present(self):
        contents = dedent('''
        only\tfield\tnames
        ''').strip()
        with self.assertRaises(ValueError):
            parse(contents)

        contents = dedent('''
        field\tnames
        wrong\ttypes
        ''').strip()
        with self.assertRaises(ValueError):
            parse(contents)
Ejemplo n.º 2
0
 def test_comments_should_be_ignored(self):
     contents = dedent('''
     #this file is about something
     a\tb\tc\td\te
     int\tint\tint\tstring\tstring
     123\t456\t789\tq\tw
     #2\t5\t8\tq\tw
     3\t6\t7\t#e\t#r
     ''').strip()
     expected = [
         {
             'a': 123,
             'b': 456,
             'c': 789,
             'd': 'q',
             'e': 'w'
         },
         {
             'a': 3,
             'b': 6,
             'c': 7,
             'd': '#e',
             'e': '#r'
         },
     ]
     result = parse(contents)
     self.assertEqual(result, expected)
Ejemplo n.º 3
0
    def test_empty_lines_should_be_ignored(self):
        contents = dedent('''
        a\tb\tc\td\te
        int\tint\tint\tint\tint
        123\t456\t789\t0\t-1


        -1\t0\t789\t456\t123
        ''').strip() + '\n'
        expected = [
            {
                'a': 123,
                'b': 456,
                'c': 789,
                'd': 0,
                'e': -1
            },
            {
                'a': -1,
                'b': 0,
                'c': 789,
                'd': 456,
                'e': 123
            },
        ]
        result = parse(contents)
        self.assertEqual(result, expected)
Ejemplo n.º 4
0
 def test_normal_records(self):
     contents = dedent('''
     a\tb\tc\td\te
     int\tint\tint\tint\tint
     123\t456\t789\t0\t-1
     -1\t0\t789\t456\t123
     ''').strip()
     expected = [
         {
             'a': 123,
             'b': 456,
             'c': 789,
             'd': 0,
             'e': -1
         },
         {
             'a': -1,
             'b': 0,
             'c': 789,
             'd': 456,
             'e': 123
         },
     ]
     result = parse(contents)
     self.assertEqual(result, expected)
Ejemplo n.º 5
0
 def test_escape_sequences(self):
     backslash = '\\\\'
     tab = '\\t'
     newline = '\\n'
     null = '\\N'
     contents = dedent('''
     a\tb\tc\td\te
     string\tstring\tstring\tstring\tstring
     #a\tb\tc\td\te
     {}\t{}\t{}\t{}\tz
     \#a\tb\tc\td\te
     '''.format(backslash, tab, newline, null)).strip()
     expected = [{
         'a': '\\',
         'b': '\t',
         'c': '\n',
         'd': None,
         'e': 'z'
     }, {
         'a': '#a',
         'b': 'b',
         'c': 'c',
         'd': 'd',
         'e': 'e'
     }]
     result = parse(contents)
     self.assertEqual(result, expected)
Ejemplo n.º 6
0
 def test_no_records(self):
     contents = dedent('''
     a\tb\tc\td\te
     int\tint\tint\tint\tint
     ''').strip()
     expected = []
     result = parse(contents)
     self.assertEqual(result, expected)
Ejemplo n.º 7
0
 def test_normal_records(self):
     contents = dedent('''
     123\t456\t789\t0\t-1
     -1\t0\t789\t456\t123
     ''').strip()
     expected = [
         ['123', '456', '789', '0',   '-1'],
         ['-1',  '0',   '789', '456', '123'],
     ]
     result = parse(contents)
     self.assertEqual(result, expected)
Ejemplo n.º 8
0
 def test_normal_records(self):
     contents = dedent('''
     123\t456\t789\t0\t-1
     -1\t0\t789\t456\t123
     ''').strip()
     expected = [
         ['123', '456', '789', '0', '-1'],
         ['-1', '0', '789', '456', '123'],
     ]
     result = parse(contents)
     self.assertEqual(result, expected)
Ejemplo n.º 9
0
    def test_empty_lines(self):
        contents = dedent('''
        123\t456\t789\t0\t-1


        -1\t0\t789\t456\t123
        ''').strip() + '\n'
        expected = [
            ['123', '456', '789', '0',   '-1'],
            ['-1',  '0',   '789', '456', '123'],
        ]
        result = parse(contents)
        self.assertEqual(result, expected)
Ejemplo n.º 10
0
    def test_empty_lines(self):
        contents = dedent('''
        123\t456\t789\t0\t-1


        -1\t0\t789\t456\t123
        ''').strip() + '\n'
        expected = [
            ['123', '456', '789', '0', '-1'],
            ['-1', '0', '789', '456', '123'],
        ]
        result = parse(contents)
        self.assertEqual(result, expected)
Ejemplo n.º 11
0
 def test_escape_sequences(self):
     backslash = '\\\\'
     tab = '\\t'
     newline = '\\n'
     carriage_return = '\\r'
     null = '\\N'
     contents = dedent('''
     {}\t{}\t{}\t{}\t{}\tz
     \#a\tb\tc\td\te\tf
     '''.format(backslash, tab, newline, carriage_return, null)).strip()
     expected = [
         ['\\', '\t', '\n', '\r', None, 'z'],
         ['#a', 'b',  'c',  'd',  'e', 'f'],
     ]
     result = parse(contents)
     self.assertEqual(result, expected)
Ejemplo n.º 12
0
 def test_escape_sequences(self):
     backslash = '\\\\'
     tab = '\\t'
     newline = '\\n'
     carriage_return = '\\r'
     null = '\\N'
     contents = dedent('''
     {}\t{}\t{}\t{}\t{}\tz
     \#a\tb\tc\td\te\tf
     '''.format(backslash, tab, newline, carriage_return, null)).strip()
     expected = [
         ['\\', '\t', '\n', '\r', None, 'z'],
         ['#a', 'b', 'c', 'd', 'e', 'f'],
     ]
     result = parse(contents)
     self.assertEqual(result, expected)
Ejemplo n.º 13
0
    def test_type_converters(self):
        contents = dedent(u'''
        b\ti\tf\td\tdt\ts
        bool\tint\tfloat\tdate\tdatetime\tstring

        \\N\t\\N\t\\N\t\\N\t\\N
        true\t42\t6.28\t2014-04-29\t1987-04-29T03:02:00-03:00\tÁlvaro's bday
        false\t42\t6.28\t2014-04-29\t1987-04-29T03:02:00-03:00\tÁlvaro's bday
        ''').strip()
        field_names = ('b', 'i', 'f', 'd', 'dt', 's')

        class UTC_less_3(datetime.tzinfo):
            def utcoffset(self, dt):
                return datetime.timedelta(hours=-3)

            def tzname(self, dt):
                return '-03:00'

        sample_date = datetime.date(2014, 4, 29)
        sample_datetime = datetime.datetime(1987,
                                            4,
                                            29,
                                            3,
                                            2,
                                            0,
                                            tzinfo=UTC_less_3())

        rows = parse(contents)
        self.assertEqual(len(rows), 3)

        none_row = [None, None, None, None, None]
        self.assertEqual(rows[0], dict(zip(field_names, none_row)))

        expected_row = [
            True, 42, 6.28, sample_date, sample_datetime, u"Álvaro's bday"
        ]
        self.assertEqual(rows[1], dict(zip(field_names, expected_row)))

        expected_row[0] = False
        self.assertEqual(rows[2], dict(zip(field_names, expected_row)))