From 82f9ee7d3227c1289cf7b51f54783eff2fa27350 Mon Sep 17 00:00:00 2001 From: Basit Chonka Date: Wed, 20 Oct 2021 17:38:16 +0200 Subject: [PATCH 1/2] feat(aggregation): support for 5.1 operators --- package.json | 2 +- snippets/stage-autocompleter.json | 84 +++++++++++++++++++++++++++++-- 2 files changed, 82 insertions(+), 4 deletions(-) diff --git a/package.json b/package.json index 9f4fd7b4e..f99fe493a 100644 --- a/package.json +++ b/package.json @@ -948,7 +948,7 @@ "mocha": "^8.2.1", "mocha-junit-reporter": "^2.0.0", "mocha-multi": "^1.1.3", - "mongodb-ace-autocompleter": "^0.6.0", + "mongodb-ace-autocompleter": "^0.8.0", "mongodb-build-info": "^1.2.0", "mongodb-runner": "^4.8.3", "node-loader": "^0.6.0", diff --git a/snippets/stage-autocompleter.json b/snippets/stage-autocompleter.json index 034bee994..a53917d0f 100644 --- a/snippets/stage-autocompleter.json +++ b/snippets/stage-autocompleter.json @@ -82,6 +82,42 @@ ], "description": "Returns a count of the number of documents at this stage of the aggregation pipeline." }, + "MongoDB Aggregations $densify": { + "prefix": "$densify", + "body": [ + "/**", + " * field: The required field to densify.", + " * partitionByFields: The set of fields that acts as a compound key to define each partition.", + " * range: {", + " * step: The amount to increment the field value in each document.", + " * unit: If specified field must evaluate to a date for every document in the collection, otherwise must evaluate to a numeric.", + " * bounds: A string or array of numeric/date bounds, corresponding to the type of the field.", + " * }", + " */", + "\\$densify: {", + " field: ${1:string},", + " partitionByFields: [${2:string}, ${3:string}, ...],", + " range: {", + " step: ${4:number},", + " unit: ${5:string},", + " bounds: [${6:lowerbound}, ${7:upperbound}, ...]", + " }", + "}" + ], + "description": "Creates new documents to eliminate the gaps in the time or numeric domain at the required granularity level." + }, + "MongoDB Aggregations $documents": { + "prefix": "$documents", + "body": [ + "/**", + " * expression: Any valid expression.", + " */", + "\\$documents: {", + " ${1:expression}", + "}" + ], + "description": "Returns literal results for a full-text search." + }, "MongoDB Aggregations $facet": { "prefix": "$facet", "body": [ @@ -318,7 +354,7 @@ "prefix": "$search", "body": [ "/** ", - " * index: the name of the Search index.", + " * index: The name of the Search index.", " * text: Analyzed search, with required fields of query and path, the analyzed field(s) to search.", " * term: Un-analyzed search.", " * compound: Combines ops.", @@ -337,6 +373,48 @@ ], "description": "Performs a full-text search on the specified field(s)." }, + "MongoDB Aggregations $searchMeta": { + "prefix": "$searchMeta", + "body": [ + "/**", + " * index: The name of the Search index.", + " * count: The count of the results.", + " * facet: {", + " * operator: Analyzed search, with required fields of query and path, can either be replaced with the name of a valid operator.", + " * facets: {", + " * stringFacet: Narrows search results based on unique string values, with required fields of type and path.", + " * numberFacet: Narrows search results by breaking them up into separate ranges of numbers, with required fields of type, path, and boundaries.", + " * dateFacet: Narrows search results by breaking them up into separate ranges of dates, with required fields of type, path, and boundaries.", + " * }", + " * }", + " */", + "\\$searchMeta: {", + " index: ${1:string},", + " facet: {", + " operator: {", + " text: {", + " query: ${2:string},", + " path: ${3:string}", + " }", + " },", + " facets: {", + " ${4:stringFacet}: {", + " type: ${5:string},", + " path: ${6:string},", + " numBuckets: ${7:integer}", + " },", + " numberFacet: {", + " type: 'number',", + " path: ${8:string},", + " boundaries: [${9:lowerbound}, ${10:upperbound}, ...],", + " default: ${11:string}", + " }", + " }", + " }", + "}" + ], + "description": "Performs a full-text search on the specified field(s) and gets back only the generated search meta data from a query." + }, "MongoDB Aggregations $set": { "prefix": "$set", "body": [ @@ -374,8 +452,8 @@ " ${3:path}: {", " ${4:function}: ${5:functionArgs},", " window: {", - " documents: [${6:lowerBound}, ${7:upperBound}],", - " range: [${8:lowerBound}, ${9:upperBound}],", + " documents: [${6:lowerbound}, ${7:upperbound}],", + " range: [${8:lowerbound}, ${9:upperbound}],", " unit: ${10:string}", " }", " },", From c61298c88947ad2dff001fbdca8c68d251c907db Mon Sep 17 00:00:00 2001 From: Basit Chonka Date: Wed, 20 Oct 2021 21:12:23 +0200 Subject: [PATCH 2/2] feat(aggregation): add tests --- src/test/suite/snippets/stageAutocompleter.test.ts | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/test/suite/snippets/stageAutocompleter.test.ts b/src/test/suite/snippets/stageAutocompleter.test.ts index 775ccaaa2..0b25840b4 100644 --- a/src/test/suite/snippets/stageAutocompleter.test.ts +++ b/src/test/suite/snippets/stageAutocompleter.test.ts @@ -15,6 +15,8 @@ const STAGE_LABELS = [ 'MongoDB Aggregations $bucketAuto', 'MongoDB Aggregations $collStats', 'MongoDB Aggregations $count', + 'MongoDB Aggregations $densify', + 'MongoDB Aggregations $documents', 'MongoDB Aggregations $facet', 'MongoDB Aggregations $geoNear', 'MongoDB Aggregations $graphLookup', @@ -24,6 +26,7 @@ const STAGE_LABELS = [ 'MongoDB Aggregations $lookup', 'MongoDB Aggregations $match', 'MongoDB Aggregations $merge', + 'MongoDB Aggregations $metaSearch', 'MongoDB Aggregations $out', 'MongoDB Aggregations $project', 'MongoDB Aggregations $redact',