testcontainers/testcontainers-java

InternalCommandPortListeningCheck always fails for containers built without `/bin/sh`

Open

#3,317 建立於 2020年10月11日

在 GitHub 查看
 (5 留言) (7 反應) (0 負責人)Java (7,535 star) (1,588 fork)batch import
help wantedtype/bug

描述

Relates to #2984

I'm surprised we've not come across this earlier, but the default TCP port listening detector InternalCommandPortListeningCheck does not work for containers that do not have /bin/sh included.

This predominantly affects images built upon scratch.

The workaround/solution is to use a more application specific WaitStrategy - e.g. an HTTP wait strategy.

However the log messages don't make this easy to realise.

Given that we do both the internal and external port checks for a good reason, I don't think we can just rely on the external port check. Still perhaps we can raise a very specific error message if /bin/sh is not available inside the container.

貢獻者指南

InternalCommandPortListeningCheck always fails for containers built without `/bin/sh` · testcontainers/testcontainers-java#3317 | Good First Issue