mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-23 08:38:27 -05:00
uphold the smove contract to return 0 when the element is not a member of the source set, even if source=dest
This commit is contained in:
parent
6c60526db9
commit
626b4f6907
@ -343,7 +343,10 @@ void smoveCommand(redisClient *c) {
|
|||||||
|
|
||||||
/* If srcset and dstset are equal, SMOVE is a no-op */
|
/* If srcset and dstset are equal, SMOVE is a no-op */
|
||||||
if (srcset == dstset) {
|
if (srcset == dstset) {
|
||||||
|
if (setTypeIsMember(srcset,ele))
|
||||||
addReply(c,shared.cone);
|
addReply(c,shared.cone);
|
||||||
|
else
|
||||||
|
addReply(c,shared.czero);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -519,6 +519,7 @@ start_server {
|
|||||||
test "SMOVE non existing key" {
|
test "SMOVE non existing key" {
|
||||||
setup_move
|
setup_move
|
||||||
assert_equal 0 [r smove myset1 myset2 foo]
|
assert_equal 0 [r smove myset1 myset2 foo]
|
||||||
|
assert_equal 0 [r smove myset1 myset1 foo]
|
||||||
assert_equal {1 a b} [lsort [r smembers myset1]]
|
assert_equal {1 a b} [lsort [r smembers myset1]]
|
||||||
assert_equal {2 3 4} [lsort [r smembers myset2]]
|
assert_equal {2 3 4} [lsort [r smembers myset2]]
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user