Open amirabiri opened 5 years ago
Hi @amirabiri,
We're aware of that problem. Some old time ago, a decision was made to fail fast if image fails to resolve.
We do plan to change it to resolve on start, but delayed it until 2.x. Although we could do it sooner, e.g. as part of #1345, see this conversation: https://github.com/testcontainers/testcontainers-java/pull/1345#discussion_r270116389
We do plan to change it to resolve on start, but delayed it until 2.x. Although we could do it sooner, e.g. as part of #1345
Yes, I think we can and should
Any progress on this? I would never have been able to solve my problem without reading @amirabiri's comment.
Hello,
It looks like #1345 did not change the policy on image resolution and based on the 2.x milestone activity, 2.x seems to have been stalled for around 5 years.
Are there any recent plans regarding this issue ?
thanks,
In certain cases a test may fail with a NoClassDefFoundError, and it's a nightmare to find the real error.
For example:
Then running
gradle test
results in:To find out the actual error, it was necessary to run Gradle with
--info
. I only used a bad image name here as an example to reproduce - the real error was "Docker environment should have more than 2GB free disk space", and it happened only on the CI build agent - so this was a real nightmare to diagnose!What makes this even more difficult to pin down is the fact that even removing the
@Testcontainers
and@Container
still results in the exact same behaviour!The reason for all of this, is the fact that
GenericContainer
's constructor callsthis.setDockerImageName()
which in turn callsgetDockerImageName()
which actually attempts to get the image: https://github.com/testcontainers/testcontainers-java/blob/master/core/src/main/java/org/testcontainers/containers/GenericContainer.java#L1057IMO this is an action that should not take place in a constructor - this should happen only later during
start()
. Either way there ought to be some better solution, because diagnosing errors this way is a nightmare.