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:
us...@infra.apache.org


With regards,
Apache Git Services

Reply via email to