seelmann commented on a change in pull request #3596: [AIRFLOW-2747] Explicit
re-schedule of sensors
URL: https://github.com/apache/incubator-airflow/pull/3596#discussion_r219044092
##########
File path: airflow/models.py
##########
@@ -1744,6 +1749,29 @@ def dry_run(self):
self.render_templates()
task_copy.dry_run()
+ @provide_session
+ def handle_reschedule(self, reschedule_exception, test_mode=False,
context=None,
+ session=None):
+ self.end_date = timezone.utcnow()
+ self.set_duration()
+
+ # Log reschedule request
+ session.add(TaskReschedule(self.task, self.execution_date,
self._try_number,
+ self.start_date, self.end_date,
+ reschedule_exception.reschedule_date))
+
+ # set state
+ self.state = State.NONE
+
+ # Decrement try_number so subsequent runs will use the same try number
and write
+ # to same log file.
+ self._try_number -= 1
+
+ if not test_mode:
+ session.merge(self)
+ session.commit()
Review comment:
I changed it to skip reschedule handling completely when in `test_mode`,
added test and verified behaviour via command line.
Regarding the first question regarding exception handing and rollback,
that's is covered by the `@provide_session` decorator around.
----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on GitHub and use the
URL above to go to the specific comment.
For queries about this service, please contact Infrastructure at:
[email protected]
With regards,
Apache Git Services