Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
whqwjb
go-ethereum
提交
8df689bd
G
go-ethereum
项目概览
whqwjb
/
go-ethereum
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
G
go-ethereum
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
8df689bd
编写于
12月 30, 2014
作者:
O
obscuren
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Chain tests
上级
2f8a45cd
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
48 addition
and
5 deletion
+48
-5
_data/invalid1
_data/invalid1
+0
-0
_data/valid1
_data/valid1
+0
-0
_data/valid2
_data/valid2
+0
-0
_data/valid3
_data/valid3
+0
-0
_data/valid4
_data/valid4
+0
-0
core/chain_manager_test.go
core/chain_manager_test.go
+48
-5
未找到文件。
_data/invalid1
0 → 100755
浏览文件 @
8df689bd
文件已添加
_data/
chain
1
→
_data/
valid
1
浏览文件 @
8df689bd
文件已移动
_data/
chain
2
→
_data/
valid
2
浏览文件 @
8df689bd
文件已移动
_data/valid3
0 → 100755
浏览文件 @
8df689bd
文件已添加
_data/valid4
0 → 100755
浏览文件 @
8df689bd
文件已添加
core/chain_manager_test.go
浏览文件 @
8df689bd
...
...
@@ -6,6 +6,7 @@ import (
"path"
"reflect"
"runtime"
"strconv"
"testing"
"github.com/ethereum/go-ethereum/core/types"
...
...
@@ -13,15 +14,15 @@ import (
"github.com/ethereum/go-ethereum/ethutil"
"github.com/ethereum/go-ethereum/event"
"github.com/ethereum/go-ethereum/rlp"
//logpkg "github.com/ethereum/go-ethereum/logger"
)
//var Logger logpkg.LogSystem
//var Log = logpkg.NewLogger("TEST")
func
init
()
{
runtime
.
GOMAXPROCS
(
runtime
.
NumCPU
())
//Logger = logpkg.NewStdLogSystem(os.Stdout, log.LstdFlags, logpkg.
Info
Level)
//Logger = logpkg.NewStdLogSystem(os.Stdout, log.LstdFlags, logpkg.
Debug
Level)
//logpkg.AddLogSystem(Logger)
ethutil
.
ReadConfig
(
"/tmp/ethtest"
,
"/tmp/ethtest"
,
"ETH"
)
...
...
@@ -50,21 +51,22 @@ func loadChain(fn string, t *testing.T) (types.Blocks, error) {
func
insertChain
(
done
chan
bool
,
chainMan
*
ChainManager
,
chain
types
.
Blocks
,
t
*
testing
.
T
)
{
err
:=
chainMan
.
InsertChain
(
chain
)
done
<-
true
if
err
!=
nil
{
fmt
.
Println
(
err
)
t
.
FailNow
()
}
done
<-
true
}
func
TestChainInsertions
(
t
*
testing
.
T
)
{
chain1
,
err
:=
loadChain
(
"
chain
1"
,
t
)
chain1
,
err
:=
loadChain
(
"
valid
1"
,
t
)
if
err
!=
nil
{
fmt
.
Println
(
err
)
t
.
FailNow
()
}
fmt
.
Println
(
len
(
chain1
))
chain2
,
err
:=
loadChain
(
"
chain
2"
,
t
)
chain2
,
err
:=
loadChain
(
"
valid
2"
,
t
)
if
err
!=
nil
{
fmt
.
Println
(
err
)
t
.
FailNow
()
...
...
@@ -94,3 +96,44 @@ func TestChainInsertions(t *testing.T) {
t
.
Error
(
"chain1 isn't canonical and should be"
)
}
}
func
TestChainMultipleInsertions
(
t
*
testing
.
T
)
{
const
max
=
4
chains
:=
make
([]
types
.
Blocks
,
max
)
var
longest
int
for
i
:=
0
;
i
<
max
;
i
++
{
var
err
error
name
:=
"valid"
+
strconv
.
Itoa
(
i
+
1
)
chains
[
i
],
err
=
loadChain
(
name
,
t
)
if
len
(
chains
[
i
])
>=
len
(
chains
[
longest
])
{
longest
=
i
}
fmt
.
Println
(
"loaded"
,
name
,
"with a length of"
,
len
(
chains
[
i
]))
if
err
!=
nil
{
fmt
.
Println
(
err
)
t
.
FailNow
()
}
}
var
eventMux
event
.
TypeMux
chainMan
:=
NewChainManager
(
&
eventMux
)
txPool
:=
NewTxPool
(
chainMan
,
&
eventMux
)
blockMan
:=
NewBlockManager
(
txPool
,
chainMan
,
&
eventMux
)
chainMan
.
SetProcessor
(
blockMan
)
done
:=
make
(
chan
bool
,
max
)
for
i
,
chain
:=
range
chains
{
var
i
int
=
i
go
func
()
{
insertChain
(
done
,
chainMan
,
chain
,
t
)
fmt
.
Println
(
i
,
"done"
)
}()
}
for
i
:=
0
;
i
<
max
;
i
++
{
<-
done
}
if
!
reflect
.
DeepEqual
(
chains
[
longest
][
len
(
chains
[
longest
])
-
1
],
chainMan
.
CurrentBlock
())
{
t
.
Error
(
"Invalid canonical chain"
)
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录