1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121
|
import pickle
import unittest
from decimal import Decimal
from agate import Table
from agate.data_types import Number, Text
class TestColumn(unittest.TestCase):
def setUp(self):
self.rows = (
(1, 2, 'a'),
(2, 3, 'b'),
(None, 4, 'c')
)
self.number_type = Number()
self.text_type = Text()
self.column_names = ['one', 'two', 'three']
self.column_types = [self.number_type, self.number_type, self.text_type]
self.table = Table(self.rows, self.column_names, self.column_types)
def test_index(self):
self.assertEqual(self.table.columns['one'].index, 0)
self.assertEqual(self.table.columns['two'].index, 1)
self.assertEqual(self.table.columns['three'].index, 2)
def test_name(self):
self.assertEqual(self.table.columns['one'].name, 'one')
def test_data_type(self):
self.assertIs(self.table.columns['one'].data_type, self.number_type)
def test_pickleable(self):
pickle.dumps(self.table.columns['one'])
def test_row_names(self):
table = Table(self.rows, self.column_names, self.column_types, row_names='three')
column = table.columns['one']
self.assertSequenceEqual(column._keys, ['a', 'b', 'c'])
self.assertEqual(column['b'], 2)
def test_keys(self):
table = Table(self.rows, self.column_names, self.column_types, row_names='three')
self.assertIs(self.table.columns['one'].keys(), None)
self.assertSequenceEqual(table.columns['one'].keys(), ['a', 'b', 'c'])
def test_values(self):
self.assertSequenceEqual(
self.table.columns['one'].values(),
[Decimal('1'), Decimal('2'), None]
)
def test_values_distinct(self):
rows = (
(1, 2),
(2, 3),
(None, 3)
)
table = Table(rows, ('one', 'two'), [self.number_type, self.number_type])
self.assertSequenceEqual(
table.columns['two'].values_distinct(),
[Decimal('2'), Decimal('3')]
)
def test_items(self):
table = Table(self.rows, self.column_names, self.column_types, row_names='three')
self.assertSequenceEqual(table.columns['one'].items(), [
('a', Decimal('1')),
('b', Decimal('2')),
('c', None)
])
def test_dict(self):
table = Table(self.rows, self.column_names, self.column_types, row_names='three')
self.assertDictEqual(table.columns['one'].dict(), {
'a': Decimal('1'),
'b': Decimal('2'),
'c': None
})
def test_values_without_nulls(self):
self.assertSequenceEqual(
self.table.columns['one'].values_without_nulls(),
[Decimal('1'), Decimal('2')]
)
def test_values_sorted(self):
rows = (
(2, 2, 'a'),
(None, 3, 'b'),
(1, 4, 'c')
)
table = Table(rows, self.column_names, self.column_types)
self.assertSequenceEqual(
table.columns['one'].values_sorted(),
[Decimal('1'), Decimal('2'), None]
)
def test_values_without_nulls_sorted(self):
rows = (
(2, 2, 'a'),
(None, 3, 'b'),
(1, 4, 'c')
)
table = Table(rows, self.column_names, self.column_types)
self.assertSequenceEqual(
table.columns['one'].values_without_nulls_sorted(),
[Decimal('1'), Decimal('2')]
)
|