Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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
Respect TTL of a DNS record for proxy config #5960
base: main
Are you sure you want to change the base?
Respect TTL of a DNS record for proxy config #5960
Changes from 12 commits
417bf3b
3681f0f
f57259c
f40cbe4
a26e3f5
649469e
ab43277
a6e725c
e0819c4
0b3cc2b
54ec6f3
a67ee3f
241b4ff
fce4fd2
7d85a69
67f4997
e775351
18b24ea
979e6fd
3dbc847
fcfed45
09efa86
25ff1af
43212b6
195033f
d1c9596
d5c8326
1240a24
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
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 would be efficient if we could skip the resolution process if
proxyConfig.proxyAddress()
was created with IP addresses.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.
I didn't understand this case - are you concerned that the resolution succeeds but the
InetAddress
does not exist?Would it make sense to just align error handling with dns resolution for the normal code path (not using proxy)?
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.
Thanks for your comments!
After take a look
RefreshingAddressResolver
,RefreshingAddressResolver
returnsInetSocketAddress
when succeed.As you mentioned before, it is unnecessary codes.
Therefore, I delete this codes.
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.
nit; it may make more sense to throw an exception instead
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.
The input is ignored.
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.
This comment wasn't addressed. Was it intended? Let me know if I'm missing something or misunderstood.
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.
I'm really sorry about this. 🙇♂️
I missed it.
Now, I fixed it!
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.
nit; I believe that currently only resolved
InetSocketAddress
can be used to create aProxyConfig
.Can you add some integration tests to confirm the current code works correctly?
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.
@jrhee17 Thanks for your comments. 🙇♂️
I added two integration test codes for this feature.
Due to restrictions on mocking, narrow
Access specifier
, I couldn't use aspy
instance to validate it or injectDNSResolver
as well.That's why I made a new class called
DNSResolverFacadeUtils
class 😅 .As @minwoox mentioned, we don't need to check if
InetSocketAddress
is resolved, since it will be resolved whenHttpClientDelegate
callsexecute()
. After removingcheckArgument(...)
, I was finally able to write some integration test cases... 😅When you have time, please take another look. 🙇♂️