-
Notifications
You must be signed in to change notification settings - Fork 1.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Pika 的 TCL 测试完善计划 #2046
Closed
8 tasks
Comments
Merged
Closed
This was referenced Mar 4, 2024
Closed
Merged
Merged
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
TCL 测试覆盖现状
背景
目前
Pika
的TCL
测试移植了Redis
那边的测试集,目前已经展开了测试类型包括printver
,basic
,scan
,expire
,multi
,quit
,pubsub
,slowlog
,maxmemory
,bitops
,hyperloglog
,type
,acl
,set
,list
,zset
,string
,hash
这几个类型,由于Pika
和Redis
之间存在一些差异,所以我们需要修改TCL
的代码来保证测试的正确性快速入门 TCL
以这段代码举例,
r
代表Redis
执行,所以下面这段代码意思是先执行Del novar
命令,然后再执行setnx novar foobared
命令检查返回值是不是1
, 然后执行get novar
检查返回值是不是foobared
,这就是一个最简单的TCL
样例Q&A
1. 目前还有很多
TCL
样例被注释了是为什么?Pika
的有些命令与Redis
命令并不是100%
兼容的,具体可以查看 Pika 支持的 Redis 接口及兼容情况Pika
中的Key
可以对应不同的数据结构,但是Redis
中一个Key
只能对应一种数据结构Pika
不支持Redis
中的一些命令,比如:sort
,rename
等等Pika
的返回值与Redis
不一致,是一个bug
需要进行修改2. 我应该怎么去修改目前存在
bug
的Pika
的TCL
测试呢?目前
Pika
的TCL
的代码在tests/unit
下方,以下面这个代码为例,对于所有存在Bug
的测试样例,我们目前都已经打上了Bug
注释,通过编辑器全局搜索# Bug need Fix
关键字可以很容易找到,然后进行问题复现并进行修复,如果需要提PR
修复的请关联此issue
, 当然如果你手动测试Pika
发现了问题,同样也可以新加一个TCL
的测试样例在相应文件下方,欢迎联系 @Mixficsol3. 目前被注释掉的
TCL
测试有几种类型,我怎么快速找到它们?Bug need Fix
(这是一个已经确认的 bug, 需要修复)Keys for multiple data types of Pika can be duplicate
由于Pika
中的Key
可以对应不同的数据结构,但是Redis
中一个Key
只能对应一种数据结构这种情况导致的返回值不一致This parameter is not available in Pika
(Redis 中有这个配置参数,但是 Pika 目前没有)Pika does not support the debug command
(Pika 中暂未实现这个命令)No cause has been confirmed
(暂时未确认原因)Currently Redis and Pika are consistent
(Redis 官网的返回和 Pika 一致,考虑需要修改 TCL)4. 现在所有的被注释掉的
TCL
测试都有以上这个相应的注解注释吗?目前我们只对
Zset
,Set
,Hash
,String
,List
这五种常用的数据结构的TCL
测试进行了注解补充,后续我们会继续对剩下类型的TCL
测试进行注解补充TCL 测试已知的问题
Zset:
ZINTERSTORE #516 regression, mixed sets and ziplist zsets
测试样例代码 1:
test/unit/type/zset.tcl
Pika 命令返回:
Redis 命令返回:
Set:
SINTER against non-set should throw error
SUNION against non-set should throw error
SMOVE wrong src key type
测试样例代码 1:
test/unit/type/set.tcl
Pika 命令返回:
Redis 命令返回:
测试样例代码 2:
test/unit/type/set.tcl
Pika 命令返回:
Redis 命令返回:
测试样例代码 3:
test/unit/type/set.tcl
Pika 命令返回:
Redis 命令返回:
String:
SETRANGE against non-existing key
Extended SET GET option with XX
Extended SET GET option with no previous value
测试样例代码 1:
test/unit/type/string.tcl
Pika 命令返回:
Redis 命令返回:
测试样例代码 2:
test/unit/type/string.tcl
Pika 命令返回:
Redis 命令返回:
测试样例代码 3:
test/unit/type/string.tcl
Pika 命令返回:
Redis 命令返回:
如何添加一段
TCL
的异常代码样例如果你发现了一个 测试样例存在
Bug
是需要修复的,请使用一下的这个模版添加在这个文件里面样例添加:
SUNION against non-set should throw error
测试样例代码:
test/unit/type/string.tcl
(所在的文件路径)Pika 命令返回:
Pika 的返回截图
Redis 命令返回:
Redis 的返回截图
The text was updated successfully, but these errors were encountered: