2021-02-15 14:41:59 -05:00
|
|
|
# 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.
|
|
|
|
from typing import List, Optional
|
|
|
|
|
|
|
|
from superset import ConnectorRegistry, db, security_manager
|
|
|
|
from superset.models.slice import Slice
|
|
|
|
|
|
|
|
|
|
|
|
class InsertChartMixin:
|
|
|
|
"""
|
|
|
|
Implements shared logic for tests to insert charts (slices) in the DB
|
|
|
|
"""
|
|
|
|
|
|
|
|
def insert_chart(
|
|
|
|
self,
|
|
|
|
slice_name: str,
|
|
|
|
owners: List[int],
|
|
|
|
datasource_id: int,
|
|
|
|
created_by=None,
|
|
|
|
datasource_type: str = "table",
|
|
|
|
description: Optional[str] = None,
|
|
|
|
viz_type: Optional[str] = None,
|
|
|
|
params: Optional[str] = None,
|
|
|
|
cache_timeout: Optional[int] = None,
|
2021-11-24 06:42:52 -05:00
|
|
|
certified_by: Optional[str] = None,
|
|
|
|
certification_details: Optional[str] = None,
|
2021-02-15 14:41:59 -05:00
|
|
|
) -> Slice:
|
|
|
|
obj_owners = list()
|
|
|
|
for owner in owners:
|
|
|
|
user = db.session.query(security_manager.user_model).get(owner)
|
|
|
|
obj_owners.append(user)
|
|
|
|
datasource = ConnectorRegistry.get_datasource(
|
|
|
|
datasource_type, datasource_id, db.session
|
|
|
|
)
|
|
|
|
slice = Slice(
|
|
|
|
cache_timeout=cache_timeout,
|
2021-11-24 06:42:52 -05:00
|
|
|
certified_by=certified_by,
|
|
|
|
certification_details=certification_details,
|
2021-02-15 14:41:59 -05:00
|
|
|
created_by=created_by,
|
|
|
|
datasource_id=datasource.id,
|
|
|
|
datasource_name=datasource.name,
|
|
|
|
datasource_type=datasource.type,
|
|
|
|
description=description,
|
|
|
|
owners=obj_owners,
|
|
|
|
params=params,
|
|
|
|
slice_name=slice_name,
|
|
|
|
viz_type=viz_type,
|
|
|
|
)
|
|
|
|
db.session.add(slice)
|
|
|
|
db.session.commit()
|
|
|
|
return slice
|