Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xindoo
redis
提交
352208ff
R
redis
项目概览
xindoo
/
redis
通知
2
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
redis
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
352208ff
编写于
4月 03, 2014
作者:
A
antirez
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Initial HyperLogLog tests.
上级
d2ca4bb6
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
69 addition
and
0 deletion
+69
-0
tests/test_helper.tcl
tests/test_helper.tcl
+1
-0
tests/unit/hyperloglog.tcl
tests/unit/hyperloglog.tcl
+68
-0
未找到文件。
tests/test_helper.tcl
浏览文件 @
352208ff
...
...
@@ -47,6 +47,7 @@ set ::all_tests {
unit/obuf-limits
unit/bitops
unit/memefficiency
unit/hyperloglog
}
# Index to the next test to run in the ::all_tests list.
set ::next_test 0
...
...
tests/unit/hyperloglog.tcl
0 → 100644
浏览文件 @
352208ff
start_server
{
tags
{
"hll"
}}
{
test
{
HyperLogLog self test passes
}
{
catch
{
r pfselftest
}
e
set e
}
{
OK
}
test
{
PFADD without arguments creates an HLL value
}
{
r pfadd hll
r exists hll
}
{
1
}
test
{
Approximated cardinality after creation is zero
}
{
r pfcount hll
}
{
0
}
test
{
PFADD returns 1 when at least 1 reg was modified
}
{
r pfadd hll a b c
}
{
1
}
test
{
PFADD returns 0 when no reg was modified
}
{
r pfadd hll a b c
}
{
0
}
test
{
PFADD works with empty string
(
regression
)}
{
r pfadd hll
""
}
# Note that the self test stresses much better the
# cardinality estimation error. We are testing just the
# command implementation itself here.
test
{
PFCOUNT returns approximated cardinality of set
}
{
r del hll
set res
{}
r pfadd hll 1 2 3 4 5
lappend res
[
r pfcount hll
]
# Call it again to test cached value invalidation.
r pfadd hll 6 7 8 8 9 10
lappend res
[
r pfcount hll
]
set res
}
{
5 10
}
test
{
PFADD, PFCOUNT, PFMERGE type checking works
}
{
r set foo bar
catch
{
r pfadd foo 1
}
e
assert_match
{
*WRONGTYPE*
}
$e
catch
{
r pfcount foo
}
e
assert_match
{
*WRONGTYPE*
}
$e
catch
{
r pfmerge bar foo
}
e
assert_match
{
*WRONGTYPE*
}
$e
catch
{
r pfmerge foo bar
}
e
assert_match
{
*WRONGTYPE*
}
$e
}
test
{
PFMERGE results on the cardinality of union of sets
}
{
r del hll hll1 hll2 hll3
r pfadd hll1 a b c
r pfadd hll2 b c d
r pfadd hll3 c d e
r pfmerge hll hll1 hll2 hll3
r pfcount hll
}
{
5
}
test
{
PFGETREG returns the HyperLogLog raw registers
}
{
r del hll
r pfadd hll 1 2 3
llength
[
r pfgetreg hll
]
}
{
16384
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录