chore: add abstraction for worker operations #9578
Draft
+503
−77
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
This PR introduces a pluggable hooks framework that abstracts Zero-related operations in the worker package, enabling Dgraph to run in embedded mode without a separate Zero process -- many "unit" tests that aren't reliant on a full networked cluster would be great candidates for the abstraction.
Motivation
To support embedded deployment scenarios where Dgraph runs as a library within another application or in testing, the tight coupling between the worker package and Zero network operations needed to be abstracted. This allows alternative implementations to provide UID assignment, timestamp allocation, and transaction coordination without requiring a running Zero cluster.
Changes
New Package:
hooks/Testing
-raceflag covering:Checklist
Conventional Commits syntax, leading
with
fix:,feat:,chore:,ci:, etc.