apache-airflow-providers-cncf-kubernetes 8.3.0rc1__tar.gz → 8.3.0rc2__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of apache-airflow-providers-cncf-kubernetes might be problematic. Click here for more details.

Files changed (59) hide show
  1. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/PKG-INFO +2 -2
  2. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/README.rst +1 -1
  3. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/operators/pod.py +16 -7
  4. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/utils/pod_manager.py +1 -1
  5. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/pyproject.toml +1 -1
  6. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/LICENSE +0 -0
  7. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/__init__.py +0 -0
  8. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/backcompat/__init__.py +0 -0
  9. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/backcompat/backwards_compat_converters.py +0 -0
  10. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/callbacks.py +0 -0
  11. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/cli/__init__.py +0 -0
  12. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/cli/kubernetes_command.py +0 -0
  13. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/decorators/__init__.py +0 -0
  14. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/decorators/kubernetes.py +0 -0
  15. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/executors/__init__.py +0 -0
  16. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/executors/kubernetes_executor.py +0 -0
  17. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/executors/kubernetes_executor_types.py +0 -0
  18. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/executors/kubernetes_executor_utils.py +0 -0
  19. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/executors/local_kubernetes_executor.py +0 -0
  20. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/get_provider_info.py +0 -0
  21. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/hooks/__init__.py +0 -0
  22. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/hooks/kubernetes.py +0 -0
  23. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/k8s_model.py +0 -0
  24. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/kube_client.py +0 -0
  25. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/kube_config.py +0 -0
  26. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/kubernetes_executor_templates/__init__.py +0 -0
  27. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/kubernetes_executor_templates/basic_template.yaml +0 -0
  28. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/kubernetes_helper_functions.py +0 -0
  29. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/operators/__init__.py +0 -0
  30. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/operators/custom_object_launcher.py +0 -0
  31. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/operators/job.py +0 -0
  32. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/operators/kubernetes_pod.py +0 -0
  33. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/operators/resource.py +0 -0
  34. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/operators/spark_kubernetes.py +0 -0
  35. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/pod_generator.py +0 -0
  36. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/pod_generator_deprecated.py +0 -0
  37. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/pod_launcher_deprecated.py +0 -0
  38. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/pod_template_file_examples/__init__.py +0 -0
  39. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/pod_template_file_examples/dags_in_image_template.yaml +0 -0
  40. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/pod_template_file_examples/dags_in_volume_template.yaml +0 -0
  41. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/pod_template_file_examples/git_sync_template.yaml +0 -0
  42. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/python_kubernetes_script.jinja2 +0 -0
  43. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/python_kubernetes_script.py +0 -0
  44. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/resource_convert/__init__.py +0 -0
  45. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/resource_convert/configmap.py +0 -0
  46. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/resource_convert/env_variable.py +0 -0
  47. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/resource_convert/secret.py +0 -0
  48. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/secret.py +0 -0
  49. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/sensors/__init__.py +0 -0
  50. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/sensors/spark_kubernetes.py +0 -0
  51. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/template_rendering.py +0 -0
  52. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/triggers/__init__.py +0 -0
  53. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/triggers/job.py +0 -0
  54. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/triggers/kubernetes_pod.py +0 -0
  55. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/triggers/pod.py +0 -0
  56. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/utils/__init__.py +0 -0
  57. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/utils/delete_from.py +0 -0
  58. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/utils/k8s_resource_iterator.py +0 -0
  59. {apache_airflow_providers_cncf_kubernetes-8.3.0rc1 → apache_airflow_providers_cncf_kubernetes-8.3.0rc2}/airflow/providers/cncf/kubernetes/utils/xcom_sidecar.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: apache-airflow-providers-cncf-kubernetes
3
- Version: 8.3.0rc1
3
+ Version: 8.3.0rc2
4
4
  Summary: Provider package apache-airflow-providers-cncf-kubernetes for Apache Airflow
5
5
  Keywords: airflow-provider,cncf.kubernetes,airflow,integration
6
6
  Author-email: Apache Software Foundation <dev@airflow.apache.org>
@@ -80,7 +80,7 @@ Project-URL: YouTube, https://www.youtube.com/channel/UCSXwxpWZQ7XZ1WL3wqevChA/
80
80
 
81
81
  Package ``apache-airflow-providers-cncf-kubernetes``
82
82
 
83
- Release: ``8.3.0.rc1``
83
+ Release: ``8.3.0.rc2``
84
84
 
85
85
 
86
86
  `Kubernetes <https://kubernetes.io/>`__
@@ -42,7 +42,7 @@
42
42
 
43
43
  Package ``apache-airflow-providers-cncf-kubernetes``
44
44
 
45
- Release: ``8.3.0.rc1``
45
+ Release: ``8.3.0.rc2``
46
46
 
47
47
 
48
48
  `Kubernetes <https://kubernetes.io/>`__
@@ -36,6 +36,7 @@ import kubernetes
36
36
  import tenacity
37
37
  from deprecated import deprecated
38
38
  from kubernetes.client import CoreV1Api, V1Pod, models as k8s
39
+ from kubernetes.client.exceptions import ApiException
39
40
  from kubernetes.stream import stream
40
41
  from urllib3.exceptions import HTTPError
41
42
 
@@ -788,9 +789,18 @@ class KubernetesPodOperator(BaseOperator):
788
789
  # Skip await_pod_completion when the event is 'timeout' due to the pod can hang
789
790
  # on the ErrImagePull or ContainerCreating step and it will never complete
790
791
  if event["status"] != "timeout":
791
- self.pod = self.pod_manager.await_pod_completion(
792
- self.pod, istio_enabled, self.base_container_name
793
- )
792
+ try:
793
+ self.pod = self.pod_manager.await_pod_completion(
794
+ self.pod, istio_enabled, self.base_container_name
795
+ )
796
+ except ApiException as e:
797
+ if e.status == 404:
798
+ self.pod = None
799
+ self.log.warning(
800
+ "Pod not found while waiting for completion. The last status was %r", event["status"]
801
+ )
802
+ else:
803
+ raise e
794
804
  if self.pod is not None:
795
805
  self.post_complete_action(
796
806
  pod=self.pod,
@@ -807,8 +817,7 @@ class KubernetesPodOperator(BaseOperator):
807
817
  logs = self.client.read_namespaced_pod_log(
808
818
  name=pod.metadata.name,
809
819
  namespace=pod.metadata.namespace,
810
- pod=pod,
811
- container_name=self.base_container_name,
820
+ container=self.base_container_name,
812
821
  follow=follow,
813
822
  timestamps=False,
814
823
  since_seconds=since_seconds,
@@ -818,11 +827,11 @@ class KubernetesPodOperator(BaseOperator):
818
827
  line = raw_line.decode("utf-8", errors="backslashreplace").rstrip("\n")
819
828
  if line:
820
829
  self.log.info("[%s] logs: %s", self.base_container_name, line)
821
- except HTTPError as e:
830
+ except (HTTPError, ApiException) as e:
822
831
  self.log.warning(
823
832
  "Reading of logs interrupted with error %r; will retry. "
824
833
  "Set log level to DEBUG for traceback.",
825
- e,
834
+ e if not isinstance(e, ApiException) else e.reason,
826
835
  )
827
836
 
828
837
  def post_complete_action(self, *, pod, remote_pod, **kwargs) -> None:
@@ -516,7 +516,7 @@ class PodManager(LoggingMixin):
516
516
  # a timeout is a normal thing and we ignore it and resume following logs
517
517
  if not isinstance(exc, TimeoutError):
518
518
  self.log.warning(
519
- "Pod %s log read interrupted but container %s still running",
519
+ "Pod %s log read interrupted but container %s still running. Logs generated in the last one second might get duplicated.",
520
520
  pod.metadata.name,
521
521
  container_name,
522
522
  )
@@ -28,7 +28,7 @@ build-backend = "flit_core.buildapi"
28
28
 
29
29
  [project]
30
30
  name = "apache-airflow-providers-cncf-kubernetes"
31
- version = "8.3.0.rc1"
31
+ version = "8.3.0.rc2"
32
32
  description = "Provider package apache-airflow-providers-cncf-kubernetes for Apache Airflow"
33
33
  readme = "README.rst"
34
34
  authors = [