# Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreements. See the NOTICE file # distributed with this work for additional information # regarding copyright ownership. The ASF licenses this file # to you under the Apache License, Version 2.0 (the # "License"); you may not use this file except in compliance # with the License. You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, # software distributed under the License is distributed on an # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY # KIND, either express or implied. See the License for the # specific language governing permissions and limitations # under the License. """Unit tests for Superset""" import json from .base_tests import SupersetTestCase from .fixtures.datasource import datasource_post class DatasourceTests(SupersetTestCase): def __init__(self, *args, **kwargs): super(DatasourceTests, self).__init__(*args, **kwargs) def test_external_metadata(self): self.login(username='admin') tbl = self.get_table_by_name('birth_names') schema = tbl.schema or '' url = ( f'/datasource/external_metadata/table/{tbl.id}/?' f'db_id={tbl.database.id}&' f'table_name={tbl.table_name}&' f'schema={schema}&' ) resp = self.get_json_resp(url) col_names = {o.get('name') for o in resp} self.assertEquals( col_names, {'sum_boys', 'num', 'gender', 'name', 'ds', 'state', 'sum_girls'}, ) def compare_lists(self, l1, l2, key): l2_lookup = {o.get(key): o for o in l2} for obj1 in l1: obj2 = l2_lookup.get(obj1.get(key)) for k in obj1: if k not in 'id' and obj1.get(k): self.assertEquals(obj1.get(k), obj2.get(k)) def test_save(self): self.login(username='admin') tbl_id = self.get_table_by_name('birth_names').id datasource_post['id'] = tbl_id data = dict(data=json.dumps(datasource_post)) resp = self.get_json_resp('/datasource/save/', data) for k in datasource_post: if k == 'columns': self.compare_lists(datasource_post[k], resp[k], 'column_name') elif k == 'metrics': self.compare_lists(datasource_post[k], resp[k], 'metric_name') else: self.assertEquals(resp[k], datasource_post[k])