Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
YottaChain
YTBP
提交
4885dc83
Y
YTBP
项目概览
YottaChain
/
YTBP
通知
0
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Y
YTBP
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
4885dc83
编写于
4月 03, 2018
作者:
A
Andrianto Lie
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add unit tests to verify that no empty region/ cycle/ shard can exist
上级
5b2695b1
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
49 addition
and
0 deletion
+49
-0
tests/chain_tests/block_tests.cpp
tests/chain_tests/block_tests.cpp
+49
-0
未找到文件。
tests/chain_tests/block_tests.cpp
浏览文件 @
4885dc83
...
@@ -57,6 +57,55 @@ BOOST_AUTO_TEST_CASE( push_block ) { try {
...
@@ -57,6 +57,55 @@ BOOST_AUTO_TEST_CASE( push_block ) { try {
BOOST_REQUIRE_EQUAL
(
test1
.
validate
(),
true
);
BOOST_REQUIRE_EQUAL
(
test1
.
validate
(),
true
);
}
FC_LOG_AND_RETHROW
()
}
/// schedule_test
}
FC_LOG_AND_RETHROW
()
}
/// schedule_test
BOOST_AUTO_TEST_CASE
(
push_invalid_block
)
{
try
{
TESTER
chain
;
// Create a new block
signed_block
new_block
;
auto
head_time
=
chain
.
control
->
head_block_time
();
auto
next_time
=
head_time
+
fc
::
microseconds
(
config
::
block_interval_us
);
uint32_t
slot
=
chain
.
control
->
get_slot_at_time
(
next_time
);
auto
sch_pro
=
chain
.
control
->
get_scheduled_producer
(
slot
);
auto
priv_key
=
chain
.
get_private_key
(
sch_pro
,
"active"
);
// On block action
action
on_block_act
;
on_block_act
.
account
=
config
::
system_account_name
;
on_block_act
.
name
=
N
(
onblock
);
on_block_act
.
authorization
=
vector
<
permission_level
>
{{
config
::
system_account_name
,
config
::
active_name
}};
on_block_act
.
data
=
fc
::
raw
::
pack
(
chain
.
control
->
head_block_header
());
transaction
trx
;
trx
.
actions
.
emplace_back
(
std
::
move
(
on_block_act
));
trx
.
set_reference_block
(
chain
.
control
->
head_block_id
());
trx
.
expiration
=
chain
.
control
->
head_block_time
()
+
fc
::
seconds
(
1
);
trx
.
kcpu_usage
=
2000
;
// 1 << 24;
// Add properties to block header
new_block
.
previous
=
chain
.
control
->
head_block_id
();
new_block
.
timestamp
=
next_time
;
new_block
.
producer
=
sch_pro
;
new_block
.
block_mroot
=
chain
.
control
->
get_dynamic_global_properties
().
block_merkle_root
.
get_root
();
vector
<
transaction_metadata
>
input_metas
;
input_metas
.
emplace_back
(
packed_transaction
(
trx
),
chain
.
control
->
get_chain_id
(),
chain
.
control
->
head_block_time
(),
true
);
new_block
.
transaction_mroot
=
transaction_metadata
::
calculate_transaction_merkle_root
(
input_metas
);
new_block
.
sign
(
priv_key
);
// Create a new empty region
new_block
.
regions
.
resize
(
new_block
.
regions
.
size
()
+
1
);
// Pushing this block should fail, since every region inside a block should not be empty
BOOST_REQUIRE_THROW
(
chain
.
control
->
push_block
(
new_block
),
tx_empty_region
);
// Create a new cycle inside the empty region
new_block
.
regions
.
back
().
cycles_summary
.
resize
(
new_block
.
regions
.
back
().
cycles_summary
.
size
()
+
1
);
// Pushing this block should fail, since there should not be an empty cycle inside a block
BOOST_REQUIRE_THROW
(
chain
.
control
->
push_block
(
new_block
),
tx_empty_cycle
);
// Create a new shard inside the empty cycle
new_block
.
regions
.
back
().
cycles_summary
.
back
().
resize
(
new_block
.
regions
.
back
().
cycles_summary
.
back
().
size
()
+
1
);
// Pushing this block should fail, since there should not be an empty shard inside a block
BOOST_REQUIRE_THROW
(
chain
.
control
->
push_block
(
new_block
),
tx_empty_shard
);
}
FC_LOG_AND_RETHROW
()
}
/// push_invalid_block
// Utility function to check expected irreversible block
// Utility function to check expected irreversible block
uint32_t
calc_exp_last_irr_block_num
(
const
base_tester
&
chain
,
const
uint32_t
&
head_block_num
)
{
uint32_t
calc_exp_last_irr_block_num
(
const
base_tester
&
chain
,
const
uint32_t
&
head_block_num
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录