mirror of
http://github.com/valkey-io/valkey
synced 2024-11-22 18:54:58 +00:00
Merge pull request #2094 from mattsta/nosort
Fix zero-ordering SORT when called against lists
This commit is contained in:
commit
c50693d40f
15
src/sort.c
15
src/sort.c
@ -285,16 +285,13 @@ void sortCommand(redisClient *c) {
|
||||
return;
|
||||
}
|
||||
|
||||
/* For the STORE option, or when SORT is called from a Lua script,
|
||||
* we want to force a specific ordering even when no explicit ordering
|
||||
* was asked (SORT BY nosort). This guarantees that replication / AOF
|
||||
* is deterministic.
|
||||
/* When sorting a set with no sort specified, we must sort the output
|
||||
* so the result is consistent across scripting and replication.
|
||||
*
|
||||
* However in the case 'dontsort' is true, but the type to sort is a
|
||||
* sorted set, we don't need to do anything as ordering is guaranteed
|
||||
* in this special case. */
|
||||
if ((storekey || c->flags & REDIS_LUA_CLIENT) &&
|
||||
(dontsort && sortval->type != REDIS_ZSET))
|
||||
* The other types (list, sorted set) will retain their native order
|
||||
* even if no sort order is requested, so they remain stable across
|
||||
* scripting and replication. */
|
||||
if ((dontsort && sortval->type == REDIS_SET))
|
||||
{
|
||||
/* Force ALPHA sorting */
|
||||
dontsort = 0;
|
||||
|
@ -246,6 +246,24 @@ start_server {
|
||||
r sort mylist by num get x:*->
|
||||
} {100}
|
||||
|
||||
test "SORT by nosort retains native order for lists" {
|
||||
r del testa
|
||||
r lpush testa 2 1 4 3 5
|
||||
r sort testa by nosort
|
||||
} {5 3 4 1 2}
|
||||
|
||||
test "SORT by nosort plus store retains native order for lists" {
|
||||
r del testa
|
||||
r lpush testa 2 1 4 3 5
|
||||
r sort testa by nosort store testb
|
||||
r lrange testb 0 -1
|
||||
} {5 3 4 1 2}
|
||||
|
||||
test "SORT by nosort with limit returns based on original list order" {
|
||||
r sort testa by nosort limit 0 3 store testb
|
||||
r lrange testb 0 -1
|
||||
} {5 3 4}
|
||||
|
||||
tags {"slow"} {
|
||||
set num 100
|
||||
set res [create_random_dataset $num lpush]
|
||||
|
Loading…
Reference in New Issue
Block a user