Ashish0253 commented on code in PR #62688:
URL: https://github.com/apache/airflow/pull/62688#discussion_r2955880740


##########
airflow-core/src/airflow/models/deadline.py:
##########
@@ -482,6 +478,36 @@ def deserialize_reference(cls, reference_data: dict):
                 min_runs=min_runs,
             )
 
+    class JobStartDateDeadline(BaseDeadlineReference):
+        """A deadline that returns the start date of the latest active 
SchedulerJob."""
+
+        # By setting this to an empty set, we tell the system this reference
+        # doesn't need an 'id' or any other data from the DAG definition.
+        required_kwargs: set[str] = set()
+
+        def _evaluate_with(self, *, session: Session, **kwargs: Any) -> 
datetime | None:
+            """Find the start date of the most recently started running 
SchedulerJob."""
+            from sqlalchemy import desc
+
+            from airflow.jobs.job import Job
+
+            # We query the job table directly for the newest SchedulerJob that 
is still 'running'.
+            # This ensures we are always measuring against the current active 
platform engine.
+            stmt = (
+                select(Job.start_date)
+                .where(
+                    Job.job_type == "SchedulerJob",
+                    Job.state == "running",
+                )
+                .order_by(desc(Job.start_date))
+                .limit(1)
+            )

Review Comment:
   thanks for the help 
   in airflow-core/src/airflow/serialization/definitions/deadline.py - 
_fetch_from_db function is indeed hardcoded to run_id and dag_id
   
   ```
   def _fetch_from_db(column, *, session: Session, dag_id: str, run_id: str) -> 
datetime | None:
   ```
   
   should i make changes here too ?



-- 
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: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]

Reply via email to