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


Python kubernetes_pod_operator.KubernetesPodOperator類代碼示例

本文整理匯總了Python中airflow.contrib.operators.kubernetes_pod_operator.KubernetesPodOperator的典型用法代碼示例。如果您正苦於以下問題:Python KubernetesPodOperator類的具體用法?Python KubernetesPodOperator怎麽用?Python KubernetesPodOperator使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: test_volume_mount

    def test_volume_mount():
        with mock.patch.object(PodLauncher, 'log') as mock_logger:
            volume_mount = VolumeMount('test-volume',
                                       mount_path='/root/mount_file',
                                       sub_path=None,
                                       read_only=True)

            volume_config = {
                'persistentVolumeClaim':
                    {
                        'claimName': 'test-volume'
                    }
            }
            volume = Volume(name='test-volume', configs=volume_config)
            k = KubernetesPodOperator(
                namespace='default',
                image="ubuntu:16.04",
                cmds=["bash", "-cx"],
                arguments=["cat /root/mount_file/test.txt"],
                labels={"foo": "bar"},
                volume_mounts=[volume_mount],
                volumes=[volume],
                name="test",
                task_id="task"
            )
            k.execute(None)
            mock_logger.info.assert_any_call(b"retrieved from mount\n")
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:27,代碼來源:test_kubernetes_pod_operator.py

示例2: test_pod_affinity

 def test_pod_affinity():
     affinity = {
         'nodeAffinity': {
             'requiredDuringSchedulingIgnoredDuringExecution': {
                 'nodeSelectorTerms': [
                     {
                         'matchExpressions': [
                             {
                                 'key': 'beta.kubernetes.io/os',
                                 'operator': 'In',
                                 'values': ['linux']
                             }
                         ]
                     }
                 ]
             }
         }
     }
     k = KubernetesPodOperator(
         namespace='default',
         image="ubuntu:16.04",
         cmds=["bash", "-cx"],
         arguments=["echo", "10"],
         labels={"foo": "bar"},
         name="test",
         task_id="task",
         affinity=affinity,
         executor_config={'KubernetesExecutor': {'affinity': affinity}}
     )
     k.execute(None)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:30,代碼來源:test_kubernetes_pod_operator.py

示例3: test_working_pod

 def test_working_pod():
     k = KubernetesPodOperator(
         namespace='default',
         image="ubuntu:16.04",
         cmds=["bash", "-cx"],
         arguments=["echo 10"],
         labels={"foo": "bar"},
         name="test",
         task_id="task"
     )
     k.execute(None)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:11,代碼來源:test_kubernetes_pod_operator.py

示例4: test_xcom_push

 def test_xcom_push(self):
     return_value = '{"foo": "bar"\n, "buzz": 2}'
     k = KubernetesPodOperator(
         namespace='default',
         image="ubuntu:16.04",
         cmds=["bash", "-cx"],
         arguments=['echo \'{}\' > /airflow/xcom/return.json'.format(return_value)],
         labels={"foo": "bar"},
         name="test",
         task_id="task",
         do_xcom_push=True
     )
     self.assertEqual(k.execute(None), json.loads(return_value))
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:13,代碼來源:test_kubernetes_pod_operator.py

示例5: test_logging

 def test_logging(self):
     with mock.patch.object(PodLauncher, 'log') as mock_logger:
         k = KubernetesPodOperator(namespace='default',
                                   image="ubuntu:16.04",
                                   cmds=["bash", "-cx"],
                                   arguments=["echo", "10"],
                                   labels={"foo": "bar"},
                                   name="test",
                                   task_id="task",
                                   get_logs=True
                                   )
         k.execute(None)
         mock_logger.info.assert_any_call("+ echo\n")
開發者ID:ataki,項目名稱:incubator-airflow,代碼行數:13,代碼來源:test_kubernetes_pod_operator.py

示例6: test_faulty_image

 def test_faulty_image(self):
     bad_image_name = "foobar"
     k = KubernetesPodOperator(
         namespace='default',
         image=bad_image_name,
         cmds=["bash", "-cx"],
         arguments=["echo 10"],
         labels={"foo": "bar"},
         name="test",
         task_id="task",
         startup_timeout_seconds=5
     )
     with self.assertRaises(AirflowException):
         k.execute(None)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:14,代碼來源:test_kubernetes_pod_operator.py

示例7: test_faulty_service_account

 def test_faulty_service_account(self):
     bad_service_account_name = "foobar"
     k = KubernetesPodOperator(
         namespace='default',
         image="ubuntu:16.04",
         cmds=["bash", "-cx"],
         arguments=["echo 10"],
         labels={"foo": "bar"},
         name="test",
         task_id="task",
         startup_timeout_seconds=5,
         service_account_name=bad_service_account_name
     )
     with self.assertRaises(ApiException):
         k.execute(None)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:15,代碼來源:test_kubernetes_pod_operator.py

示例8: test_config_path_move

    def test_config_path_move():
        new_config_path = '/tmp/kube_config'
        old_config_path = os.path.expanduser('~/.kube/config')
        shutil.copy(old_config_path, new_config_path)

        k = KubernetesPodOperator(
            namespace='default',
            image="ubuntu:16.04",
            cmds=["bash", "-cx"],
            arguments=["echo 10"],
            labels={"foo": "bar"},
            name="test",
            task_id="task",
            config_file=new_config_path
        )
        k.execute(None)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:16,代碼來源:test_kubernetes_pod_operator.py

示例9: test_pod_failure

 def test_pod_failure(self):
     """
         Tests that the task fails when a pod reports a failure
     """
     bad_internal_command = "foobar"
     k = KubernetesPodOperator(
         namespace='default',
         image="ubuntu:16.04",
         cmds=["bash", "-cx"],
         arguments=[bad_internal_command + " 10"],
         labels={"foo": "bar"},
         name="test",
         task_id="task"
     )
     with self.assertRaises(AirflowException):
         k.execute(None)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:16,代碼來源:test_kubernetes_pod_operator.py

示例10: test_pod_node_selectors

 def test_pod_node_selectors():
     node_selectors = {
         'beta.kubernetes.io/os': 'linux'
     }
     k = KubernetesPodOperator(
         namespace='default',
         image="ubuntu:16.04",
         cmds=["bash", "-cx"],
         arguments=["echo", "10"],
         labels={"foo": "bar"},
         name="test",
         task_id="task",
         node_selectors=node_selectors,
         executor_config={'KubernetesExecutor': {'node_selectors': node_selectors}}
     )
     k.execute(None)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:16,代碼來源:test_kubernetes_pod_operator.py

示例11: test_pod_delete_even_on_launcher_error

 def test_pod_delete_even_on_launcher_error(self, client_mock, delete_pod_mock, run_pod_mock):
     k = KubernetesPodOperator(
         namespace='default',
         image="ubuntu:16.04",
         cmds=["bash", "-cx"],
         arguments=["echo 10"],
         labels={"foo": "bar"},
         name="test",
         task_id="task",
         in_cluster=False,
         cluster_context='default',
         is_delete_operator_pod=True
     )
     run_pod_mock.side_effect = AirflowException('fake failure')
     with self.assertRaises(AirflowException):
         k.execute(None)
     assert delete_pod_mock.called
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:17,代碼來源:test_kubernetes_pod_operator.py

示例12: test_envs_from_secrets

 def test_envs_from_secrets(self, client_mock, launcher_mock):
     # GIVEN
     from airflow.utils.state import State
     secrets = [Secret('env', None, "secret_name")]
     # WHEN
     k = KubernetesPodOperator(
         namespace='default',
         image="ubuntu:16.04",
         cmds=["bash", "-cx"],
         arguments=["echo 10"],
         secrets=secrets,
         labels={"foo": "bar"},
         name="test",
         task_id="task",
     )
     # THEN
     launcher_mock.return_value = (State.SUCCESS, None)
     k.execute(None)
     self.assertEqual(launcher_mock.call_args[0][0].secrets, secrets)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:19,代碼來源:test_kubernetes_pod_operator.py

示例13: test_fs_group

    def test_fs_group():
        security_context = {
            'securityContext': {
                'fsGroup': 1000,
            }
        }

        k = KubernetesPodOperator(
            namespace='default',
            image="ubuntu:16.04",
            cmds=["bash", "-cx"],
            arguments=["echo", "10"],
            labels={"foo": "bar"},
            name="test",
            task_id="task",
            security_context=security_context,
            executor_config={'KubernetesExecutor': {'securityContext': security_context}}
        )
        k.execute(None)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:19,代碼來源:test_kubernetes_pod_operator.py

示例14: test_image_pull_secrets_correctly_set

    def test_image_pull_secrets_correctly_set(self, client_mock, launcher_mock):
        from airflow.utils.state import State

        fake_pull_secrets = "fakeSecret"
        k = KubernetesPodOperator(
            namespace='default',
            image="ubuntu:16.04",
            cmds=["bash", "-cx"],
            arguments=["echo 10"],
            labels={"foo": "bar"},
            name="test",
            task_id="task",
            image_pull_secrets=fake_pull_secrets,
            in_cluster=False,
            cluster_context='default'
        )
        launcher_mock.return_value = (State.SUCCESS, None)
        k.execute(None)
        self.assertEqual(launcher_mock.call_args[0][0].image_pull_secrets,
                         fake_pull_secrets)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:20,代碼來源:test_kubernetes_pod_operator.py

示例15: test_config_path

    def test_config_path(self, client_mock, launcher_mock):
        from airflow.utils.state import State

        file_path = "/tmp/fake_file"
        k = KubernetesPodOperator(
            namespace='default',
            image="ubuntu:16.04",
            cmds=["bash", "-cx"],
            arguments=["echo 10"],
            labels={"foo": "bar"},
            name="test",
            task_id="task",
            config_file=file_path,
            in_cluster=False,
            cluster_context='default'
        )
        launcher_mock.return_value = (State.SUCCESS, None)
        k.execute(None)
        client_mock.assert_called_with(in_cluster=False,
                                       cluster_context='default',
                                       config_file=file_path)
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:21,代碼來源:test_kubernetes_pod_operator.py


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