Skip to content
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

bug: fix leaking logs #2912

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

KenxinKun
Copy link

What does this PR do?

Adds a new non-breaking option func (hp *HostPortStrategy) WithLogger(logger Logging) *HostPortStrategy.

Why is it important?

The linked issue identified leaking logs when waiting for exposed/listening ports. The proposed implementation preserves the current behaviour when not providing the option.

Related issues

How to test this PR

New unit tests are included using mock implementations of the logger interface.

Follow-ups

Consider if the proposed implementation aligns well with the current designs for a centralised logger. I could not import the testcontainers.Logging interface due to circular import dependencies, so I had to define a local targeted interface.

@KenxinKun KenxinKun requested a review from a team as a code owner December 6, 2024 15:25
Copy link

netlify bot commented Dec 6, 2024

Deploy Preview for testcontainers-go ready!

Name Link
🔨 Latest commit fb9eeda
🔍 Latest deploy log https://app.netlify.com/sites/testcontainers-go/deploys/6753176427cd670008189887
😎 Deploy Preview https://deploy-preview-2912--testcontainers-go.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

@KenxinKun KenxinKun changed the title [bug] fix leaking logs bug fix leaking logs Dec 6, 2024
@KenxinKun KenxinKun changed the title bug fix leaking logs bug: fix leaking logs Dec 6, 2024
@mdelapenya
Copy link
Member

Hi @KenxinKun thanks for the fix. I'd go with the default testcontainers.Logger instead, so the eventual refactor of the logging system that @stevenh and I are going to tackle would be easier. It's true that enabling passing a custom logger to this wait strategy would make it, but I wonder if this would need to be applied to any other wait strategy. For that reason, I'd ask you to change the current impl, and simply delegate to the default logger. But I'd like to listen to your opinion fist.

@stevenh
Copy link
Collaborator

stevenh commented Dec 10, 2024

I'm wondering if this is another case for where having the default client and the ability to configure it with things like a logger could be way to go @mdelapenya as I suspect it's unlikely you want a separate logger for different strategies?

@mdelapenya
Copy link
Member

it's unlikely you want a separate logger for different strategies

Indeed, that's what I think too. @KenxinKun if we change this PR to avoid a custom logger for the wait strategy, using the library's built-in (and to be changed soon) logging infra, then this would be ready to merge. Thanks!

@KenxinKun
Copy link
Author

Sure no problem it makes sense, I'll try to change it tomorrow.
For my own use case through which I discovered the bug I'd have preferred the single logger indeed.

I'm not at my laptop to check now, but I recall having an import circular dependency importing from the parent testcontainers directory. I'll double check tomorrow if it's the same case here or not but if it is, should I try to untangle it?

@KenxinKun
Copy link
Author

Yeah as I suspected the wait package is imported here (at least) https://github.com/testcontainers/testcontainers-go/blob/main/container.go
so unless we remove that import we won't be able to import testcontainers.Logger for the wait strategy...

@KenxinKun
Copy link
Author

Morning! So I just tried briefly to untangle this but there's a significant number of uses of the wait package in the top testcontainers package. At first I thought it was just interfaces (primarily wait.Strategy and from the response of that one also wait.StrategyTarget), but there's also direct uses of wait.ForAll, wait.ForListeningPort and wait.ForExposedPort which complicates a possible refactoring 🤔

Thoughts:

  • If it was just the interfaces I would have moved them to the top testcontainers package, and added an alias inside the wait package with a deprecation note (i.e. keep the "core" interfaces in the top package)
  • The use of specific implementations of Strategy as listed above makes this difficult since it seems obvious we want to keep those implementations inside wait
  • So without doing some likely problematic breaking changes it feels difficult to just import testcontainers.Logger into wait... The current implementation at least allows an injection but is it possible to move the logger to its own package? That would allow importing from elsewhere. For current definitions in the top package, perhaps type aliases would do the trick?

Let me know your thoughts @mdelapenya and @stevenh before I make further changes

@mdelapenya
Copy link
Member

@KenxinKun sorry for making you going in circles with the wait and core packages 🤦 Indeed, the core uses wait so not possible.

What you suggested about having a logger makes sense, and we do have it in our backlog for an eventual v1 work, please see https://github.com/orgs/testcontainers/projects/13/views/1?filterQuery=log&pane=issue&itemId=87805987.

If you're interested in helping out with that, please let us know, as @stevenh would like to tackle the work on a more consistent logger, and you could collaborate in doing that.

@KenxinKun
Copy link
Author

Sure happy to help, we use this library so much!

@KenxinKun
Copy link
Author

@mdelapenya @stevenh apologies I had a crazy last month but I have time now to collaborate on that centralised logger, how should I proceed to work on v1? Just pull the latest v1 tag on a new PR or do we need a side chat first?

@stevenh
Copy link
Collaborator

stevenh commented Jan 22, 2025

Busy here too, so not had much time to work on Open Source this month.

What I need to do is flesh out some protoypes to see how client, logging and other components tie together.

@KenxinKun
Copy link
Author

@stevenh cool just let me know what you need :)

@mdelapenya
Copy link
Member

@KenxinKun @stevenh, also busy here at the moment with conferences, will be back to routine next week. In any case, super proud of your humble contributions, thank you both.

@KenxinKun please disregard fetching the v1 branch, it's there for reference of what we want to achieve, but that branch is not up-to-date anymore, so take it as this: "some" of the things in that branch could land into main, but started from main.

Said that, if you can work on the central logger, let's start from main/scratch. And feel free you both to talk on what to work next, on our Slack, on a GH discussion for a design doc, or I can even setup a sync zoom/slack session for initial coordination before the async work. Whatever works.

@KenxinKun
Copy link
Author

Sure can you add me to the Slack workspace @mdelapenya ? (email on my profile is good)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Bug]: Leaking logs despite configuring loggers
3 participants