From 1e4b635e196f14ae02ae23770d62345e5d6573a9 Mon Sep 17 00:00:00 2001 From: Alex Roitman Date: Thu, 24 Aug 2017 10:54:43 -0700 Subject: [PATCH] Add tests for WHEREIN. Add WHEREIN to the commands.json --- core/commands.json | 40 ++++++++++++++++++++++++++++++++++++++++ tests/keys_test.go | 14 ++++++++++++++ 2 files changed, 54 insertions(+) diff --git a/core/commands.json b/core/commands.json index a2ebede6..a8fd5e17 100644 --- a/core/commands.json +++ b/core/commands.json @@ -344,6 +344,14 @@ "optional": true, "multiple": true }, + { + "command": "WHEREIN", + "name": ["field","count","value"], + "type": ["string","integer","double"], + "optional": true, + "multiple": true, + "variadic": true + }, { "command": "NOFIELDS", "name": [], @@ -411,6 +419,14 @@ "optional": true, "multiple": true }, + { + "command": "WHEREIN", + "name": ["field","count","value"], + "type": ["string","integer","double"], + "optional": true, + "multiple": true, + "variadic": true + }, { "command": "NOFIELDS", "name": [], @@ -496,6 +512,14 @@ "optional": true, "multiple": true }, + { + "command": "WHEREIN", + "name": ["field","count","value"], + "type": ["string","integer","double"], + "optional": true, + "multiple": true, + "variadic": true + }, { "command": "NOFIELDS", "name": [], @@ -632,6 +656,14 @@ "optional": true, "multiple": true }, + { + "command": "WHEREIN", + "name": ["field","count","value"], + "type": ["string","integer","double"], + "optional": true, + "multiple": true, + "variadic": true + }, { "command": "NOFIELDS", "name": [], @@ -812,6 +844,14 @@ "optional": true, "multiple": true }, + { + "command": "WHEREIN", + "name": ["field","count","value"], + "type": ["string","integer","double"], + "optional": true, + "multiple": true, + "variadic": true + }, { "command": "NOFIELDS", "name": [], diff --git a/tests/keys_test.go b/tests/keys_test.go index 49b72ac5..d9d24f5d 100644 --- a/tests/keys_test.go +++ b/tests/keys_test.go @@ -29,6 +29,7 @@ func subTestKeys(t *testing.T, mc *mockServer) { runStep(t, mc, "SET EX", keys_SET_EX_test) runStep(t, mc, "PDEL", keys_PDEL_test) runStep(t, mc, "FIELDS", keys_FIELDS_test) + runStep(t, mc, "WHEREIN", keys_WHEREIN_test) } func keys_BOUNDS_test(mc *mockServer) error { @@ -332,3 +333,16 @@ func keys_PDEL_test(mc *mockServer) error { {"PDEL", "mykey", "*"}, {0}, }) } + +func keys_WHEREIN_test(mc *mockServer) error { + return mc.DoBatch([][]interface{}{ + {"SET", "mykey", "myid_a1", "FIELD", "a", 1, "POINT", 33, -115}, {"OK"}, + {"WITHIN", "mykey", "WHEREIN", "a", 3, 0, 1, 2, "BOUNDS", 32.8, -115.2, 33.2, -114.8}, {`[0 [[myid_a1 {"type":"Point","coordinates":[-115,33]} [a 1]]]]`}, + {"WITHIN", "mykey", "WHEREIN", "a", "a", 0, 1, 2, "BOUNDS", 32.8, -115.2, 33.2, -114.8}, {"ERR invalid argument 'a'"}, + {"WITHIN", "mykey", "WHEREIN", "a", 1, 0, 1, 2, "BOUNDS", 32.8, -115.2, 33.2, -114.8}, {"ERR invalid argument '1'"}, + {"WITHIN", "mykey", "WHEREIN", "a", 3, 0, "a", 2, "BOUNDS", 32.8, -115.2, 33.2, -114.8}, {"ERR invalid argument 'a'"}, + {"SET", "mykey", "myid_a2", "FIELD", "a", 2, "POINT", 32.99, -115}, {"OK"}, + {"SET", "mykey", "myid_a3", "FIELD", "a", 3, "POINT", 33, -115.02}, {"OK"}, + {"WITHIN", "mykey", "WHEREIN", "a", 3, 0, 1, 2, "BOUNDS", 32.8, -115.2, 33.2, -114.8}, {`[0 [[myid_a1 {"type":"Point","coordinates":[-115,33]} [a 1]] [myid_a2 {"type":"Point","coordinates":[-115,32.99]} [a 2]]]]`}, + }) +}