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

Get rid of "unused variable" warnings #31876

Merged
merged 31 commits into from
Sep 26, 2018

Conversation

cbuescher
Copy link
Member

@cbuescher cbuescher commented Jul 6, 2018

Another clean up trying to get rid of some annoying warnings. One large group that is
reasonably easy to tackle is the "unused variable" warnings. There are several cases
were most likely want to suppress the warnings (especially in the client documentation test
where the snippets should contain unused variable names). Most of the things can just be deleted though.

This is most likey a leftover from 24d10ad and can go.
@colings86 colings86 added the :Core/Infra/Core Core issues without another label label Jul 9, 2018
@elasticmachine
Copy link
Collaborator

Pinging @elastic/es-core-infra

@@ -130,7 +130,8 @@ public int getMaxLoopCounter() {
private final ScriptClassInfo scriptClassInfo;
private final CompilerSettings settings;
private final String name;
private final String source;
// TODO can this be removed all up the call chain?
// private final String source;
Copy link
Member Author

Choose a reason for hiding this comment

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

@jdconrad I couldn't find any reference to this field, but maybe its here for debugging purposes or anything the like? In that case I would add a comment instead of removing. If this is really unused, maybe it can also be removed from the method signatures passing it down here. Could you take a look and comment?

Copy link
Contributor

Choose a reason for hiding this comment

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

Will take a look! Thanks for pointing this out.

Copy link
Contributor

Choose a reason for hiding this comment

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

@cbuescher Looks like this is now extraneous. It never got removed once source was set in the class above. Please feel free to remove this as part of this PR or if you'd prefer I can remove it in a different PR.

Copy link
Member Author

Choose a reason for hiding this comment

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

will do, thanks

Request replicaRequest = (Request) primary.perform(request).replicaRequest;
// TODO check if the following two lines are really unused or might have side effects
// final Request request = new Request();
// Request replicaRequest = (Request) primary.perform(request).replicaRequest;
Copy link
Member Author

Choose a reason for hiding this comment

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

@ywelsch replicaRequest was used to test the primaryTerm() with "assertThat(replicaRequest.primaryTerm(), equalTo(primaryTerm));". Since that got removed, this part of the test can also go I guess. Does the test still perform its function after this? After all the primaryTerm gets mocked out somewhere above, but never asserted anywhere later? Could you take a look and comment?

Copy link
Contributor

Choose a reason for hiding this comment

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

you can delete this test. It doesn't do anything meaningful.

cbuescher pushed a commit to cbuescher/elasticsearch that referenced this pull request Jul 10, 2018
Currently Role.Builder keeps a reference to the FieldPermissionsCache that is
passed into its constructors. This seems to be unused except for passing it on
to convertFromIndicesPrivileges() in the second ctor itself, but we don't need
to keep the internal reference in that case, so it can be removed.

Relates to elastic#31876
cbuescher pushed a commit that referenced this pull request Jul 11, 2018
Currently Role.Builder keeps a reference to the FieldPermissionsCache that is
passed into its constructors. This seems to be unused except for passing it on
to convertFromIndicesPrivileges() in the second ctor itself, but we don't need
to keep the internal reference in that case, so it can be removed.

Relates to #31876
@cbuescher
Copy link
Member Author

All the open questions are adressed now, I think this is ready for a full review now. Spin off in #31935 can be merged separately but is also included in this PR.

@cbuescher cbuescher changed the title WIP Get rid of "unused variable" warnings Get rid of "unused variable" warnings Jul 11, 2018
@cbuescher cbuescher removed their assignment Jul 20, 2018
Christoph Büscher added 8 commits July 20, 2018 12:17
 Conflicts:
	client/rest-high-level/src/test/java/org/elasticsearch/client/documentation/SnapshotClientDocumentationIT.java
	server/src/test/java/org/elasticsearch/index/query/GeoDistanceQueryBuilderTests.java
	x-pack/plugin/rollup/src/test/java/org/elasticsearch/xpack/rollup/RollupRequestTranslationTests.java
@cbuescher cbuescher force-pushed the remove-unused-variables branch from d42f896 to ff0d7f4 Compare September 20, 2018 13:42
Copy link
Member

@danielmitterdorfer danielmitterdorfer left a comment

Choose a reason for hiding this comment

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

Thanks for updating the PR. I left a couple of comments.

final Set<String> articleIds = new HashSet<>();
final Set<String> commentIds = new HashSet<>();
final Map<String, Set<String>> commenterToCommentId = new HashMap<>();

private Control(String category) {
this.category = category;
// category not used any further
Copy link
Member

Choose a reason for hiding this comment

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

Does it make sense to remove the constructor argument then as well?

Copy link
Member Author

Choose a reason for hiding this comment

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

Yes, makes sense to remove the whole constructor actually since the class is private already and only used inside this test class.

}

void update(String word, String topField, float score, float idf, int docFreq, int tf) {
public void update(String word, String topField, float score) {
Copy link
Member

Choose a reason for hiding this comment

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

Is it necessary to increase the visibility of this method?

Copy link
Member Author

Choose a reason for hiding this comment

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

No, not sure how this happend. Removing.

@@ -64,6 +64,7 @@ public void testLimit() {
SearchSourceBuilder sourceBuilder = SourceGenerator.sourceBuilder(container, null, randomIntBetween(1, 10));
Builder aggBuilder = sourceBuilder.aggregations();
assertEquals(1, aggBuilder.count());
@SuppressWarnings("unused")
Copy link
Member

Choose a reason for hiding this comment

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

I wonder whether we should provide an accessor instead and uncomment the line below?

Copy link
Member Author

Choose a reason for hiding this comment

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

Good point.

@cbuescher
Copy link
Member Author

@danielmitterdorfer thanks a lot for getting back to this. I addressed most of your comments with the latest commit, checking back on how MovAvgIT is supposed to work. Could you go through the other comments I replied to and see if you agree?

parseQuery(query).toQuery(createShardContext());
// TODO: what can we check?
// TODO: what can we check? See https://github.com/elastic/elasticsearch/issues/34043
Copy link
Member

Choose a reason for hiding this comment

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

Thanks for creating the issue!

Copy link
Member

@danielmitterdorfer danielmitterdorfer left a comment

Choose a reason for hiding this comment

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

Thanks @cbuescher! LGTM

@cbuescher cbuescher merged commit ba3ceea into elastic:master Sep 26, 2018
@s1monw
Copy link
Contributor

s1monw commented Sep 26, 2018

@cbuescher I think this change caused some failures I am hitting locally. It reproduces on master:

./gradlew :server:integTest -Dtests.seed=CE15410BFF4D8B8A -Dtests.class=org.elasticsearch.search.aggregations.pipeline.moving.avg.MovAvgIT -Dtests.method="testHoltWintersNotEnoughData" -Dtests.security.manager=true -Dtests.locale=fi -Dtests.timezone=JST -Dcompiler.java=10 -Druntime.java=8
2> REPRODUCE WITH: ./gradlew :server:integTest -Dtests.seed=CE15410BFF4D8B8A -Dtests.class=org.elasticsearch.search.aggregations.pipeline.moving.avg.MovAvgIT -Dtests.method="testHoltWintersNotEnoughData" -Dtests.security.manager=true -Dtests.locale=fi -Dtests.timezone=JST -Dcompiler.java=10 -Druntime.java=8
FAILURE 0.39s | MovAvgIT.testHoltWintersNotEnoughData <<< FAILURES!
   > Throwable #1: junit.framework.AssertionFailedError: Expected exception SearchPhaseExecutionException but no exception was thrown
   >    at __randomizedtesting.SeedInfo.seed([CE15410BFF4D8B8A:A5C013FEF4A98B75]:0)
   >    at org.apache.lucene.util.LuceneTestCase.expectThrows(LuceneTestCase.java:2687)
   >    at org.apache.lucene.util.LuceneTestCase.expectThrows(LuceneTestCase.java:2672)
   >    at org.elasticsearch.search.aggregations.pipeline.moving.avg.MovAvgIT.testHoltWintersNotEnoughData(MovAvgIT.java:856)
   >    at java.lang.Thread.run(Thread.java:748)

@s1monw
Copy link
Contributor

s1monw commented Sep 26, 2018

I opened #34098

kcm pushed a commit that referenced this pull request Oct 30, 2018
This change cleans up "unused variable" warnings. There are several cases were we 
most likely want to suppress the warnings (especially in the client documentation test
where the snippets contain many unused variables). In a lot of cases the unused
variables can just be deleted though.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
:Core/Infra/Core Core issues without another label >non-issue v7.0.0-beta1
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants