vatsrahul1001 opened a new pull request, #64625:
URL: https://github.com/apache/airflow/pull/64625

   ## Summary
   Fix asset watcher triggers being deleted and recreated on every dag-parsing 
loop.
   `encode_trigger` wraps kwargs with `BaseSerialization.serialize()` (e.g., 
`tuple()` becomes
   `{"__type": "tuple", "__var": []}`), which is correct for JSON-serializable 
DAG definitions.
   However, `add_asset_trigger_references` needs raw Python kwargs because 
`Trigger._decrypt_kwargs`
   returns native Python objects from the DB. This mismatch caused 
`BaseEventTrigger.hash()` to
   produce different hashes for the same logical trigger, resulting in an 
infinite delete/recreate
   cycle every parsing loop.
   Replace `encode_trigger` with `_get_raw_trigger_kwargs` that unwraps any 
BaseSerialization-encoded
   values back to native Python objects, ensuring hash consistency between 
DAG-defined and DB-stored
   triggers. `encode_trigger` remains in use where it belongs — DAG 
serialization for JSON storage.
   
   
   - [X] Yes (please specify the tool below)
   Claude
   
   * Read the **[Pull Request 
Guidelines](https://github.com/apache/airflow/blob/main/contributing-docs/05_pull_requests.rst#pull-request-guidelines)**
 for more information. Note: commit author/co-author name and email in commits 
become permanently public when merged.
   * For fundamental code changes, an Airflow Improvement Proposal 
([AIP](https://cwiki.apache.org/confluence/display/AIRFLOW/Airflow+Improvement+Proposals))
 is needed.
   * When adding dependency, check compliance with the [ASF 3rd Party License 
Policy](https://www.apache.org/legal/resolved.html#category-x).
   * For significant user-facing changes create newsfragment: 
`{pr_number}.significant.rst`, in 
[airflow-core/newsfragments](https://github.com/apache/airflow/tree/main/airflow-core/newsfragments).
 You can add this file in a follow-up commit after the PR is created so you 
know the PR number.
   


-- 
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