當前位置: 首頁>>代碼示例>>Python>>正文


Python DagRun.dag_id方法代碼示例

本文整理匯總了Python中airflow.models.DagRun.dag_id方法的典型用法代碼示例。如果您正苦於以下問題:Python DagRun.dag_id方法的具體用法?Python DagRun.dag_id怎麽用?Python DagRun.dag_id使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在airflow.models.DagRun的用法示例。


在下文中一共展示了DagRun.dag_id方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_success_dag_never_run

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_success_dag_never_run(self):
        endpoint = "success"
        dag_id = "example_bash_operator"
        form = dict(
            task_id="run_this_last",
            dag_id=dag_id,
            execution_date=self.EXAMPLE_DAG_DEFAULT_DATE,
            upstream="false",
            downstream="false",
            future="false",
            past="false",
            origin="/graph?dag_id=example_bash_operator",
        )
        clear_db_runs()
        resp = self.client.post('success', data=form, follow_redirects=True)
        self.check_content_in_response(
            f"Cannot make {endpoint}, seem that dag {dag_id} has never run", resp) 
開發者ID:apache,項目名稱:airflow,代碼行數:19,代碼來源:test_views.py

示例2: test_delete_dag_button_for_dag_on_scheduler_only

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_delete_dag_button_for_dag_on_scheduler_only(self):
        # Test for JIRA AIRFLOW-3233 (PR 4069):
        # The delete-dag URL should be generated correctly for DAGs
        # that exist on the scheduler (DB) but not the webserver DagBag

        dag_id = 'example_bash_operator'
        test_dag_id = "non_existent_dag"

        DM = models.DagModel
        dag_query = self.session.query(DM).filter(DM.dag_id == dag_id)
        dag_query.first().tags = []  # To avoid "FOREIGN KEY constraint" error
        self.session.commit()

        dag_query.update({'dag_id': test_dag_id})
        self.session.commit()

        resp = self.client.get('/', follow_redirects=True)
        self.check_content_in_response('/delete?dag_id={}'.format(test_dag_id), resp)
        self.check_content_in_response("return confirmDeleteDag(this, '{}')".format(test_dag_id), resp)

        self.session.query(DM).filter(DM.dag_id == test_dag_id).update({'dag_id': dag_id})
        self.session.commit() 
開發者ID:apache,項目名稱:airflow,代碼行數:24,代碼來源:test_views.py

示例3: test_show_external_log_redirect_link_with_external_log_handler

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_show_external_log_redirect_link_with_external_log_handler(self, endpoint, mock_log_handler):
        """Show external links if log handler is external."""
        class ExternalHandler(ExternalLoggingMixin):
            LOG_NAME = 'ExternalLog'

            @property
            def log_name(self):
                return self.LOG_NAME

        mock_log_handler.return_value = ExternalHandler()

        url = f'{endpoint}?dag_id=example_bash_operator'
        with self.capture_templates() as templates:
            self.client.get(url, follow_redirects=True)
            ctx = templates[0].local_context
            self.assertTrue(ctx['show_external_log_redirect'])
            self.assertEqual(ctx['external_log_name'], ExternalHandler.LOG_NAME) 
開發者ID:apache,項目名稱:airflow,代碼行數:19,代碼來源:test_views.py

示例4: test_get_logs_with_metadata_as_download_file

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_get_logs_with_metadata_as_download_file(self):
        url_template = "get_logs_with_metadata?dag_id={}&" \
                       "task_id={}&execution_date={}&" \
                       "try_number={}&metadata={}&format=file"
        try_number = 1
        url = url_template.format(self.DAG_ID,
                                  self.TASK_ID,
                                  quote_plus(self.DEFAULT_DATE.isoformat()),
                                  try_number,
                                  json.dumps({}))
        response = self.client.get(url)
        expected_filename = '{}/{}/{}/{}.log'.format(self.DAG_ID,
                                                     self.TASK_ID,
                                                     self.DEFAULT_DATE.isoformat(),
                                                     try_number)

        content_disposition = response.headers.get('Content-Disposition')
        self.assertTrue(content_disposition.startswith('attachment'))
        self.assertTrue(expected_filename in content_disposition)
        self.assertEqual(200, response.status_code)
        self.assertIn('Log for testing.', response.data.decode('utf-8')) 
開發者ID:apache,項目名稱:airflow,代碼行數:23,代碼來源:test_views.py

示例5: test_get_logs_with_metadata_as_download_large_file

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_get_logs_with_metadata_as_download_large_file(self):
        with mock.patch("airflow.utils.log.file_task_handler.FileTaskHandler.read") as read_mock:
            first_return = (['1st line'], [{}])
            second_return = (['2nd line'], [{'end_of_log': False}])
            third_return = (['3rd line'], [{'end_of_log': True}])
            fourth_return = (['should never be read'], [{'end_of_log': True}])
            read_mock.side_effect = [first_return, second_return, third_return, fourth_return]
            url_template = "get_logs_with_metadata?dag_id={}&" \
                           "task_id={}&execution_date={}&" \
                           "try_number={}&metadata={}&format=file"
            try_number = 1
            url = url_template.format(self.DAG_ID,
                                      self.TASK_ID,
                                      quote_plus(self.DEFAULT_DATE.isoformat()),
                                      try_number,
                                      json.dumps({}))
            response = self.client.get(url)

            self.assertIn('1st line', response.data.decode('utf-8'))
            self.assertIn('2nd line', response.data.decode('utf-8'))
            self.assertIn('3rd line', response.data.decode('utf-8'))
            self.assertNotIn('should never be read', response.data.decode('utf-8')) 
開發者ID:apache,項目名稱:airflow,代碼行數:24,代碼來源:test_views.py

示例6: test_get_logs_with_metadata

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_get_logs_with_metadata(self):
        url_template = "get_logs_with_metadata?dag_id={}&" \
                       "task_id={}&execution_date={}&" \
                       "try_number={}&metadata={}"
        response = \
            self.client.get(url_template.format(self.DAG_ID,
                                                self.TASK_ID,
                                                quote_plus(self.DEFAULT_DATE.isoformat()),
                                                1,
                                                json.dumps({})), data=dict(
                                                    username='test',
                                                    password='test'),
                            follow_redirects=True)

        self.assertIn('"message":', response.data.decode('utf-8'))
        self.assertIn('"metadata":', response.data.decode('utf-8'))
        self.assertIn('Log for testing.', response.data.decode('utf-8'))
        self.assertEqual(200, response.status_code) 
開發者ID:apache,項目名稱:airflow,代碼行數:20,代碼來源:test_views.py

示例7: test_get_logs_with_metadata_for_removed_dag

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_get_logs_with_metadata_for_removed_dag(self, mock_read):
        mock_read.return_value = (['airflow log line'], [{'end_of_log': True}])
        url_template = "get_logs_with_metadata?dag_id={}&" \
                       "task_id={}&execution_date={}&" \
                       "try_number={}&metadata={}"
        url = url_template.format(self.DAG_ID_REMOVED, self.TASK_ID,
                                  quote_plus(self.DEFAULT_DATE.isoformat()), 1, json.dumps({}))
        response = self.client.get(
            url,
            data=dict(
                username='test',
                password='test'
            ),
            follow_redirects=True
        )

        self.assertIn('"message":', response.data.decode('utf-8'))
        self.assertIn('"metadata":', response.data.decode('utf-8'))
        self.assertIn('airflow log line', response.data.decode('utf-8'))
        self.assertEqual(200, response.status_code) 
開發者ID:apache,項目名稱:airflow,代碼行數:22,代碼來源:test_views.py

示例8: test_get_logs_for_handler_without_read_method

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_get_logs_for_handler_without_read_method(self, mock_log_reader):
        type(mock_log_reader.return_value).supports_read = PropertyMock(return_value=False)

        url_template = "get_logs_with_metadata?dag_id={}&" \
                       "task_id={}&execution_date={}&" \
                       "try_number={}&metadata={}&format=json"
        try_number = 1
        url = url_template.format(self.DAG_ID,
                                  self.TASK_ID,
                                  quote_plus(self.DEFAULT_DATE.isoformat()),
                                  try_number,
                                  json.dumps({}))
        response = self.client.get(url)
        self.assertEqual(200, response.status_code)
        self.assertIn('message', response.json)
        self.assertIn('metadata', response.json)
        self.assertIn(
            'Task log handler does not support read logs.',
            response.json['message']) 
開發者ID:apache,項目名稱:airflow,代碼行數:21,代碼來源:test_views.py

示例9: test_blocked_success_when_selecting_dags

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_blocked_success_when_selecting_dags(self):
        resp = self.client.post('blocked',
                                data={'dag_ids': ['example_subdag_operator']},
                                follow_redirects=True)
        self.assertEqual(resp.status_code, 200)
        blocked_dags = {blocked['dag_id'] for blocked in json.loads(resp.data.decode('utf-8'))}
        self.assertNotIn('example_bash_operator', blocked_dags)
        self.assertIn('example_subdag_operator', blocked_dags)

        # Multiple
        resp = self.client.post('blocked',
                                data={'dag_ids': ['example_subdag_operator', 'example_bash_operator']},
                                follow_redirects=True)
        self.assertEqual(resp.status_code, 200)
        blocked_dags = {blocked['dag_id'] for blocked in json.loads(resp.data.decode('utf-8'))}
        self.assertIn('example_bash_operator', blocked_dags)
        self.assertIn('example_subdag_operator', blocked_dags)
        self.check_content_not_in_response('example_xcom', resp) 
開發者ID:apache,項目名稱:airflow,代碼行數:20,代碼來源:test_views.py

示例10: test_success_fail_for_read_only_role

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_success_fail_for_read_only_role(self):
        # succcess endpoint need can_dag_edit, which read only role can not access
        self.logout()
        self.login(username='dag_read_only',
                   password='dag_read_only')

        form = dict(
            task_id="run_this_last",
            dag_id="example_bash_operator",
            execution_date=self.default_date,
            upstream="false",
            downstream="false",
            future="false",
            past="false",
        )
        resp = self.client.post('success', data=form)
        self.check_content_not_in_response('Wait a minute', resp, resp_code=302) 
開發者ID:apache,項目名稱:airflow,代碼行數:19,代碼來源:test_views.py

示例11: test_user_defined_filter_and_macros_raise_error

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_user_defined_filter_and_macros_raise_error(self):
        """
        Test that the Rendered View is able to show rendered values
        even for TIs that have not yet executed
        """
        self.app.dag_bag = mock.MagicMock(
            **{'get_dag.return_value': SerializedDagModel.get(self.dag.dag_id).dag}
        )
        self.assertEqual(self.task2.bash_command,
                         'echo {{ fullname("Apache", "Airflow") | hello }}')

        url = ('rendered?task_id=task2&dag_id=testdag&execution_date={}'
               .format(self.percent_encode(self.default_date)))

        resp = self.client.get(url, follow_redirects=True)
        self.check_content_not_in_response("echo Hello Apache Airflow", resp)
        self.check_content_in_response(
            "Webserver does not have access to User-defined Macros or Filters "
            "when Dag Serialization is enabled. Hence for the task that have not yet "
            "started running, please use 'airflow tasks render' for debugging the "
            "rendering of template_fields.<br/><br/>OriginalError: no filter named &#39;hello&#39",
            resp
        ) 
開發者ID:apache,項目名稱:airflow,代碼行數:25,代碼來源:test_views.py

示例12: test_trigger_dag_conf

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_trigger_dag_conf(self):

        test_dag_id = "example_bash_operator"
        conf_dict = {'string': 'Hello, World!'}

        DR = models.DagRun
        self.session.query(DR).delete()
        self.session.commit()

        self.client.post('trigger?dag_id={}'.format(test_dag_id), data={'conf': json.dumps(conf_dict)})

        run = self.session.query(DR).filter(DR.dag_id == test_dag_id).first()
        self.assertIsNotNone(run)
        self.assertIn(DagRunType.MANUAL.value, run.run_id)
        self.assertEqual(run.run_type, DagRunType.MANUAL.value)
        self.assertEqual(run.conf, conf_dict) 
開發者ID:apache,項目名稱:airflow,代碼行數:18,代碼來源:test_views.py

示例13: test_task

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_task(self):
        url = ('task?task_id=runme_0&dag_id=example_bash_operator&execution_date={}'
               .format(self.percent_encode(self.EXAMPLE_DAG_DEFAULT_DATE)))
        resp = self.client.get(url, follow_redirects=True)
        self.check_content_in_response('Task Instance Details', resp) 
開發者ID:apache,項目名稱:airflow,代碼行數:7,代碼來源:test_views.py

示例14: test_xcom

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_xcom(self):
        url = ('xcom?task_id=runme_0&dag_id=example_bash_operator&execution_date={}'
               .format(self.percent_encode(self.EXAMPLE_DAG_DEFAULT_DATE)))
        resp = self.client.get(url, follow_redirects=True)
        self.check_content_in_response('XCom', resp) 
開發者ID:apache,項目名稱:airflow,代碼行數:7,代碼來源:test_views.py

示例15: test_rendered

# 需要導入模塊: from airflow.models import DagRun [as 別名]
# 或者: from airflow.models.DagRun import dag_id [as 別名]
def test_rendered(self):
        url = ('rendered?task_id=runme_0&dag_id=example_bash_operator&execution_date={}'
               .format(self.percent_encode(self.EXAMPLE_DAG_DEFAULT_DATE)))
        resp = self.client.get(url, follow_redirects=True)
        self.check_content_in_response('Rendered Template', resp) 
開發者ID:apache,項目名稱:airflow,代碼行數:7,代碼來源:test_views.py


注:本文中的airflow.models.DagRun.dag_id方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。