mirror of
https://github.com/apache/superset.git
synced 2024-09-19 12:09:42 -04:00
84f7614e97
* Add filterset resource * fix: fix pre-commit * add tests * add tests and fixes based of failures * Fix pre-commit errors * chore init filterset resource under ff constraint * Fix migration conflicts * Fix pylint and migrations issues * Fix pylint and migrations issues * Fix pylint and migrations issues * Fix pylint and migrations issues * Fix pylint and migrations issues * Fix pylint and migrations issues * Fix pylint and migrations issues * Fix pylint and migrations issues * Fix pylint and migrations issues * Fix pylint and migrations issues * Fix pylint and migrations issues * add tests and fixes based of failures * Fix missing license * fix down revision * update down_revision * fix: update down_revision * chore: add description to migration * fix: type * refactor: is_user_admin * fix: use get_public_role * fix: move import to the relevant location * chore: add openSpec api schema * chore: cover all openspec API * fix: pre-commit and lint * fix: put and post schemas * fix: undo superset_test_config.py * fix: limit filterSetsApi to include_route_methods = {"get_list", "put", "post", "delete"} * renaming some params * chore: add debug in test config * fix: rename database to different name * fix: try to make conftest.py harmless * fix: pre-commit * fix: new down_revision ref * fix: bad ref * fix: bad ref 2 * fix: bad ref 3 * fix: add api in initiatior * fix: open spec * fix: convert name to str to include int usecases * fix: pylint * fix: pylint * Update superset/common/request_contexed_based.py Co-authored-by: Ville Brofeldt <33317356+villebro@users.noreply.github.com> * chore: resolve PR comments * chore: resolve PR comments * chore: resolve PR comments * fix failed tests * fix pylint * Update conftest.py * chore remove BaseCommand to remove abstraction * chore remove BaseCommand to remove abstraction * chore remove BaseCommand to remove abstraction * chore remove BaseCommand to remove abstraction * chore fix migration Co-authored-by: Ofeknielsen <ofek.israel@nieslen.com> Co-authored-by: amitmiran137 <amit.miran@nielsen.com> Co-authored-by: Amit Miran <47772523+amitmiran137@users.noreply.github.com> Co-authored-by: Ville Brofeldt <33317356+villebro@users.noreply.github.com>
103 lines
3.3 KiB
Python
103 lines
3.3 KiB
Python
# 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 __future__ import annotations
|
|
|
|
from typing import Any, Dict, List, Optional, Set, TYPE_CHECKING, Union
|
|
|
|
from superset.models.filter_set import FilterSet
|
|
from tests.integration_tests.dashboards.filter_sets.consts import FILTER_SET_URI
|
|
from tests.integration_tests.test_app import app
|
|
|
|
if TYPE_CHECKING:
|
|
from flask import Response
|
|
from flask.testing import FlaskClient
|
|
|
|
|
|
def call_create_filter_set(
|
|
client: FlaskClient[Any], dashboard_id: int, data: Dict[str, Any]
|
|
) -> Response:
|
|
uri = FILTER_SET_URI.format(dashboard_id=dashboard_id)
|
|
return client.post(uri, json=data)
|
|
|
|
|
|
def call_get_filter_sets(client: FlaskClient[Any], dashboard_id: int) -> Response:
|
|
uri = FILTER_SET_URI.format(dashboard_id=dashboard_id)
|
|
return client.get(uri)
|
|
|
|
|
|
def call_delete_filter_set(
|
|
client: FlaskClient[Any],
|
|
filter_set_dict_to_update: Dict[str, Any],
|
|
dashboard_id: Optional[int] = None,
|
|
) -> Response:
|
|
dashboard_id = (
|
|
dashboard_id
|
|
if dashboard_id is not None
|
|
else filter_set_dict_to_update["dashboard_id"]
|
|
)
|
|
uri = "{}/{}".format(
|
|
FILTER_SET_URI.format(dashboard_id=dashboard_id),
|
|
filter_set_dict_to_update["id"],
|
|
)
|
|
return client.delete(uri)
|
|
|
|
|
|
def call_update_filter_set(
|
|
client: FlaskClient[Any],
|
|
filter_set_dict_to_update: Dict[str, Any],
|
|
data: Dict[str, Any],
|
|
dashboard_id: Optional[int] = None,
|
|
) -> Response:
|
|
dashboard_id = (
|
|
dashboard_id
|
|
if dashboard_id is not None
|
|
else filter_set_dict_to_update["dashboard_id"]
|
|
)
|
|
uri = "{}/{}".format(
|
|
FILTER_SET_URI.format(dashboard_id=dashboard_id),
|
|
filter_set_dict_to_update["id"],
|
|
)
|
|
return client.put(uri, json=data)
|
|
|
|
|
|
def get_filter_set_by_name(name: str) -> FilterSet:
|
|
with app.app_context():
|
|
return FilterSet.get_by_name(name)
|
|
|
|
|
|
def get_filter_set_by_id(id_: int) -> FilterSet:
|
|
with app.app_context():
|
|
return FilterSet.get(id_)
|
|
|
|
|
|
def get_filter_set_by_dashboard_id(dashboard_id: int) -> FilterSet:
|
|
with app.app_context():
|
|
return FilterSet.get_by_dashboard_id(dashboard_id)
|
|
|
|
|
|
def collect_all_ids(
|
|
filtersets: Union[Dict[str, List[FilterSet]], List[FilterSet]]
|
|
) -> Set[int]:
|
|
if isinstance(filtersets, dict):
|
|
filtersets_lists: List[List[FilterSet]] = list(filtersets.values())
|
|
ids: Set[int] = set()
|
|
lst: List[FilterSet]
|
|
for lst in filtersets_lists:
|
|
ids.update(set(map(lambda fs: fs.id, lst)))
|
|
return ids
|
|
return set(map(lambda fs: fs.id, filtersets))
|