Skip to content

[FLINK-39769][tests][JUnit5 migration] Module: flink-examples-streaming#28496

Open
spuru9 wants to merge 1 commit into
apache:masterfrom
spuru9:FLINK-39769
Open

[FLINK-39769][tests][JUnit5 migration] Module: flink-examples-streaming#28496
spuru9 wants to merge 1 commit into
apache:masterfrom
spuru9:FLINK-39769

Conversation

@spuru9

@spuru9 spuru9 commented Jun 20, 2026

Copy link
Copy Markdown
Contributor

What is the purpose of the change

Migrate the remaining JUnit 4 tests in flink-examples/flink-examples-streaming to JUnit 5 (Jupiter). After this PR the module has zero JUnit 4 imports. Part of the umbrella JUnit 4 → 5 migration.

JIRA: FLINK-39769 (sub-task of FLINK-25325)

Brief change log

Three test classes migrated:

  • StreamingExamplesITCase and SocketWindowWordCountITCase (parameterized):
    • @RunWith(Parameterized.class)@ExtendWith(ParameterizedTestExtension.class).
    • @Parameterized.Parameter@Parameter; @Parameterized.Parameters@Parameters(name = ...).
    • @Test@TestTemplate (required for the parameterized extension).
    • extends AbstractTestBaseJUnit4extends AbstractTestBase (the JUnit 5 sibling).
    • org.junit.Assert.failorg.assertj.core.api.Assertions.fail (SocketWindowWordCountITCase).
  • TopSpeedWindowingExampleITCase:
    • @ClassRule MiniClusterWithClientResource@RegisterExtension static MiniClusterExtension.
    • @ClassRule TemporaryFolder@TempDir static File; newFile()/newFolder()new File(tempDir, ...).
    • Drop extends TestLogger; org.junit.Testorg.junit.jupiter.api.Test.
  • Drop public on test classes and methods per the Flink JUnit 5 Migration Guide.

No production code is touched.

Verifying this change

This change is a test-only migration covered by the existing tests it migrates:

./mvnw -pl flink-examples/flink-examples-streaming test \
  -Dtest='StreamingExamplesITCase,TopSpeedWindowingExampleITCase,SocketWindowWordCountITCase'

Result: 11 tests run, 0 failures, 0 errors, 0 skipped (StreamingExamplesITCase 8, SocketWindowWordCountITCase 2, TopSpeedWindowingExampleITCase 1), matching the pre-migration baseline.

Does this pull request potentially affect one of the following parts:

  • Dependencies (does it add or upgrade a dependency): (no)
  • The public API, i.e., is any changed class annotated with @Public(Evolving): (no)
  • The serializers: (no)
  • The runtime per-record code paths (performance sensitive): (no)
  • Anything that affects deployment or recovery: JobManager (and its components), Checkpointing, Kubernetes/Yarn, ZooKeeper: (no)
  • The S3 file system connector: (no)

Documentation

  • Does this pull request introduce a new feature? (no)
  • If yes, how is the feature documented? (not applicable)

Was generative AI tooling used to co-author this PR?
  • Yes — Claude Code

…examples-streaming

Migrate the remaining JUnit 4 tests in flink-examples-streaming to JUnit 5:

- StreamingExamplesITCase and SocketWindowWordCountITCase: replace
  @RunWith(Parameterized.class) with the Flink ParameterizedTestExtension
  (@ExtendWith + @Parameter/@Parameters/@testtemplate) and move the base class
  from AbstractTestBaseJUnit4 to AbstractTestBase.
- TopSpeedWindowingExampleITCase: drop TestLogger and replace the @ClassRule
  MiniClusterWithClientResource / TemporaryFolder with @RegisterExtension
  MiniClusterExtension and @tempdir.
- Convert the remaining org.junit.Assert.fail to AssertJ.
@flinkbot

flinkbot commented Jun 20, 2026

Copy link
Copy Markdown
Collaborator

CI report:

Bot commands The @flinkbot bot supports the following commands:
  • @flinkbot run azure re-run the last Azure build

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants