mirror of
https://github.com/apache/superset.git
synced 2024-09-17 19:19:38 -04:00
116 lines
3.1 KiB
Python
116 lines
3.1 KiB
Python
|
# -*- coding: utf-8 -*-
|
||
|
from __future__ import absolute_import
|
||
|
from __future__ import division
|
||
|
from __future__ import print_function
|
||
|
from __future__ import unicode_literals
|
||
|
|
||
|
from superset.dataframe import dedup, SupersetDataFrame
|
||
|
from superset.db_engine_specs import BaseEngineSpec
|
||
|
from .base_tests import SupersetTestCase
|
||
|
|
||
|
|
||
|
class SupersetDataFrameTestCase(SupersetTestCase):
|
||
|
def test_dedup(self):
|
||
|
self.assertEquals(
|
||
|
dedup(['foo', 'bar']),
|
||
|
['foo', 'bar'],
|
||
|
)
|
||
|
self.assertEquals(
|
||
|
dedup(['foo', 'bar', 'foo', 'bar']),
|
||
|
['foo', 'bar', 'foo__1', 'bar__1'],
|
||
|
)
|
||
|
self.assertEquals(
|
||
|
dedup(['foo', 'bar', 'bar', 'bar']),
|
||
|
['foo', 'bar', 'bar__1', 'bar__2'],
|
||
|
)
|
||
|
|
||
|
def test_get_columns_basic(self):
|
||
|
data = [
|
||
|
('a1', 'b1', 'c1'),
|
||
|
('a2', 'b2', 'c2'),
|
||
|
]
|
||
|
cursor_descr = (
|
||
|
('a', 'string'),
|
||
|
('b', 'string'),
|
||
|
('c', 'string'),
|
||
|
)
|
||
|
cdf = SupersetDataFrame(data, cursor_descr, BaseEngineSpec)
|
||
|
self.assertEqual(
|
||
|
cdf.columns,
|
||
|
[
|
||
|
{
|
||
|
'is_date': False,
|
||
|
'type': 'STRING',
|
||
|
'name': 'a',
|
||
|
'is_dim': True,
|
||
|
}, {
|
||
|
'is_date': False,
|
||
|
'type': 'STRING',
|
||
|
'name': 'b',
|
||
|
'is_dim': True,
|
||
|
}, {
|
||
|
'is_date': False,
|
||
|
'type': 'STRING',
|
||
|
'name': 'c',
|
||
|
'is_dim': True,
|
||
|
},
|
||
|
],
|
||
|
)
|
||
|
|
||
|
def test_get_columns_with_int(self):
|
||
|
data = [
|
||
|
('a1', 1),
|
||
|
('a2', 2),
|
||
|
]
|
||
|
cursor_descr = (
|
||
|
('a', 'string'),
|
||
|
('b', 'int'),
|
||
|
)
|
||
|
cdf = SupersetDataFrame(data, cursor_descr, BaseEngineSpec)
|
||
|
self.assertEqual(
|
||
|
cdf.columns,
|
||
|
[
|
||
|
{
|
||
|
'is_date': False,
|
||
|
'type': 'STRING',
|
||
|
'name': 'a',
|
||
|
'is_dim': True,
|
||
|
}, {
|
||
|
'is_date': False,
|
||
|
'type': 'INT',
|
||
|
'name': 'b',
|
||
|
'is_dim': False,
|
||
|
'agg': 'sum',
|
||
|
},
|
||
|
],
|
||
|
)
|
||
|
|
||
|
def test_get_columns_type_inference(self):
|
||
|
data = [
|
||
|
(1.2, 1),
|
||
|
(3.14, 2),
|
||
|
]
|
||
|
cursor_descr = (
|
||
|
('a', None),
|
||
|
('b', None),
|
||
|
)
|
||
|
cdf = SupersetDataFrame(data, cursor_descr, BaseEngineSpec)
|
||
|
self.assertEqual(
|
||
|
cdf.columns,
|
||
|
[
|
||
|
{
|
||
|
'is_date': False,
|
||
|
'type': 'FLOAT',
|
||
|
'name': 'a',
|
||
|
'is_dim': False,
|
||
|
'agg': 'sum',
|
||
|
}, {
|
||
|
'is_date': False,
|
||
|
'type': 'INT',
|
||
|
'name': 'b',
|
||
|
'is_dim': False,
|
||
|
'agg': 'sum',
|
||
|
},
|
||
|
],
|
||
|
)
|