Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
milvus
milvus
提交
bd3056fc
M
milvus
项目概览
milvus
/
milvus
11 个月 前同步成功
通知
261
Star
22476
Fork
2472
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
M
milvus
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
bd3056fc
编写于
9月 01, 2021
作者:
C
Cai Yudong
提交者:
GitHub
9月 01, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Improve tso codecov (#7407)
Signed-off-by:
N
yudong.cai
<
yudong.cai@zilliz.com
>
上级
3721cbfe
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
64 addition
and
15 deletion
+64
-15
internal/tso/global_allocator_test.go
internal/tso/global_allocator_test.go
+51
-0
internal/tso/tso.go
internal/tso/tso.go
+13
-15
未找到文件。
internal/tso/global_allocator_test.go
浏览文件 @
bd3056fc
...
...
@@ -12,6 +12,7 @@
package
tso
import
(
"math"
"os"
"strings"
"testing"
...
...
@@ -87,8 +88,58 @@ func TestGlobalTSOAllocator_All(t *testing.T) {
assert
.
Nil
(
t
,
err
)
})
t
.
Run
(
"Alloc"
,
func
(
t
*
testing
.
T
)
{
_
,
err
:=
gTestTsoAllocator
.
Alloc
(
100
)
assert
.
Nil
(
t
,
err
)
})
t
.
Run
(
"AllocOne"
,
func
(
t
*
testing
.
T
)
{
_
,
err
:=
gTestTsoAllocator
.
AllocOne
()
assert
.
Nil
(
t
,
err
)
})
t
.
Run
(
"Reset"
,
func
(
t
*
testing
.
T
)
{
gTestTsoAllocator
.
Reset
()
})
}
func
TestGlobalTSOAllocator_Fail
(
t
*
testing
.
T
)
{
endpoints
:=
os
.
Getenv
(
"ETCD_ENDPOINTS"
)
if
endpoints
==
""
{
endpoints
=
"localhost:2379"
}
etcdEndpoints
:=
strings
.
Split
(
endpoints
,
","
)
etcdKV
,
err
:=
tsoutil
.
NewTSOKVBase
(
etcdEndpoints
,
"/test/root/kv"
,
"tsoTest"
)
assert
.
NoError
(
t
,
err
)
gTestTsoAllocator
=
NewGlobalTSOAllocator
(
"timestamp"
,
etcdKV
)
t
.
Run
(
"Initialize"
,
func
(
t
*
testing
.
T
)
{
err
:=
gTestTsoAllocator
.
Initialize
()
assert
.
Nil
(
t
,
err
)
})
t
.
Run
(
"GenerateTSO_invalid"
,
func
(
t
*
testing
.
T
)
{
_
,
err
:=
gTestTsoAllocator
.
GenerateTSO
(
0
)
assert
.
NotNil
(
t
,
err
)
})
gTestTsoAllocator
.
SetLimitMaxLogic
(
true
)
t
.
Run
(
"SetTSO_invalid"
,
func
(
t
*
testing
.
T
)
{
err
:=
gTestTsoAllocator
.
SetTSO
(
0
)
assert
.
NotNil
(
t
,
err
)
err
=
gTestTsoAllocator
.
SetTSO
(
math
.
MaxUint64
)
assert
.
NotNil
(
t
,
err
)
})
t
.
Run
(
"Alloc_invalid"
,
func
(
t
*
testing
.
T
)
{
_
,
err
:=
gTestTsoAllocator
.
Alloc
(
0
)
assert
.
NotNil
(
t
,
err
)
_
,
err
=
gTestTsoAllocator
.
Alloc
(
math
.
MaxUint32
)
assert
.
NotNil
(
t
,
err
)
})
t
.
Run
(
"Reset"
,
func
(
t
*
testing
.
T
)
{
gTestTsoAllocator
.
Reset
()
})
}
internal/tso/tso.go
浏览文件 @
bd3056fc
...
...
@@ -68,19 +68,19 @@ type timestampOracle struct {
lastSavedTime
atomic
.
Value
}
func
(
t
*
timestampOracle
)
loadTimestamp
()
(
time
.
Time
,
error
)
{
strData
,
err
:=
t
.
txnKV
.
Load
(
t
.
key
)
var
binData
[]
byte
=
[]
byte
(
strData
)
if
err
!=
nil
{
return
typeutil
.
ZeroTime
,
err
}
if
len
(
binData
)
==
0
{
return
typeutil
.
ZeroTime
,
nil
}
return
typeutil
.
ParseTimestamp
(
binData
)
}
//
func (t *timestampOracle) loadTimestamp() (time.Time, error) {
//
strData, err := t.txnKV.Load(t.key)
//
//
var binData []byte = []byte(strData)
//
//
if err != nil {
//
return typeutil.ZeroTime, err
//
}
//
if len(binData) == 0 {
//
return typeutil.ZeroTime, nil
//
}
//
return typeutil.ParseTimestamp(binData)
//
}
// save timestamp, if lastTs is 0, we think the timestamp doesn't exist, so create it,
// otherwise, update it.
...
...
@@ -95,12 +95,10 @@ func (t *timestampOracle) saveTimestamp(ts time.Time) error {
}
func
(
t
*
timestampOracle
)
InitTimestamp
()
error
{
//last, err := t.loadTimestamp()
//if err != nil {
// return err
//}
next
:=
time
.
Now
()
// If the current system time minus the saved etcd timestamp is less than `updateTimestampGuard`,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录