diff --git a/src/NRedisStack/ResponseParser.cs b/src/NRedisStack/ResponseParser.cs index b6ff2632..a0490af9 100644 --- a/src/NRedisStack/ResponseParser.cs +++ b/src/NRedisStack/ResponseParser.cs @@ -670,16 +670,24 @@ public static Dictionary ToStringRedisResultDictionary(this { var res = (RedisResult[])value!; var dict = new Dictionary(); - foreach (var pair in res) + if (res[0].Resp2Type == ResultType.SimpleString || res[0].Resp3Type == ResultType.SimpleString) { - var arr = (RedisResult[])pair!; - if (arr.Length > 1) - { - dict.Add(arr[0].ToString()!, arr[1]); - } - else + dict.Add(res[0].ToString(), res[1]); + dict.Add(res[2].ToString(), res[3]); + } + else + { + foreach (var pair in res) { - dict.Add(arr[0].ToString()!, null); + var arr = (RedisResult[])pair!; + if (arr.Length > 1) + { + dict.Add(arr[0].ToString()!, arr[1]); + } + else + { + dict.Add(arr[0].ToString()!, null); + } } } return dict; diff --git a/tests/NRedisStack.Tests/Search/SearchTests.cs b/tests/NRedisStack.Tests/Search/SearchTests.cs index b39bcb09..5b300ecd 100644 --- a/tests/NRedisStack.Tests/Search/SearchTests.cs +++ b/tests/NRedisStack.Tests/Search/SearchTests.cs @@ -2877,7 +2877,7 @@ public void TestProfileIssue306() var searchRes = profileSearch.Item1; var searchDet = profileSearch.Item2; - Assert.Equal(6, searchDet.Count); + Assert.True(searchDet["Shards"][0].Length >= 12); Assert.Equal(2, searchRes.Documents.Count); @@ -2886,7 +2886,7 @@ public void TestProfileIssue306() var profileAggregate = ft.ProfileAggregate(index, aggReq); var aggregateRes = profileAggregate.Item1; var aggregateDet = profileAggregate.Item2; - Assert.True(aggregateDet.Count >= 6); + Assert.True(aggregateDet["Shards"][0].Length >= 12); Assert.Equal(2, aggregateRes.TotalResults); } @@ -2907,7 +2907,7 @@ public async Task TestProfileAsyncIssue306() var searchRes = profileSearch.Item1; var searchDet = profileSearch.Item2; - Assert.Equal(6, searchDet.Count); + Assert.True(searchDet["Shards"][0].Length >= 12); Assert.Equal(2, searchRes.Documents.Count); // check using AggregationRequest @@ -2915,7 +2915,7 @@ public async Task TestProfileAsyncIssue306() var profileAggregate = await ft.ProfileAggregateAsync(index, aggReq); var aggregateRes = profileAggregate.Item1; var aggregateDet = profileAggregate.Item2; - Assert.True(aggregateDet.Count >= 6); + Assert.True(aggregateDet["Shards"][0].Length >= 12); Assert.Equal(2, aggregateRes.TotalResults); }