Skip to content

test(amber): add unit test coverage for Region#4568

Merged
aglinxinyuan merged 1 commit into
apache:mainfrom
aglinxinyuan:xinyuan-test-region-spec
Apr 30, 2026
Merged

test(amber): add unit test coverage for Region#4568
aglinxinyuan merged 1 commit into
apache:mainfrom
aglinxinyuan:xinyuan-test-region-spec

Conversation

@aglinxinyuan
Copy link
Copy Markdown
Contributor

What changes were proposed in this PR?

Add RegionSpec covering the public surface of Region (amber/src/main/scala/org/apache/texera/amber/engine/architecture/scheduling/Region.scala):

  • Constructor exposes physicalOps, physicalLinks, and ports via getOperators/getLinks/getPorts
  • getOperator(id) looks up by PhysicalOpIdentity and throws NoSuchElementException for unknown ids
  • topologicalIterator yields operators in topological order derived from physicalLinks
  • getSourceOperators treats operators without input ports as sources
  • getStarterOperators equals getSourceOperators when no resourceConfig is provided

Any related issues, documentation, discussions?

Closes #4567

How was this PR tested?

sbt "WorkflowExecutionService/testOnly org.apache.texera.amber.engine.architecture.scheduling.RegionSpec" — 9/9 tests pass.

Was this PR authored or co-authored using generative AI tooling?

Generated-by: Claude Code (Claude Opus 4.7)

### What changes were proposed in this PR?

Add `RegionSpec` covering the public surface of `Region`:

- Constructor exposes `physicalOps`, `physicalLinks`, and `ports` via
  `getOperators`/`getLinks`/`getPorts`
- `getOperator(id)` looks up by `PhysicalOpIdentity` and throws
  `NoSuchElementException` for unknown ids
- `topologicalIterator` yields operators in topological order derived
  from `physicalLinks`
- `getSourceOperators` treats operators without input ports as sources
- `getStarterOperators` equals `getSourceOperators` when no
  `resourceConfig` is provided

### Any related issues, documentation, discussions?

Closes apache#4567

### How was this PR tested?

`sbt "WorkflowExecutionService/testOnly org.apache.texera.amber.engine.architecture.scheduling.RegionSpec"` — 9/9 tests pass.

### Was this PR authored or co-authored using generative AI tooling?

Generated-by: Claude Code (Claude Opus 4.7)

Co-authored-by: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
@aglinxinyuan aglinxinyuan merged commit aec0009 into apache:main Apr 30, 2026
19 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

add unit test coverage for Region

2 participants