-
-
Notifications
You must be signed in to change notification settings - Fork 511
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Improve Podman compatibility #414
Improve Podman compatibility #414
Conversation
I just noticed there's also #407 which also adds |
Hey @baez90 thanks again for the PR and the explanation to add context and motivation for it. It makes a difference in the review process. I think #407 is super simple and straight forward, so we could merge that PR first and then rebase your code with that. Does it makes sense to you? |
Sure thing, I think I've already an idea how to incorporate the changes from #407 with my own 😊 Glad to hear the descriptions are getting a bit better, I'm still learning but I've to admit that I really like the idea! |
One thing that I'd like you to explore before merging this PR is the idea of running the entire test suite using podman instead of Docker. Do you want to contribute a Github Action workflow specific to it? |
Interesting idea. I'll have a look into it how much I'd have to adjust in the current test suite to make this possible. Edit: at some point it might be necessary to detect if Podman or Docker is used...would you see that rather in the test suite or in the library code? I'd probably rather adopt the tests to cover some Podman specifics than making the |
The java folks have a PoC for Podman here: testcontainers/testcontainers-java#4583 |
awesome! Thanks for letting me know! |
That would be great to have this PR merged :) |
I'm still both waiting for #407 to be merged and working on some improvements (as soon as I can spare some time) to - hopefully - run tests against Podman in the CI - although I'm still not sure if I'll be able to make it 100% compatible. Sorry for the delay I think I should be able to work on this tomorrow 😊 |
1583528
to
da54e7b
Compare
Codecov Report
@@ Coverage Diff @@
## main #414 +/- ##
==========================================
+ Coverage 65.61% 66.92% +1.31%
==========================================
Files 19 20 +1
Lines 1201 1823 +622
==========================================
+ Hits 788 1220 +432
- Misses 305 483 +178
- Partials 108 120 +12
Continue to review full report at Codecov.
|
32897fb
to
037f878
Compare
@mdelapenya now that the pipeline does not fail anymore I'd consider this done. Let me know if I shall split this PR or anything else. I also updated the description to cover the latest changes. I know that some tests in the Podman pipeline are still a bit flaky but I'd like to wait until Podman 4.x is ready for Ubuntu and revisit the pipeline then once more? |
RC1 for Podman 4.1 mentions a fixed but that resolves the requirement to always set a bridge network for Podman containers because now the bridge network is assigned automatically again. Does anyone know if the work around to add a new container at first to the @mdelapenya any thoughts? How do you like to proceed with this PR and #407 ? |
I just got the update to Podman 4.1 and it seems like the issue with the missing default network is now resolved. I probably could get rid of some code but the question is do we want to rely for Podman users to have the latest version or shall we test also against a 3.x version? @mdelapenya any thoughts? |
037f878
to
21d8636
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hey @baez90 this is great and the code LGTM! Thank you very much for your time and dedication to support Podman.
I'll be honest: I need time to download the PR and play with Podman as I never did it in the past.
But the tests seems OK, which is a great step. Let me play with this version of the PR, and hopefully soon we will see this baby merged into the code.
Good job!
a9c2557
to
3b17b33
Compare
Thank you very much for taking your time to review the PR and giving me feedback and everything! From my side most things are done now. I've been thinking of removing the Podman provider again but without it the default network detection is still problematic.I don't really know if the special behavior to join a new container always to the The current implementation works quite good with Podman 4.1. There are some tests still failing but those are not directly related to the Podman API compatibility but to the fact that Podman does not really handle a lot of parallel container operations really good (no daemon, file system locks for the BoltDB...). I raised an issue for the Docker API version problem, let's see what's coming from them but it shouldn't be a blocker for now I guess? I'd like to add that not all changes I made are only necessary for Podman but also come in handy if someone's using Docker rootless (e.g. mounting the right socket to the reaper not always Let me know if you encounter any problems or if I should change some things 😊 |
3b17b33
to
1cdb5b3
Compare
1ecd98d
to
64af8fe
Compare
@mdelapenya unfortunately I cannot reproduce your issue with Podman on Windows. I tuned the CI pipeline to install Podman 4.1 from Debian experimental (still no Podman 4 for Ubuntu 20.04 or 22.04) and it seems as this would work now as expected including running tests in parallel and without any 'continue on error' setting in place. Apart from some more experiments with Podman on Windows I'd say this actually looks quite good from my side, what do you think? |
@mdelapenya is there something missing here? Of course I'll rebase this PR once more if the other PR is merged. But at some point I'd really appreciate it to get this either merged or I'll close it as there seems to be no interest in this. I don't see any sense investing more time in keeping this up to date without any further progress/feedbackq on how to go on with this PR. |
We merged a PR regarding LogConsumer yesterday and caused the conflicts. Could you resolve them 🙏
@baez90 please forgive me. It IS of interest and I do appreciate your hard effort in contributing it. I shared my concerns about not being able to make it work on my machine, but it does not mean it's of no interest. I've been focused on smaller PRs with lower impact and less time to review. Your PR represents the big star for the new release and I'd like to create a great experience using TC-go with Podman. So please please do not hesitate about the importance of your contributions. Sometimes maintainers need to juggle with company work, family time and open source 😞 |
- allow configuring the default network name - it's podman for Podman instead of bridge and 'bridge' is not a valid network name with Podman - allow configuring an alternative Docker socket path for the reaper - this is also useful for rootless Docker
…c defaults Set provider type for all docker_test.go test cases
Failures during test execution are ignored for now. Passing all tests can be achieved over time.
64af8fe
to
fb47fba
Compare
@baez90 I'd appreciate not pushing-force with every commit submission 🙏, as the mental effort of having to review the entire PR again after a push, instead of reviewing the incoming delta, is also exhausting 😔 Please don't get me wrong, it may be a personal preference, as I've seen this style in many other places. And as there are no contributing guidelines yet, is totally fine I'm now AFK but will try my best with this PR ASAP |
@mdelapenya I didn't change anything I only rebased the branch to resolve conflicts 😉 Regarding your concern testing the PR on MacOS: like I mentioned earlier I had similar problems running the test suite on Windows with Podman Machine due to limitations especially with the reaper because I couldn't find any possibility to mount native Windows pipes as Linux socket into the ryuk conainer. But other tests were running. I don't have access to a Mac so I can't say if there are similar problems to be expected with the way Podman is working on MacOS. I already added the retry logic you mentioned in another PR (I think) to the Podman pipeline and I'm thinking of doing the same for the Docker pipeline as the last checks didn't even fail in code I touched 😅 (from what I can tell) and also only for Docker not for Podman... Apart from that the main change is actually only how the default network is handled to ensure Docker gets its I'm also sorry for the probably a bit harsh words earlier. It just happened to be a little bit frustrating. |
ComposeVersion allows to format service names, volume names,... compatible to the installed docker-compose version. Also parallel execution of tests is removed again as it makes more trouble than it helps, apparently.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It took a while, and sorry about that. I see you when you expressed your frustration, and as a maintainer it's my mission to keep you engaged, even more after this huge and fantastic contribution. Really well done
@gianarb I'd appreciate a final review before merging this one 🙏 |
This PR is a tremendous effort but it has everything it needs! Testing, a new set of CI jobs. For me it can be merged! Thanks |
What does this PR do?
Although Podman claims to be API compatible with Docker and for instance in #336 the consent seems to be let's wait until all problems are gone 😅 I thought I'd see what can be done as kind of a compromise.
The problems I could identify (and solve) are:
bridge
which isn't the case for Podman. Even worse,bridge
is not even a valid network name with Podman because it's also a network mode and Podman does not allow the creation of networks conflicting with network modes.DOCKER_HOST
env variable nor any other customization the testcontainers docs are describing are honored. This is also an issue with rootless Docker.stdout
and/orstderr
but otherwise it breaks the exec wait strategy.DefaultNetwork
optionThe
DefaultNetwork
option allows Podman users to configure the name of the default network. If it's not set the previous auto-detection is applied so no breaking change.PodmanProvider
provider typePodman does not allow ambiguities between network mode names and network names therefore the default Podman network is called
podman
unlike thebridge
network of Docker.To be able to detect both cases without a breaking change the second
ProviderType
was introduced. Current test implementations will just behave like before but with this addition users of testcontainers-go can either explicitly set the provider type or setup aGenericProvider
to their likes and use that one.Honoring
DOCKER_HOST
andTESTCONTAINERS_DOCKER_SOCKET_OVERRIDE
The
DOCKER_HOST
env variable was already considered when creating the Docker API client. Now its value is propagated (via thecontext.Context
) to the reaper as a fallback ifTESTCONTAINERS_DOCKER_SOCKET_OVERRIDE
isnt' set. If both env variables are empty the default socket path/var/run/docker.sock
will be assumed.Default
NetworkMode
if not setIn cases when the
NetworkMode
isn't set it will be set tobridge
to avoid issues with Podman. Docker apparently assumesbridge
if nothing's set therefore this shouldn't break anything either.Parallel tests
To speed up the test suite I marked as many tests as possible to be executed in parallel. Some tests (like the one running in host mode) cannot be executed in parallel because that would result in port conflicts.
Compatibility state
Almost all tests are now compatible with Podman. Some are skipped because they are not compatible with Podman in rootless mode but this would be the same for Docker rootless.
Some
docker-compose
tests are failing in the CI pipeline with Podman 3.x but are running on my local machine with Podman 4.x so I assume they will be compatible eventually.Changes in test suite
Add Podman pipeline
As stated by @mdelapenya testcontainers-java has a PoC of a Podman pipeline that I 'borrowed' 😄
They are installing Podman 3.x in rootless mode which has some consequences:
compose_test.go
docker
CLI. This way validations are also possible against the Podman API.<identifier>-<service-name>-<instance-count>
vs<identifier>_<service-name>_<instance-count>
by filtering with regular expressionscontainer_test.go
Use full qualified image names (e.g.
docker.io/alpine
) because some Podman distributions do not fallback todocker.io
by default and this way the container image registry becomes explicit.logconsumer_test.go
Skip test that cannot be executed with rootless Podman because it depends on Docker-in-Docker
docker_test.go
docker.io/nginx:alpine
where possiblehost
mode tests to be able to test them with rootless Podmandefer
calls with*testing.T.Cleanup()
bridge
vs.podman
testresources
docker-compose
filesI'm deeply sorry about the total size of the PR. If you have a good idea how to split it into different parts I will look into it! Some parts are for sure not necessary but I thought it would be good for example to unify how images are referenced, how containers are cleaned in test cases any many things more I stumbled upon while I was trying to get all tests working.
Also updating all GitHub actions could be moved to another PR but adding a new pipeline with outdated actions seemed weird and having different versions of the actions in different pipelines too so I also unified that 😅
Let me know what you think and I'm sure we can figure out something 😊