-
Notifications
You must be signed in to change notification settings - Fork 3.9k
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
gcp-observability: Fixed slowness for GcpObservabilityTest.enableObservability test case #11783
base: master
Are you sure you want to change the base?
Conversation
….enableObservability test case.
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.
If this is the problem then should we do same in line 233 in original code or 236 after your commit as well? It has the same try-with-resource block usage and I don't see anywhere in grpc-java anything similar like this.
As I have observed, enabling observability requires initializing certain things and classes, which makes the task within the try-with-resources block take longer. However, when observability is disabled, I did not observe many initializations in the test cases at lines 233 and 236, so I refactored the code to use a traditional try-catch block instead. |
You just don't close? No, we need to clean up and we want to test cleanup. Without close() we will leak resources and probably threads, and we don't want those running during other tests. |
I’m working on this and plan to implement a close() method with a configurable sleep time. After the test finishes, the close() method will be called with a shorter sleep duration to speed up the cleanup process. |
That sounds fine; just make the new method package-private. |
….enableObservability test case.
As per the suggestions above, I have pushed the latest changes, which include the addition of a new close method with sleep time. After executing the test case, I found that the execution time is now under 5 seconds. Could you please review the changes. |
@@ -146,6 +146,21 @@ public void close() { | |||
} | |||
} | |||
|
|||
public void closeWithSleepTime(long sleepTime) { |
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.
please add the missing doc comments for this method.
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.
Resolved
gcpObservability.closeWithSleepTime(sleepTime); | ||
verify(sink).close(); | ||
} | ||
|
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.
remove this extra line
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.
Resolved
public void closeWithSleepTime() throws Exception { | ||
long sleepTime = 1000L; | ||
Sink sink = mock(Sink.class); | ||
ObservabilityConfig config = mock(ObservabilityConfig.class); |
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.
change variable config to observabilityConfig
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.
Resolved
….enableObservability test case - fixed review comments.
….enableObservability test case - fixed review comments.
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.
Changes LGTM and Lets wait for Review from @ejona86 @shivaspeaks
* | ||
* @param sleepTime sleepTime | ||
*/ | ||
public void closeWithSleepTime(long sleepTime) { |
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.
Don't make this public. We just want it for testing.
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.
Resolved.
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.
Does it need to be protected
? Is package-private not sufficient?
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.
Resolved and changed to default method.
*/ | ||
public void closeWithSleepTime(long sleepTime) { | ||
synchronized (GcpObservability.class) { | ||
sink.close(); |
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.
Add the missing instance == null
check, and then have the old method call this new method with a hard-coded delay.
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.
Resolved.
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.
You did half of what I said, but the old method isn't calling the new method.
gcp-observability/src/main/java/io/grpc/gcp/observability/GcpObservability.java
Outdated
Show resolved
Hide resolved
@@ -208,6 +208,7 @@ public void run() { | |||
assertThat(list.get(2)).isInstanceOf(ConditionalClientInterceptor.class); | |||
assertThat(configurator.serverInterceptors).hasSize(1); | |||
assertThat(configurator.tracerFactories).hasSize(2); | |||
gcpObservability.closeWithSleepTime(3000); | |||
} catch (Exception e) { |
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.
When the try block is exited, it calls close() again. We should be seeing a IllegalStateException
exception. If the tests are passing, that needs to be looked in to.
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.
Resolved.
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.
No, I wasn't asking for it to be closed yet again. Remove that part added. It seems the answer to my comment is try-with-resources isn't being used here. I wonder if the diff folding made me think it was.
|
||
// Test to verify the closeWithSleepTime method along with sleep time explicitly. | ||
@Test | ||
public void closeWithSleepTime() throws Exception { |
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 seems identical to StaticTestingClassEnableObservability, except for the verify(sink).close()
. That would be good to move to the other test and then we delete this one.
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.
Resolved.
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.
You deleted the verify(sink).close()
and left the test? That's the exact opposite of what I had asked for. What does this test that isn't part of StaticTestingClassEnableObservability
?
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.
Resolved.
…bleObservability test case.
I have resolved all comments as per above mentioned and Kindly look into it once. |
*/ | ||
public void closeWithSleepTime(long sleepTime) { | ||
synchronized (GcpObservability.class) { | ||
sink.close(); |
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.
You did half of what I said, but the old method isn't calling the new method.
sink.close(); | ||
if (config.isEnableCloudMonitoring() || config.isEnableCloudTracing()) { | ||
try { | ||
long sleepTimeMillis = TimeUnit.MILLISECONDS.convert(sleepTime, timeUnit); |
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.
timeUnit.sleep(sleepTime)
@@ -208,6 +208,7 @@ public void run() { | |||
assertThat(list.get(2)).isInstanceOf(ConditionalClientInterceptor.class); | |||
assertThat(configurator.serverInterceptors).hasSize(1); | |||
assertThat(configurator.tracerFactories).hasSize(2); | |||
gcpObservability.closeWithSleepTime(3000); | |||
} catch (Exception e) { |
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.
No, I wasn't asking for it to be closed yet again. Remove that part added. It seems the answer to my comment is try-with-resources isn't being used here. I wonder if the diff folding made me think it was.
|
||
// Test to verify the closeWithSleepTime method along with sleep time explicitly. | ||
@Test | ||
public void closeWithSleepTime() throws Exception { |
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.
You deleted the verify(sink).close()
and left the test? That's the exact opposite of what I had asked for. What does this test that isn't part of StaticTestingClassEnableObservability
?
gcp-obsrevability : Fixed the slowness issue for GcpObservabilityTest.enableObservability test case.
Fixes #10146.
Snippet before fix as execuation time taking 1m 21sec
Snippet after fix as execuation time taking below 1sec 44msec.