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
|
from parameterized import parameterized
try:
import numpy as np
except ImportError:
np = None
from tests.numpy.testcase import NumpyBaseTestCase
class FloatTestCase(NumpyBaseTestCase):
n = 10
def check_result(self, rv, col_type):
self.assertArraysEqual(rv[0], np.array(range(self.n)))
self.assertEqual(rv[0].dtype, col_type)
def get_query(self, ch_type):
with self.create_table('a {}'.format(ch_type)):
data = [np.array(range(self.n))]
self.client.execute(
'INSERT INTO test (a) VALUES', data, columnar=True
)
query = 'SELECT * FROM test'
inserted = self.emit_cli(query)
self.assertEqual(
inserted, '\n'.join(str(x) for x in data[0]) + '\n'
)
return self.client.execute(query, columnar=True)
def test_float32(self):
rv = self.get_query('Float32')
self.check_result(rv, np.float32)
def test_float64(self):
rv = self.get_query('Float64')
self.check_result(rv, np.float64)
def test_fractional_round_trip(self):
with self.create_table('a Float32'):
data = [np.array([0.5, 1.5], dtype=np.float32)]
self.client.execute(
'INSERT INTO test (a) VALUES', data, columnar=True
)
query = 'SELECT * FROM test'
inserted = self.emit_cli(query)
self.assertEqual(inserted, '0.5\n1.5\n')
inserted = self.client.execute(query, columnar=True)
self.assertArraysEqual(inserted[0], data[0])
@parameterized.expand(['Float32', 'Float64'])
def test_nullable(self, float_type):
with self.create_table('a Nullable({})'.format(float_type)):
data = [np.array([np.nan, 0.5, None, 1.5], dtype=object)]
self.client.execute(
'INSERT INTO test (a) VALUES', data, columnar=True
)
query = 'SELECT * FROM test'
inserted = self.emit_cli(query)
self.assertEqual(inserted, 'nan\n0.5\n\\N\n1.5\n')
inserted = self.client.execute(query, columnar=True)
self.assertArraysEqual(
inserted[0].astype(str), data[0].astype(str)
)
self.assertEqual(inserted[0].dtype, object)
def test_nan(self):
with self.create_table('a Float32'):
data = [np.array([float('nan'), 0.5], dtype=np.float32)]
self.client.execute(
'INSERT INTO test (a) VALUES', data, columnar=True
)
query = 'SELECT * FROM test'
inserted = self.emit_cli(query)
self.assertEqual(inserted, 'nan\n0.5\n')
inserted = self.client.execute(query, columnar=True)
self.assertArraysEqual(
inserted[0].astype(str), data[0].astype(str)
)
self.assertEqual(inserted[0].dtype, np.float32)
|