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

Avoid logging duplicate deprecation warnings multiple times #1660

Merged
merged 4 commits into from
Dec 15, 2021

Conversation

VachaShah
Copy link
Collaborator

Description

This PR adds logic to avoid logging duplicate deprecation messages. It resolves the issue #1108 and all other deprecation message instances. (Coming from #1537 (review)). There are also test changes since a lot of tests verify the deprecation warnings.

Issues Resolved

Closes #1108

Check List

  • New functionality includes testing.
    • All tests pass
  • New functionality has been documented.
    • New functionality has javadoc added
  • Commits are signed per the DCO using --signoff

By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.
For more information on following Developer Certificate of Origin and signing off your commits, please check here.

@VachaShah VachaShah requested a review from a team as a code owner December 6, 2021 18:55
@opensearch-ci-bot
Copy link
Collaborator

Can one of the admins verify this patch?

@opensearch-ci-bot
Copy link
Collaborator

✅   Gradle Wrapper Validation success 8d1d07698203277c19fc559b54245cce4314daa2

@opensearch-ci-bot
Copy link
Collaborator

✅   Gradle Precommit success 8d1d07698203277c19fc559b54245cce4314daa2

@opensearch-ci-bot
Copy link
Collaborator

❌   Gradle Check failure 8d1d07698203277c19fc559b54245cce4314daa2
Log 1343

Reports 1343

@VachaShah VachaShah force-pushed the deprecation-logs-once branch from 8d1d076 to 47a5366 Compare December 6, 2021 20:43
@opensearch-ci-bot
Copy link
Collaborator

✅   Gradle Wrapper Validation success 47a5366924836114d948056537e37093e9684dcd

@opensearch-ci-bot
Copy link
Collaborator

✅   Gradle Precommit success 47a5366924836114d948056537e37093e9684dcd

@opensearch-ci-bot
Copy link
Collaborator

❌   Gradle Check failure 47a5366924836114d948056537e37093e9684dcd
Log 1346

Reports 1346

Copy link
Member

@dblock dblock left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice work. I would appreciate another pair of eyes other than myself. Maybe @andrross?

Comment on lines 79 to 82
if (keys.contains(this.keyWithXOpaqueId)) {
return true;
}
keys.add(this.keyWithXOpaqueId);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this safe on an unsynchronized HashSet? I'm assuming this method can be accessed concurrently from any number of threads. It's likely fine for the de-duplication logic to be best effort and a duplicate log entry emitted due to a race is not a big deal, but I'm more concerned about undefined behavior now or in future JDK versions if the underlying data structure is modified in the middle of a contains() invocation.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Definitely agree! We can use the SynchronizedSet, the only downside might be performance since the collection will be locked by a single thread at a time. If that is not a concern, we can make this synchronized. WDYT?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think ConcurrentHashMap will give the concurrency guarantees while also allowing lock-free reads. Something like:

private final Set<String> keys = ConcurrentHashMap.newKeySet();

...

public boolean isAlreadyLogged() {
    return !keys.add(keyWithXOpaqueId);
}

Under the hood it looks like the KeySetView of ConcurrentHashMap is using the same method as putIfAbsent in its add method. That should be lock-free in the case that the key is present, and only incur any synchronization overhead in the case that it is newly adding a key.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry for the delay! That makes sense. I have updated the implementation to use the keySet() from ConcurrentHashMap.

@VachaShah
Copy link
Collaborator Author

start gradle check

@opensearch-ci-bot
Copy link
Collaborator

❌   Gradle Check failure 47a5366924836114d948056537e37093e9684dcd
Log 1379

Reports 1379

@VachaShah VachaShah force-pushed the deprecation-logs-once branch from 47a5366 to 931bb72 Compare December 15, 2021 07:08
@opensearch-ci-bot
Copy link
Collaborator

❌   Gradle Check failure 931bb72d6bac52526117977513ac38c475fea8bb
Log 1502

Reports 1502

@VachaShah
Copy link
Collaborator Author

❌   Gradle Check failure 931bb72 Log 1502

Reports 1502

Execution failed for task ':distribution:bwc:bugfix:buildBwcLinuxTar'.
> Building 1.2.1 didn't generate expected file /var/CITOOL/workflow/OpenSearch_CI/PR_Checks/Gradle_Check/search/distribution/bwc/bugfix/build/bwc/checkout-1.2/distribution/archives/linux-tar/build/distributions/opensearch-min-1.2.1-SNAPSHOT-linux-x64.tar.gz

This should resolve after PR #1731 is merged.

@VachaShah VachaShah force-pushed the deprecation-logs-once branch from 931bb72 to 998f97c Compare December 15, 2021 08:44
@opensearch-ci-bot
Copy link
Collaborator

❌   Gradle Check failure 998f97c1eda48c805231bf3e52483f680e3e3e11
Log 1503

Reports 1503

* Otherwise, a warning can be logged by some test and the upcoming test can be impacted by it.
*/
public static void resetDeprecatedMessageForTests() {
keys = new HashSet<>();
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This isn't right because you're resetting the field to the non-concurrent hashset implementation. I would actually replace this with keys.clear() since the ConcurrentHashMap is thread safe.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh my bad! I missed this, I will change it.

Comment on lines 50 to 51
private static Set<String> keys = ConcurrentHashMap.newKeySet();
private String keyWithXOpaqueId;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Both of these can be final (see comment below about a change to the reset method).

@@ -19,10 +19,10 @@
- skip:
version: " - 6.2.99"
reason: deprecated in 6.3
features: "warnings"
features: "allowed_warnings"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I admit that I don't really understand what these files mean, but why did you change "warnings" to "allowed_warnings"?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

allowed_warnings asserts if the warning occurs but does not fail the test if it doesn't. This is in a lot of files and there is no order in which they run so it is very difficult to determine when the first warning will occur given that a lot of tests assert the same duplicate warnings.

@VachaShah VachaShah force-pushed the deprecation-logs-once branch from 998f97c to 2330282 Compare December 15, 2021 22:16
@opensearch-ci-bot
Copy link
Collaborator

✅   Gradle Check success 2330282
Log 1516

Reports 1516

@VachaShah VachaShah requested a review from andrross December 15, 2021 23:05
@VachaShah VachaShah merged commit e66ea2c into opensearch-project:main Dec 15, 2021
@VachaShah VachaShah deleted the deprecation-logs-once branch December 15, 2021 23:27
@dblock
Copy link
Member

dblock commented Dec 16, 2021

Nice job @VachaShah and thanks for a thorough code review @andrross!

opensearch-trigger-bot bot pushed a commit that referenced this pull request Mar 2, 2022
* Avoid logging duplicate deprecation warnings multiple times

Signed-off-by: Vacha <[email protected]>

* Fixes test failures

Signed-off-by: Vacha <[email protected]>

* Adding deprecation logger tests

Signed-off-by: Vacha <[email protected]>

* Using ConcurrentHashMap keySet

Signed-off-by: Vacha Shah <[email protected]>
(cherry picked from commit e66ea2c)
dblock pushed a commit that referenced this pull request Mar 3, 2022
…times (#2315)

* Avoid logging duplicate deprecation warnings multiple times (#1660)

* Avoid logging duplicate deprecation warnings multiple times

Signed-off-by: Vacha <[email protected]>

* Fixes test failures

Signed-off-by: Vacha <[email protected]>

* Adding deprecation logger tests

Signed-off-by: Vacha <[email protected]>

* Using ConcurrentHashMap keySet

Signed-off-by: Vacha Shah <[email protected]>
(cherry picked from commit e66ea2c)

* Fixing failing RestResizeHandlerTests in 1.x

Signed-off-by: Vacha Shah <[email protected]>

Co-authored-by: Vacha <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[BUG] Deprecation message spamming logs from Security plugin
4 participants