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

DOC-4733 added geo indexing examples #376

Draft
wants to merge 2 commits into
base: master
Choose a base branch
from
Draft
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
192 changes: 192 additions & 0 deletions tests/Doc/GeoIndexExample.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,192 @@
// EXAMPLE: geoindex

// STEP_START import
using NRedisStack.RedisStackCommands;
using NRedisStack.Search;
using NRedisStack.Search.Literals.Enums;
using StackExchange.Redis;
// STEP_END

// REMOVE_START
using NRedisStack.Tests;
using NetTopologySuite.Geometries;

namespace Doc;
[Collection("DocsTests")]
// REMOVE_END

// HIDE_START
public class GeoIndexExample
{

[SkipIfRedis(Is.OSSCluster)]

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M02; .NET 6.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M02; .NET 6.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M03; .NET 6.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M03; .NET 6.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M02; .NET 7.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M02; .NET 7.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M03; .NET 8.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M03; .NET 8.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M03; .NET 7.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M03; .NET 7.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M02; .NET 8.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 8.0-M02; .NET 8.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 6.2.16; .NET 6.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 6.2.16; .NET 6.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.2.6; .NET 6.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.2.6; .NET 6.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 6.2.16; .NET 8.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 6.2.16; .NET 8.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.4.1; .NET 7.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.4.1; .NET 7.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.4.1; .NET 8.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.4.1; .NET 8.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 6.2.16; .NET 7.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 6.2.16; .NET 7.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.4.1; .NET 6.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.4.1; .NET 6.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.2.6; .NET 7.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.2.6; .NET 7.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.2.6; .NET 8.0;

'Is' does not contain a definition for 'OSSCluster'

Check failure on line 22 in tests/Doc/GeoIndexExample.cs

View workflow job for this annotation

GitHub Actions / Redis 7.2.6; .NET 8.0;

'Is' does not contain a definition for 'OSSCluster'
public void run()
{
var muxer = ConnectionMultiplexer.Connect("localhost:6379");
var db = muxer.GetDatabase();
//REMOVE_START
// Clear any keys here before using them in tests.
db.KeyDelete(new RedisKey[] { "product:46885", "product:46886", "shape:1", "shape:2", "shape:3", "shape:4" });
try { db.FT().DropIndex("productidx"); } catch { }
try { db.FT().DropIndex("geomidx"); } catch { }
//REMOVE_END
// HIDE_END

// STEP_START create_geo_idx
Schema geoSchema = new Schema()
.AddGeoField(new FieldName("$.location", "location"));

bool geoCreateResult = db.FT().Create(
"productidx",
new FTCreateParams()
.On(IndexDataType.JSON)
.Prefix("product:"),
geoSchema
);
Console.WriteLine(geoCreateResult); // >>> True
// STEP_END
// REMOVE_START
Assert.True(geoCreateResult);
// REMOVE_END

// STEP_START add_geo_json
var product46885 = new
{
description = "Navy Blue Slippers",
price = 45.99,
city = "Denver",
location = "-104.991531, 39.742043"
};

bool gjAddResult1 = db.JSON().Set("product:46885", "$", product46885);
Console.WriteLine(gjAddResult1); // >>> True

var product46886 = new
{
description = "Bright Green Socks",
price = 25.50,
city = "Fort Collins",
location = "-105.0618814,40.5150098"
};

bool gjAddResult2 = db.JSON().Set("product:46886", "$", product46886);
Console.WriteLine(gjAddResult2); // >>> True
// STEP_END
// REMOVE_START
Assert.True(gjAddResult1);
Assert.True(gjAddResult2);
// REMOVE_END

// STEP_START geo_query
SearchResult geoQueryResult = db.FT().Search(
"productidx",
new Query("@location:[-104.800644 38.846127 100 mi]")
);
Console.WriteLine(geoQueryResult.Documents.Count); // >>> 1

Console.WriteLine(
string.Join(", ", geoQueryResult.Documents.Select(x => x["json"]))
);
// >>> {"description":"Navy Blue Slippers","price":45.99,"city":"Denver"...
// STEP_END
// REMOVE_START
Assert.Single(geoQueryResult.Documents);
Assert.Equal(
"{\"description\":\"Navy Blue Slippers\",\"price\":45.99,\"city\":\"Denver\",\"location\":\"-104.991531, 39.742043\"}",
string.Join(", ", geoQueryResult.Documents.Select(x => x["json"]))
);
// REMOVE_END

// STEP_START create_gshape_idx
Schema geomSchema = new Schema()
.AddGeoShapeField(
new FieldName("$.geom", "geom"),
Schema.GeoShapeField.CoordinateSystem.FLAT
)
.AddTextField(new FieldName("$.name", "name"));

bool geomCreateResult = db.FT().Create(
"geomidx",
new FTCreateParams()
.On(IndexDataType.JSON)
.Prefix("shape:"),
geomSchema
);
Console.WriteLine(geomCreateResult); // >>> True
// STEP_END
// REMOVE_START
Assert.True(geomCreateResult);
// REMOVE_END

// STEP_START add_gshape_json
var shape1 = new
{
name = "Green Square",
geom = "POLYGON ((1 1, 1 3, 3 3, 3 1, 1 1))"
};

bool gmJsonRes1 = db.JSON().Set("shape:1", "$", shape1);
Console.WriteLine(gmJsonRes1); // >>> True

var shape2 = new
{
name = "Red Rectangle",
geom = "POLYGON ((2 2.5, 2 3.5, 3.5 3.5, 3.5 2.5, 2 2.5))"
};

bool gmJsonRes2 = db.JSON().Set("shape:2", "$", shape2);
Console.WriteLine(gmJsonRes1); // >>> True

var shape3 = new
{
name = "Blue Triangle",
geom = "POLYGON ((3.5 1, 3.75 2, 4 1, 3.5 1))"
};

bool gmJsonRes3 = db.JSON().Set("shape:3", "$", shape3);
Console.WriteLine(gmJsonRes3); // >>> True

var shape4 = new
{
name = "Purple Point",
geom = "POINT (2 2)"
};

bool gmJsonRes4 = db.JSON().Set("shape:4", "$", shape4);
Console.WriteLine(gmJsonRes3); // >>> True
// STEP_END
// REMOVE_START
Assert.True(gmJsonRes1);
Assert.True(gmJsonRes2);
Assert.True(gmJsonRes3);
Assert.True(gmJsonRes4);
// REMOVE_END

// STEP_START gshape_query
SearchResult geomQueryResult = db.FT().Search(
"geomidx",
new Query("(-@name:(Green Square) @geom:[WITHIN $qshape])")
.AddParam("qshape", "POLYGON ((1 1, 1 3, 3 3, 3 1, 1 1))")
.Limit(0, 1)
.Dialect(4)
);

Console.WriteLine(geomQueryResult.Documents.Count); // >>> 1
var res = string.Join(", ", geomQueryResult.Documents.Select(x => x["json"]));

Console.WriteLine(
string.Join(", ", geomQueryResult.Documents.Select(x => x["json"]))
);
// >>> [{"name":"Purple Point","geom":"POINT (2 2)"}]
// STEP_END
// REMOVE_START
Assert.Single(geomQueryResult.Documents);
Assert.Equal(
"[{\"name\":\"Purple Point\",\"geom\":\"POINT (2 2)\"}]",
string.Join(", ", geomQueryResult.Documents.Select(x => x["json"]))
);
// REMOVE_END
// HIDE_START
}
}
// HIDE_END
Loading