Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
YottaChain
YTBP
提交
f718e7ce
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,发现更多精彩内容 >>
未验证
提交
f718e7ce
编写于
4月 13, 2018
作者:
K
Kevin Heifner
提交者:
GitHub
4月 13, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #2366 from taokayan/double_bill
add unit test case for #2193(double billing)
上级
576aef8d
27ba3f3b
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
62 addition
and
0 deletion
+62
-0
tests/chain_tests/auth_tests.cpp
tests/chain_tests/auth_tests.cpp
+62
-0
未找到文件。
tests/chain_tests/auth_tests.cpp
浏览文件 @
f718e7ce
...
@@ -2,6 +2,9 @@
...
@@ -2,6 +2,9 @@
#include <eosio/testing/tester.hpp>
#include <eosio/testing/tester.hpp>
#include <eosio/chain/contracts/abi_serializer.hpp>
#include <eosio/chain/contracts/abi_serializer.hpp>
#include <eosio/chain/resource_limits.hpp>
#include <eosio/chain/resource_limits_private.hpp>
#ifdef NON_VALIDATING_TEST
#ifdef NON_VALIDATING_TEST
#define TESTER tester
#define TESTER tester
#else
#else
...
@@ -318,4 +321,63 @@ BOOST_AUTO_TEST_CASE( any_auth ) { try {
...
@@ -318,4 +321,63 @@ BOOST_AUTO_TEST_CASE( any_auth ) { try {
}
FC_LOG_AND_RETHROW
()
}
}
FC_LOG_AND_RETHROW
()
}
BOOST_AUTO_TEST_CASE
(
no_double_billing
)
{
try
{
TESTER
chain
;
chain
.
produce_block
();
account_name
acc1
=
N
(
"bill1"
);
account_name
acc2
=
N
(
"bill2"
);
account_name
acc1a
=
N
(
"bill1a"
);
chain
.
create_account
(
acc1
);
chain
.
create_account
(
acc1a
);
chain
.
produce_block
();
chainbase
::
database
&
db
=
chain
.
control
->
get_mutable_database
();
using
resource_usage_object
=
eosio
::
chain
::
resource_limits
::
resource_usage_object
;
using
by_owner
=
eosio
::
chain
::
resource_limits
::
by_owner
;
auto
create_acc
=
[
&
](
account_name
a
)
{
signed_transaction
trx
;
chain
.
set_transaction_headers
(
trx
);
authority
owner_auth
=
authority
(
chain
.
get_public_key
(
a
,
"owner"
)
);
vector
<
permission_level
>
pls
=
{{
acc1
,
"active"
}};
pls
.
push_back
({
acc1
,
"owner"
});
// same account but different permission names
pls
.
push_back
({
acc1a
,
"owner"
});
trx
.
actions
.
emplace_back
(
pls
,
contracts
::
newaccount
{
.
creator
=
acc1
,
.
name
=
a
,
.
owner
=
owner_auth
,
.
active
=
authority
(
chain
.
get_public_key
(
a
,
"active"
)
),
.
recovery
=
authority
(
chain
.
get_public_key
(
a
,
"recovery"
)
),
});
chain
.
set_transaction_headers
(
trx
);
trx
.
sign
(
chain
.
get_private_key
(
acc1
,
"active"
),
chain_id_type
()
);
trx
.
sign
(
chain
.
get_private_key
(
acc1
,
"owner"
),
chain_id_type
()
);
trx
.
sign
(
chain
.
get_private_key
(
acc1a
,
"owner"
),
chain_id_type
()
);
return
chain
.
push_transaction
(
trx
);
};
create_acc
(
acc2
);
const
auto
&
usage
=
db
.
get
<
resource_usage_object
,
by_owner
>
(
acc1
);
const
auto
&
usage2
=
db
.
get
<
resource_usage_object
,
by_owner
>
(
acc1a
);
BOOST_TEST
(
usage
.
cpu_usage
.
average
()
>
0
);
BOOST_TEST
(
usage
.
net_usage
.
average
()
>
0
);
BOOST_REQUIRE_EQUAL
(
usage
.
cpu_usage
.
average
(),
usage2
.
cpu_usage
.
average
());
BOOST_REQUIRE_EQUAL
(
usage
.
net_usage
.
average
(),
usage2
.
net_usage
.
average
());
chain
.
produce_block
();
}
FC_LOG_AND_RETHROW
()
}
BOOST_AUTO_TEST_SUITE_END
()
BOOST_AUTO_TEST_SUITE_END
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录