-
Notifications
You must be signed in to change notification settings - Fork 14.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
full refacto sensors error management #41047
Conversation
@potiuk should I make the warning conditional to the minimal airflow-core compatible version of the package of the super class ? it yes , do you have an elegant idea how ? thanks ( but doing so isn't breaking the hierarchical OOP ? ) |
Yes. You cannot have a warning for 2.7-2.9 and do not have an option to remove the warning other than upgrading. Yes the idea is simple. Check airlfow version and do it conditionally. Every provider already does it in
|
fd66a10
to
f3e233b
Compare
thanks @potiuk for the guidance ,but I still don't know how to do that in the BaseSensorOperator. I'm quit lost 😅 |
You can't do it in BaseOperator. The compatibility code shoudl be implemented in those operators that gets incompatible (because eventually you will have - say - 2.7.1 BaseSensor and the new - say Http - Operator. We recently added Then each of those provider will have to depend on the next version of the common.compat, in order to make sure that code is available. For example we have get_hook_lineage_collector added in 2.10 : https://github.com/apache/airflow/blob/main/airflow/providers/common/compat/lineage/hook.py#L20 and a number of providers using it import it (until they reach 2.10 minimum level) from there
And the aws provider has a dependency on common.compat: 1.1.0
The 1.1.0 compat has not been released yet https://airflow.apache.org/docs/apache-airflow-providers-common-compat/stable/index.html - so you can still add the code to common.compat and set all the providers to depend on 1.1.0 of common compat. |
but that mean only operators from official providers of the apache-airflow projects will show the warnings , is not that a problem ? |
Well. It's logically impossible to influence behaviour of already released airflow version. If you have 3ed-party operator - you have absolutely no way to influence their beheaviour on past airflow version. |
We could create a new DeprecatedAirflowCoreException that we ignore in unit tests and that get show to users of "old" providers versions WDYT ? and if no , does my commit "first try" is what you expect ? Thanks |
The code Ilooks good - just make it into common.compat provider and use it from there for every provider that is affected (and add dependency to "apache-airflow-provder-common-compat" for those providers. |
Okay .Also all the providers are affected , could you confirm me that the design is okay before I do the big refacto , thanks cause I would need to put that lines in every sensors -> https://github.com/apache/airflow/blob/f5b2364b4a5d965d07da0f79f834507f716c5de1/airflow/providers/sftp/sensors/sftp.py#L70 and that mean not official providers will not have the warning |
f5b2364
to
26b74ea
Compare
@@ -32,8 +32,8 @@ | |||
__version__ = "8.26.0" | |||
|
|||
if packaging.version.parse(packaging.version.parse(airflow_version).base_version) < packaging.version.parse( | |||
"2.7.0" | |||
"2.7.1" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why do you change the min version?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
cause I removed
# TODO: remove this if block when min_airflow_version is set to higher than 2.7.1
I made a commit
|
824acb9
to
4285487
Compare
f9a21c7
to
caaa606
Compare
caaa606
to
d6314b4
Compare
Generally - we rarely look at changes that have errors :) - and here I guess the problem is still back-compatibility ( I rebased to double-check) |
d6314b4
to
140de1b
Compare
88598b2
to
e01cc3b
Compare
e01cc3b
to
20a55fe
Compare
20a55fe
to
7ae0db7
Compare
Fixed the tests , could you please re-review thanks |
Will take a look later today. |
It looks good, but I would love to see if others have any concerns. That seems like a good one to leave a clean solution for Airflow 3 without deprecations, so it would be good to have it this way. @eladkal - WDYT? - also @kaxil -> that one looks like a "biggish" change in terms of DAG incompatibility, so maybe we should consider that one as a candidate to mention at the next dev call on Thursday? |
thank @potiuk for the review , this PR is mostly about restoring how sensors where working since beginning before the "fix" of 2.7.1 https://github.com/apache/airflow/pull/33401/files |
Partially yes. But we should assume that most people are at 2.7.1 + now (our providers are going soon to be 2.8.0+ compatible only) - and removing soft_fail in Airlfow 3 will mean that you will need to rewrite your dags that use it. |
from airflow.exceptions import AirflowException
from airflow.operators.empty import EmptyOperator
from airflow.sensors.python import PythonSensor
from airflow.operators.python import ShortCircuitOperator
from airflow.utils.trigger_rule import TriggerRule
from pendulum import today
from airflow import DAG
def a():
# return False # task_c will be skip
raise ValueError("toto") # task_c will not run
# return True # task_c will run
def b(error: str | None):
if error == "AirflowSensorTimeout":
return False
elif error == "None":
return True
else:
raise AirflowException()
def sav_error(context):
exception_name = context["exception"].__class__.__name__
context.get('task_instance').xcom_push("error", exception_name)
with DAG(
dag_id='example',
schedule_interval='0 0 * * *',
start_date=today("UTC").add(days=-1)):
a = PythonSensor(task_id="a", python_callable=a, on_failure_callback=sav_error, timeout=5, poke_interval=5)
b = ShortCircuitOperator(task_id="b", python_callable=b, trigger_rule=TriggerRule.ALL_DONE, op_kwargs={
'error': "{{ ti.xcom_pull(task_ids='a', key='error') }}"})
c = EmptyOperator(task_id="c")
a >> b >> c
|
@potiuk what should we do ? thanks |
Rebase/ review - potentually simplify and merge it as breaking change to main (which is already Airflow 3). We likely won't backport it to 2.10 |
okay so I close for this PR #41463 |
fix: #40787
introduce fail_policy parameter
deprecate soft_fail and silent_fail parameters
introduce the SKIP_ON_ANY_ERROR
replace soft_fail by SKIP_ON_TIMEOUT that is no more ignoring technical errors
replace silent_fail by IGNORE_ERROR
why ? cause we currently can't trust the
soft_fail
parameters for at least once delivery since sensor can be skipped on any technical errors with soft_fail ( that mean we can skip data that was available or present )