diff --git a/src/server/search/search_family.cc b/src/server/search/search_family.cc index c710d03f569c..1f64a25645f7 100644 --- a/src/server/search/search_family.cc +++ b/src/server/search/search_family.cc @@ -72,11 +72,18 @@ search::SchemaField::VectorParams ParseVectorParams(CmdArgParser* parser) { return params; } -search::SchemaField::TagParams ParseTagParams(CmdArgParser* parser) { +std::optional ParseTagParams(CmdArgParser* parser, + SinkReplyBuilder* builder) { search::SchemaField::TagParams params{}; while (parser->HasNext()) { if (parser->Check("SEPARATOR")) { - string_view separator = parser->Next(); + std::string_view separator = parser->NextOrDefault(); + if (separator.size() != 1) { + builder->SendError( + absl::StrCat("Tag separator must be a single character. Got `", separator, "`"), + kSyntaxErrType); + return std::nullopt; + } params.separator = separator.front(); continue; } @@ -127,7 +134,11 @@ optional ParseSchemaOrReply(DocIndex::DataType type, CmdArgParse // Vector fields include: {algorithm} num_args args... search::SchemaField::ParamsVariant params(monostate{}); if (type == search::SchemaField::TAG) { - params = ParseTagParams(&parser); + auto tag_params = ParseTagParams(&parser, builder); + if (!tag_params) { + return std::nullopt; + } + params = tag_params.value(); } else if (type == search::SchemaField::VECTOR) { auto vector_params = ParseVectorParams(&parser); if (parser.HasError()) { diff --git a/src/server/search/search_family_test.cc b/src/server/search/search_family_test.cc index 804a3ed13b9e..bcf03811b028 100644 --- a/src/server/search/search_family_test.cc +++ b/src/server/search/search_family_test.cc @@ -332,6 +332,11 @@ TEST_F(SearchFamilyTest, Errors) { // Wrong field type EXPECT_THAT(Run({"ft.search", "i1", "@foo:lol"}), ErrArg("Wrong access type for field: foo")); + + // ft.create index on json schema $.sometag AS sometag TAG SEPARATOR + EXPECT_THAT(Run({"ft.create", "i2", "ON", "JSON", "SCHEMA", "$.sometag", "AS", "sometag", "TAG", + "SEPARATOR"}), + ErrArg("Tag separator must be a single character. Got ``")); } TEST_F(SearchFamilyTest, NoPrefix) {