You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
flink/flink-end-to-end-tests
danrtsey.wy 67eaddb93f [hotfix] Refactor test_yarn_kerberos_docker.sh by moving common functions to common_yarn_docker.sh. 5 years ago
..
flink-batch-sql-test [FLINK-13441][e2e] Add e2e test for SQL batch job 6 years ago
flink-bucketing-sink-test [FLINK-9782][e2e] Harden bucketing sink e2e test. 6 years ago
flink-cli-test Update version to 1.10-SNAPSHOT 6 years ago
flink-confluent-schema-registry [FLINK-13794][client] Remove unused logic of printStatusDuringExecution 5 years ago
flink-connector-gcp-pubsub-emulator-tests Update version to 1.10-SNAPSHOT 6 years ago
flink-dataset-allround-test Update version to 1.10-SNAPSHOT 6 years ago
flink-dataset-fine-grained-recovery-test [FLINK-13145][runtime, tests] Enable fine grained failover in E2E HA data set test 6 years ago
flink-datastream-allround-test Update version to 1.10-SNAPSHOT 6 years ago
flink-distributed-cache-via-blob-test Update version to 1.10-SNAPSHOT 6 years ago
flink-e2e-test-utils Update version to 1.10-SNAPSHOT 6 years ago
flink-elasticsearch2-test [FLINK-13794][client] Remove unused logic of printStatusDuringExecution 5 years ago
flink-elasticsearch5-test [FLINK-13794][client] Remove unused logic of printStatusDuringExecution 5 years ago
flink-elasticsearch6-test [FLINK-13794][client] Remove unused logic of printStatusDuringExecution 5 years ago
flink-elasticsearch7-test [FLINK-13025] Elasticsearch 7.x support 5 years ago
flink-end-to-end-tests-common Update version to 1.10-SNAPSHOT 6 years ago
flink-heavy-deployment-stress-test Update version to 1.10-SNAPSHOT 6 years ago
flink-high-parallelism-iterations-test [FLINK-13794][client] Remove unused logic of printStatusDuringExecution 5 years ago
flink-local-recovery-and-allocation-test Update version to 1.10-SNAPSHOT 6 years ago
flink-metrics-availability-test Update version to 1.10-SNAPSHOT 6 years ago
flink-metrics-reporter-prometheus-test Update version to 1.10-SNAPSHOT 6 years ago
flink-parent-child-classloading-test-lib-package Update version to 1.10-SNAPSHOT 6 years ago
flink-parent-child-classloading-test-program Update version to 1.10-SNAPSHOT 6 years ago
flink-plugins-test [FLINK-14382][e2e] Add another dummy fs for e2e test. It is same as dummy fs with different schema. 5 years ago
flink-queryable-state-test Update version to 1.10-SNAPSHOT 6 years ago
flink-quickstart-test [FLINK-13794][client] Remove unused logic of printStatusDuringExecution 5 years ago
flink-sql-client-test Update version to 1.10-SNAPSHOT 6 years ago
flink-state-evolution-test Update version to 1.10-SNAPSHOT 6 years ago
flink-stream-sql-test [FLINK-13439] Run Streaming SQL e2e test with blink planner 6 years ago
flink-stream-state-ttl-test Update version to 1.10-SNAPSHOT 6 years ago
flink-stream-stateful-job-upgrade-test Update version to 1.10-SNAPSHOT 6 years ago
flink-streaming-file-sink-test Update version to 1.10-SNAPSHOT 6 years ago
flink-streaming-kafka-test Update version to 1.10-SNAPSHOT 6 years ago
flink-streaming-kafka-test-base [FLINK-13794][client] Remove unused logic of printStatusDuringExecution 5 years ago
flink-streaming-kafka010-test Update version to 1.10-SNAPSHOT 6 years ago
flink-streaming-kafka011-test Update version to 1.10-SNAPSHOT 6 years ago
flink-streaming-kinesis-test Update version to 1.10-SNAPSHOT 6 years ago
flink-tpch-test [hotfix] Add relativePath to flink-tpch-tests module 6 years ago
test-scripts [hotfix] Refactor test_yarn_kerberos_docker.sh by moving common functions to common_yarn_docker.sh. 5 years ago
.gitignore [FLINK-8983] Integrate test_confluent_schema_registry.sh into run-nightly-tests.sh 7 years ago
README.md [FLINK-12590][docs] Use HTTPS for all Flink links 6 years ago
pom.xml [FLINK-13025] Elasticsearch 7.x support 5 years ago
run-nightly-tests.sh [FLINK-12746][docs] Add DataStream API Walkthrough 5 years ago
run-pre-commit-tests.sh [FLINK-13528][kafka] Disable tests failing on Java 11 5 years ago
run-single-test.sh [FLINK-10678][e2e] Introduced switch to disable log checking in e2e tests 6 years ago

README.md

Flink End-to-End Tests

This module contains tests that verify end-to-end behaviour of Flink. We categorize end-to-end tests as either pre-commit tests or nightly tests. The former should be run on every commit, that is every Travis run, while the second category should be run by a nightly job or when manually verifying a release or making sure that the tests pass.

Tests in the pre-commit category should be more lightweight while tests in the nightly category can be quite heavyweight because we don't run them for every commit.

Running Tests

You can run all pre-commit tests by executing

$ FLINK_DIR=<flink dir> flink-end-to-end-tests/run-pre-commit-tests.sh

and all nightly tests via

$ FLINK_DIR=<flink dir> flink-end-to-end-tests/run-nightly-tests.sh

where <flink dir> is a Flink distribution directory.

You can also run tests individually via

$ FLINK_DIR=<flink dir> flink-end-to-end-tests/run-single-test.sh your_test.sh arg1 arg2

NOTICE: Please DON'T run the scripts with explicit command like sh run-nightly-tests.sh since #!/usr/bin/env bash is specified as the header of the scripts to assure flexibility on different systems.

Streaming bucketing test

Before running this nightly test case (test_streaming_bucketing.sh), please make sure to run mvn -DskipTests install in the flink-end-to-end-tests directory, so jar files necessary for the test like BucketingSinkTestProgram.jar could be generated.

What's more, starting from 1.8.0 release it's required to make sure that HADOOP_CLASSPATH is correctly set or the pre-bundled hadoop jar has been put into the lib folder of the FLINK_DIR (You can find the binaries from the Downloads page on the Flink project site).

Kubernetes test

Kubernetes test (test_kubernetes_embedded_job.sh) assumes a running minikube cluster.

Writing Tests

Examples

Have a look at test_batch_wordcount.sh for a very basic test and test_streaming_kafka010.sh for a more involved example. Whenever possible, try to put new functionality in common.sh so that it can be reused by other tests.

Adding a test case

In order to add a new test case you need add it to either test-scripts/run-nightly-tests.sh and / or test-scripts/run-pre-commit-tests.sh. Templates on how to add tests can be found in those respective files.

Note: If you want to parameterize your tests please do so by adding multiple test cases with parameters as arguments to the nightly / pre-commit test suites. This allows the test runner to do a cleanup in between each individual test and also to fail those tests individually.

Note: While developing a new test case make sure to enable bash's error handling in test-scripts/common.sh by uncommenting set -Eexuo pipefail and commenting the current default set call. Once your test is implemented properly, add set -Eeuo pipefail on the very top of your test script (before any common script).

Passing your test

A test is considered to have passed if it:

  • has exit code 0
  • there are no non-empty .out files (nothing was written to stdout / stderr by your Flink program)
  • there are no exceptions in the log files
  • there are no errors in the log files

Note: There is a whitelist for exceptions and errors that do not lead to failure, which can be found in the check_logs_for_errors and check_logs_for_exceptions in test-scripts/common.sh.

Please note that a previously supported pattern where you could assign a value the global variable PASS to have your tests fail is not supported anymore.

Cleanup

The test runner performs a cleanup after each test case, which includes:

  • Stopping the cluster
  • Killing all task and job managers
  • Reverting conf and lib dirs to default
  • Cleaning up log and temp directories

In some cases your test is required to do some additional cleanup, for example shutting down external systems like Kafka or Elasticsearch. In this case you can register a function that will be called on test exit like this:

function test_cleanup {
    # do your custom cleanup here
}

on_exit test_cleanup