You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@airflow.apache.org by GitBox <gi...@apache.org> on 2021/08/03 12:03:57 UTC
[GitHub] [airflow] cansjt edited a comment on issue #17022: TaskInstance.previous_execution_date_success fails with: 'TaskInstance' object has no attribute 'task'
cansjt edited a comment on issue #17022:
URL: https://github.com/apache/airflow/issues/17022#issuecomment-891787393
With Airflow 2.1.2 we are something similar but not identical:
```
Task failed with exception", "exc_info": "Traceback (most recent call last):
File \"/usr/local/lib/python3.8/site-packages/airflow/models/taskinstance.py\", line 1157, in _run_raw_task
self._prepare_and_execute_task_with_callbacks(context, task)
File \"/usr/local/lib/python3.8/site-packages/airflow/models/taskinstance.py\", line 1331, in _prepare_and_execute_task_with_callbacks
result = self._execute_task(context, task_copy)
File \"/usr/local/lib/python3.8/site-packages/airflow/models/taskinstance.py\", line 1361, in _execute_task
result = task_copy.execute(context=context)
File \"/usr/local/lib/python3.8/site-packages/airflow/operators/python.py\", line 150, in execute
return_value = self.execute_callable()
File \"/usr/local/lib/python3.8/site-packages/airflow/operators/python.py\", line 161, in execute_callable
return self.python_callable(*self.op_args, **self.op_kwargs)
File \"/usr/local/lib/python3.8/site-packages/aggregator/tasks/airflow.py\", line 58, in __call__
super().__call__(execution_date + timedelta(days=1), **context)
File \"/usr/local/lib/python3.8/site-packages/aggregator/tasks/__init__.py\", line 103, in __call__
start_date, end_date = self._period(execution_date, **context)
File \"/usr/local/lib/python3.8/site-packages/aggregator/retention.py\", line 189, in __call__
lower_bounds, upper_bounds = zip(*[w(execution_date, **context) for w in self._windows])
File \"/usr/local/lib/python3.8/site-packages/aggregator/retention.py\", line 189, in <listcomp>
lower_bounds, upper_bounds = zip(*[w(execution_date, **context) for w in self._windows])
File \"/usr/local/lib/python3.8/site-packages/aggregator/tasks/airflow.py\", line 77, in __call__
if task_instance is None or task_instance.previous_execution_date_success is None:
AttributeError: 'TaskInstance' object has no attribute 'previous_execution_date_success'
```
The code triggering the execution is this
```python
class FromLastRunWindow(TimeWindow):
def __init__(self, *, clamp: bool = True, **kwargs):
super().__init__(**kwargs)
self._clamp = clamp
def __call__(self, execution_date: datetime, **context) -> Tuple[datetime, datetime]:
upper = datetime.max
if self._clamp:
upper = self._fix_date(execution_date)
task_instance = context.get('task_instance')
if task_instance is None or task_instance.previous_execution_date_success is None: # Raises here
return datetime.min, upper
return datetime.combine(task_instance.previous_execution_date_success.date(),
time(0, 0, 0, 0)), upper
```
This is an auxiliary function we use in various tasks, as follows:
```python
def python_operator_callable(execution_date, **context):
start, end = FromLastRunWindow()(execution_date, **context)
# Proceed with the tasks operations ...
```
Works fine with 1.10.15. Looking at the documentation (versions 1.10.15, 2.0.0 & 2.12) it seems the `TaskInstance.previous_execution_date_success` has simply been removed, without any deprecation notice. And the proper way to retrieve the same info is the new API @josh-fell used in is example (the `TaskInstance.get_previous_execution_date()` method)
So the question is more will this be a *wontfix*, forcing anyone depending on this to update their code or is it worth a PR ? Something more or less like:
```py
class TaskInstance(...):
@property
def previous_execution_date_success(self):
"""The execution_date of the instance of this of this task from latest succesful dag run.
.. deprecated:: 2.1.3
This property will be removed in Airflow 2.y.0
"""
warnings.warn('The `TasksInstance.previous_execution_date_success` has been deprecated '
'and will be removed in Airflow 2.y.0. Use '
'TaskInstance.get_previous_execution_date(state=State.SUCCESS)` instead.',
DeprecationWarning)
return self.get_previous_execution_date(state=State.SUCCESS)
```
--
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.
To unsubscribe, e-mail: commits-unsubscribe@airflow.apache.org
For queries about this service, please contact Infrastructure at:
users@infra.apache.org