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

EQL: Remove "wildcard" function #76099

Merged
merged 5 commits into from
Aug 16, 2021
Merged

Conversation

bpintea
Copy link
Contributor

@bpintea bpintea commented Aug 4, 2021

This removes "wildcard" as an available function in EQL. This has
already been replace with "like" and "regex" embedded synthax (and
respective case insensitive variants).

Relates #71906.

This removes "wildcard" as an available function in EQL. This has
already been replace with "like" and "regex" embedded synthax (and
respective case insensitive variants).
@bpintea bpintea marked this pull request as ready for review August 4, 2021 15:41
@elasticmachine elasticmachine added the Team:QL (Deprecated) Meta label for query languages team label Aug 4, 2021
@elasticmachine
Copy link
Collaborator

Pinging @elastic/es-ql (Team:QL)

Copy link
Contributor

@rw-access rw-access left a comment

Choose a reason for hiding this comment

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

LGTM.
My only note is that I'm not sure where wildcard should be deleted and where it should be changed to like.

[[queries]]
name = "wildcardFunctionWildcardPattern"
query = '''
file where wildcard(file_name, "winini*.exe", "lsass.*") and opcode == 2
Copy link
Contributor

Choose a reason for hiding this comment

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

should this be replaced with like?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

There's already a like test for this (likeMultipleArgWithPattern).

@@ -411,73 +411,3 @@ description = "Test the `substring` function when the case already matches"
[[substring.fold.tests]]
expression = '''substring("hello world", -5, -1)'''
expected = "worl"

[wildcard]
Copy link
Contributor

Choose a reason for hiding this comment

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

should this one be replaced with like? is this file even used?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yes, file still in use.

Copy link
Contributor

@Luegg Luegg left a comment

Choose a reason for hiding this comment

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

Lgtm 👍

@bpintea
Copy link
Contributor Author

bpintea commented Aug 4, 2021

My only note is that I'm not sure where wildcard should be deleted and where it should be changed to like.

I've tried to preserve the wildcard-now-like tests where they're part of a more complex suite (like those in queries.toml) and removed them where wildcard itself was tested, since much of these are duplicated by like testing.

Copy link
Member

@costin costin left a comment

Choose a reason for hiding this comment

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

Assuming the removed tests already have equivalent for like the only comment I have is around fully removing the Wildcard class which is not needed and the substitute construct can be created directly by the parser.

@@ -205,35 +205,4 @@ public void testStringContainsWrongParams() {
assertEquals("1:15: second argument of [stringContains(process_name, 1)] must be [string], found value [1] type [integer]",
error("process where stringContains(process_name, 1)"));
}

public void testWildcardNotEnoughArguments() {
Copy link
Member

Choose a reason for hiding this comment

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

Please convert these to like if there aren't tests that already do that.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

These tests become now syntactic failures. One case could however be indeed converted (ex testWildcardWithNumericField).

Copy link
Member

Choose a reason for hiding this comment

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

As long as we have equivalent semantical tests, I'm 👍 . Note that wildcard tests that rely on the syntax can be changed to like/like~ hence my point of replacing removed tests (or checking) there are semantical equivalents to them.

@@ -31,7 +31,7 @@

/**
* EQL wildcard function. Matches the form:
* wildcard(field, "*wildcard*pattern*", ...)
* field like ("*wildcard*pattern*", ...)
*/
public class Wildcard extends BaseSurrogateFunction {
Copy link
Member

Choose a reason for hiding this comment

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

No need to keep this class around.
It's used inside the parser ExpressionBuilder#visitOperatorExpressionDefault however its only role is to call makeSubstitute which is similar to ExpressionBuilder#combineExpressions. See the handling of EqlBaseParser.IN_INSENSITIVE: in visitOperatorExpressionDefault.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Thanks. Class removed.

bpintea added 2 commits August 5, 2021 18:46
- remove Wildcard class;
- recover one failed translation test.
Copy link
Member

@costin costin left a comment

Choose a reason for hiding this comment

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

LGTM

@bpintea
Copy link
Contributor Author

bpintea commented Aug 16, 2021

@elasticmachine run elasticsearch-ci/bwc

@bpintea
Copy link
Contributor Author

bpintea commented Aug 16, 2021

@elasticmachine update branch

@bpintea bpintea merged commit a388f70 into elastic:master Aug 16, 2021
@bpintea bpintea deleted the fix/rm_wildcard branch August 16, 2021 15:48
wjp719 added a commit to wjp719/elasticsearch that referenced this pull request Aug 17, 2021
* master: (868 commits)
  Query API key - Rest spec and yaml tests (elastic#76238)
  Delay shard reassignment from nodes which are known to be restarting (elastic#75606)
  Reenable bwc tests for elastic#76475 (elastic#76576)
  Set version to 7.15 in BWC code (elastic#76577)
  Don't remove warning headers on all failure (elastic#76434)
  Disable bwc tests for elastic#76475 (elastic#76541)
  Re-enable bwc tests (elastic#76567)
  Keep track of data recovered from snapshots in RecoveryState (elastic#76499)
  [Transform] Align transform checkpoint range with date_histogram interval for better performance (elastic#74004)
  EQL: Remove "wildcard" function (elastic#76099)
  Fix 'accept' and 'content_type' fields for search_mvt API
  Add persistent licensed feature tracking (elastic#76476)
  Add system data streams to feature state snapshots (elastic#75902)
  fix the error message for instance methods that don't exist (elastic#76512)
  ILM: Add validation of the number_of_shards parameter in Shrink Action of ILM (elastic#74219)
  remove dashboard only reserved role (elastic#76507)
  Fix Stack Overflow in UnassignedInfo in Corner Case (elastic#76480)
  Add (Extended)KeyUsage KeyUsage, CipherSuite & Protocol to SSL diagnostics (elastic#65634)
  Add recovery from snapshot to tests (elastic#76535)
  Reenable BwC Tests after elastic#76532 (elastic#76534)
  ...
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants