# 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 from unittest.mock import patch import pytest from freezegun import freeze_time from freezegun.api import FakeDatetime # type: ignore from superset.extensions import db from superset.models.reports import ReportScheduleType from superset.tasks.scheduler import scheduler from tests.integration_tests.reports.utils import insert_report_schedule from tests.integration_tests.test_app import app @patch("superset.tasks.scheduler.execute.apply_async") def test_scheduler_celery_timeout_ny(execute_mock): """ Reports scheduler: Test scheduler setting celery soft and hard timeout """ with app.app_context(): report_schedule = insert_report_schedule( type=ReportScheduleType.ALERT, name="report", crontab="0 4 * * *", timezone="America/New_York", ) with freeze_time("2020-01-01T09:00:00Z"): scheduler() assert execute_mock.call_args[1]["soft_time_limit"] == 3601 assert execute_mock.call_args[1]["time_limit"] == 3610 db.session.delete(report_schedule) db.session.commit() @patch("superset.tasks.scheduler.execute.apply_async") def test_scheduler_celery_no_timeout_ny(execute_mock): """ Reports scheduler: Test scheduler setting celery soft and hard timeout """ with app.app_context(): app.config["ALERT_REPORTS_WORKING_TIME_OUT_KILL"] = False report_schedule = insert_report_schedule( type=ReportScheduleType.ALERT, name="report", crontab="0 4 * * *", timezone="America/New_York", ) with freeze_time("2020-01-01T09:00:00Z"): scheduler() assert execute_mock.call_args[1] == {"eta": FakeDatetime(2020, 1, 1, 9, 0)} db.session.delete(report_schedule) db.session.commit() app.config["ALERT_REPORTS_WORKING_TIME_OUT_KILL"] = True @patch("superset.tasks.scheduler.execute.apply_async") def test_scheduler_celery_timeout_utc(execute_mock): """ Reports scheduler: Test scheduler setting celery soft and hard timeout """ with app.app_context(): report_schedule = insert_report_schedule( type=ReportScheduleType.ALERT, name="report", crontab="0 9 * * *", timezone="UTC", ) with freeze_time("2020-01-01T09:00:00Z"): scheduler() print(execute_mock.call_args) assert execute_mock.call_args[1]["soft_time_limit"] == 3601 assert execute_mock.call_args[1]["time_limit"] == 3610 db.session.delete(report_schedule) db.session.commit() @patch("superset.tasks.scheduler.execute.apply_async") def test_scheduler_celery_no_timeout_utc(execute_mock): """ Reports scheduler: Test scheduler setting celery soft and hard timeout """ with app.app_context(): app.config["ALERT_REPORTS_WORKING_TIME_OUT_KILL"] = False report_schedule = insert_report_schedule( type=ReportScheduleType.ALERT, name="report", crontab="0 9 * * *", timezone="UTC", ) with freeze_time("2020-01-01T09:00:00Z"): scheduler() assert execute_mock.call_args[1] == {"eta": FakeDatetime(2020, 1, 1, 9, 0)} db.session.delete(report_schedule) db.session.commit() app.config["ALERT_REPORTS_WORKING_TIME_OUT_KILL"] = True