Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

  • To assign an available port, call AvailablePortHelper or AvailablePort. These are the only classes that know about the reduced port range for the test.
  • Call AvailablePort and AvailablePortHelper only in the current version of Geode. Do not call these classes in Child VMs running older versions of Geode. Older versions of Geode do not honor the new, reduced port ranges.
  • Do not launch any service using Geode’s default port for that service. Always explicitly assign an available port. The only safe use of default ports is in a test to verify that a service uses its default port by default. Note that such a test will fail the stress test CI job. To exclude such a test from the stress test job, annotate it with @Category(IgnoreInRepeatTestTasks.class).
  • Do not launch any service using a port number hard-coded into the test. Always explicitly assign an available port. There is no safe use of any hard-coded port number in tests that can run concurrently.
  • Do not attempt to reuse an ephemeral port. Some tests start a member on an ephemeral port, stop the member, and attempt to restart it on the same port. This is not safe. It was never safe. During the time between when the member stops and when it restarts, the port is available for the operating system to give to any other process. In CI, it is very, very likely that one or more concurrently-running tests (or other processes) will request ephemeral ports during the time when your test is not bound to it. If one of those processes gets the port your test was using, your test will fail.

...