Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
P
plugin
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
JIRA
JIRA
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
link33
plugin
Commits
f89c5450
Commit
f89c5450
authored
May 21, 2019
by
袁海雷
Committed by
vipwzw
May 21, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Modify rpc test for oracle
parent
86ff6f9b
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
141 additions
and
69 deletions
+141
-69
test-rpc.sh
plugin/dapp/oracle/cmd/build/test-rpc.sh
+141
-69
No files found.
plugin/dapp/oracle/cmd/build/test-rpc.sh
View file @
f89c5450
...
@@ -6,6 +6,8 @@ CASE_ERR=""
...
@@ -6,6 +6,8 @@ CASE_ERR=""
oracle_addPublisher_unsignedTx
=
"0a066d616e61676512410a3f0a146f7261636c652d7075626c6973682d6576656e741222313271796f6361794e46374c7636433971573461767873324537553431664b5366761a0361646420a08d0630e6b685d696ee9394163a223151344e687572654a784b4e4266373164323642394a336642516f5163666d657a32"
oracle_addPublisher_unsignedTx
=
"0a066d616e61676512410a3f0a146f7261636c652d7075626c6973682d6576656e741222313271796f6361794e46374c7636433971573461767873324537553431664b5366761a0361646420a08d0630e6b685d696ee9394163a223151344e687572654a784b4e4266373164323642394a336642516f5163666d657a32"
oracle_publisher_addr
=
"12qyocayNF7Lv6C9qW4avxs2E7U41fKSfv"
oracle_publisher_addr
=
"12qyocayNF7Lv6C9qW4avxs2E7U41fKSfv"
oracle_publishers_addr
=
""
oracle_publishers_addr
=
""
eventId
=
""
txhash
=
""
#color
#color
RED
=
'\033[1;31m'
RED
=
'\033[1;31m'
...
@@ -15,89 +17,119 @@ NOC='\033[0m'
...
@@ -15,89 +17,119 @@ NOC='\033[0m'
# $2=0 means true, other false
# $2=0 means true, other false
echo_rst
()
{
echo_rst
()
{
if
[
"
$2
"
-eq
0
]
;
then
if
[
"
$2
"
-eq
0
]
;
then
echo
"
$1
ok
"
echo
-e
"
${
GRE
}
$1
ok
${
NOC
}
"
else
else
echo
"
$1
err
"
echo
-e
"
${
RED
}
$1
fail
${
NOC
}
"
CASE_ERR
=
"err"
CASE_ERR
=
"err"
fi
fi
}
oracle_AddPublisher
(){
echo
"=============== # Add publisher ==============="
signAndSendRawTx
"
${
oracle_addPublisher_unsignedTx
}
"
"
${
oracle_publisher_addr
}
"
}
}
create_publish_transaction
()
{
oracle_publish_transaction
()
{
local
ip
=
$1
req
=
'"method":"Chain33.CreateTransaction","params":[{"execer":"oracle","actionName":"EventPublish","payload":{"type":"football", "subType":"Premier League","time":1747814996,"content":"test","introduction":"test"}}]'
req
=
'"method":"Chain33.CreateTransaction","params":[{"execer":"oracle","actionName":"EventPublish","payload":{"type":"football", "subType":"Premier League","time":?????????,"content":"test","introduction":"test"}}]'
echo
"#request:
$req
"
echo
"#request:
$req
"
resp
=
$(
curl
-ksd
"{
$req
}"
"
$ip
"
)
resp
=
$(
curl
-ksd
"{
$req
}"
${
MAIN_HTTP
}
)
echo
"#response:
$resp
"
echo
"#response:
$resp
"
ok
=
$(
jq
'.error|not'
<<<
"
$resp
"
)
ok
=
$(
jq
'(.error|not) and (.result != "")'
<<<
"
$resp
"
)
[
"
$ok
"
==
true
]
echo_rst
"
$FUNCNAME
"
"
$?
"
rawtx
=
$(
jq
-r
".result"
<<<
"
$resp
"
)
signAndSendRawTx
"
$rawtx
"
"
${
oracle_publisher_addr
}
"
eventId
=
"
${
txhash
}
"
echo
"eventId
$eventId
"
}
}
create_prePublishResult_transaction
()
{
oracle_prePublishResult_transaction
()
{
local
ip
=
$1
event_id
=
$1
event_id
=
$2
req
=
'"method":"Chain33.CreateTransaction","params":[{"execer":"oracle","actionName":"ResultPrePublish","payload":{"eventID":"'
"
$event_id
"
'", "source":"sina sport","result":"0:1"}}]'
req
=
'"method":"Chain33.CreateTransaction","params":[{"execer":"oracle","actionName":"ResultPrePublish","payload":{"eventID":"${event_id}", "source":"sina sport","result":"0:1"}}]'
echo
"#request:
$req
"
echo
"#request:
$req
"
resp
=
$(
curl
-ksd
"{
$req
}"
"
$ip
"
)
resp
=
$(
curl
-ksd
"{
$req
}"
${
MAIN_HTTP
}
)
echo
"#response:
$resp
"
echo
"#response:
$resp
"
ok
=
$(
jq
'.error|not'
<<<
"
$resp
"
)
ok
=
$(
jq
'(.error|not) and (.result != "")'
<<<
"
$resp
"
)
[
"
$ok
"
==
true
]
echo_rst
"
$FUNCNAME
"
"
$?
"
rawtx
=
$(
jq
-r
".result"
<<<
"
$resp
"
)
signAndSendRawTx
"
$rawtx
"
"
${
oracle_publisher_addr
}
"
}
}
create_publishResult_transaction
()
{
oracle_eventAbort_transaction
()
{
local
ip
=
$1
event_id
=
$1
event_id
=
$2
req
=
'"method":"Chain33.CreateTransaction","params":[{"execer":"oracle","actionName":"EventAbort","payload":{"eventID":"'
"
$event_id
"
'"}}]'
req
=
'"method":"Chain33.CreateTransaction","params":[{"execer":"oracle","actionName":"ResultPublish","payload":{"eventID":"${event_id}", "source":"sina sport","result":"1:1"}}]'
echo
"#request:
$req
"
echo
"#request:
$req
"
resp
=
$(
curl
-ksd
"{
$req
}"
"
$ip
"
)
resp
=
$(
curl
-ksd
"{
$req
}"
${
MAIN_HTTP
}
)
echo
"#response:
$resp
"
echo
"#response:
$resp
"
ok
=
$(
jq
'.error|not'
<<<
"
$resp
"
)
ok
=
$(
jq
'(.error|not) and (.result != "")'
<<<
"
$resp
"
)
[
"
$ok
"
==
true
]
echo_rst
"
$FUNCNAME
"
"
$?
"
rawtx
=
$(
jq
-r
".result"
<<<
"
$resp
"
)
signAndSendRawTx
"
$rawtx
"
"
${
oracle_publisher_addr
}
"
}
}
oracle_AddPublisher
(){
oracle_resultAbort_transaction
()
{
echo
"=============== # add publisher ==============="
event_id
=
$1
local
ip
=
$1
req
=
'"method":"Chain33.CreateTransaction","params":[{"execer":"oracle","actionName":"ResultAbort","payload":{"eventID":"'
"
$event_id
"
'"}}]'
signRawTx
"
${
oracle_addPublisher_unsignedTx
}
"
"
${
oracle_publisher_addr
}
"
echo
"#request:
$req
"
if
[
$?
-ne
0
]
;
then
resp
=
$(
curl
-ksd
"{
$req
}"
${
MAIN_HTTP
})
rst
=
$?
echo
"#response:
$resp
"
echo_rst
"AddPublisher signRawTx"
"
$rst
"
ok
=
$(
jq
'(.error|not) and (.result != "")'
<<<
"
$resp
"
)
fi
[
"
$ok
"
==
true
]
echo_rst
"
$FUNCNAME
"
"
$?
"
sendSignedTx
rawtx
=
$(
jq
-r
".result"
<<<
"
$resp
"
)
if
[
$?
-ne
0
]
;
then
signAndSendRawTx
"
$rawtx
"
"
${
oracle_publisher_addr
}
"
rst
=
$?
echo_rst
"AddPublisher sendSignedTx"
"
$rst
"
fi
block_wait 1
queryTransaction
".result.receipt.tyName"
"ExecOk"
if
[
$?
-ne
0
]
;
then
rst
=
$?
echo_rst
"AddPublisher queryExecRes"
"
$rst
"
fi
}
}
oracle_sendPublishEvent
()
{
oracle_publishResult_transaction
()
{
echo
"=============== # add sendPublishEvent ==============="
event_id
=
$1
local
ip
=
$1
req
=
'"method":"Chain33.CreateTransaction","params":[{"execer":"oracle","actionName":"ResultPublish","payload":{"eventID":"'
"
$event_id
"
'", "source":"sina sport","result":"1:1"}}]'
create_publish_transaction
"
$ip
"
echo
"#request:
$req
"
resp
=
$(
curl
-ksd
"{
$req
}"
${
MAIN_HTTP
})
echo
"#response:
$resp
"
ok
=
$(
jq
'(.error|not) and (.result != "")'
<<<
"
$resp
"
)
[
"
$ok
"
==
true
]
echo_rst
"
$FUNCNAME
"
"
$?
"
rawtx
=
$(
jq
-r
".result"
<<<
"
$resp
"
)
signAndSendRawTx
"
$rawtx
"
"
${
oracle_publisher_addr
}
"
}
}
signRawTx
()
{
# 签名并发送
signAndSendRawTx
()
{
unsignedTx
=
$1
unsignedTx
=
$1
addr
=
$2
addr
=
$2
signedTx
=
$(
curl
-s
--data-binary
'{"jsonrpc":"2.0","id":2,"method":"Chain33.SignRawTx","params":[{"addr":"'
${
addr
}
'","txHex":"'
${
unsignedTx
}
'","expire":"120s"}]}'
-H
'content-type:text/plain;'
${
MAIN_HTTP
}
| jq
-r
".result"
)
req
=
'"method":"Chain33.SignRawTx","params":[{"addr":"'
${
addr
}
'","txHex":"'
${
unsignedTx
}
'","expire":"120s"}]'
if
[
$signedTx
==
"null"
]
;
then
signedTx
=
$(
curl
-ksd
"{
$req
}"
${
MAIN_HTTP
}
| jq
-r
".result"
)
return
1
if
[
"
$signedTx
"
==
"null"
]
;
then
echo
"An error occurred while signing"
else
else
return
0
sendSignedTx
"
$signedTx
"
fi
fi
}
}
sendSignedTx
()
{
sendSignedTx
()
{
txHash
=
$(
curl
-s
--data-binary
'{"jsonrpc":"2.0","id":2,"method":"Chain33.SendTransaction","params":[{"token":"","data":"'
${
signedTx
}
'"}]}'
-H
'content-type:text/plain;'
${
MAIN_HTTP
}
| jq
-r
".result"
)
signedTx
=
$1
if
[
$txHash
==
"null"
]
;
then
local
req
=
'"method":"Chain33.SendTransaction","params":[{"token":"","data":"'
"
$signedTx
"
'"}]'
return
1
resp
=
$(
curl
-ksd
"{
$req
}"
${
MAIN_HTTP
})
else
ok
=
$(
echo
"
${
resp
}
"
| jq
-r
".error"
)
return
0
[
"
$ok
"
==
null
]
fi
rst
=
$?
echo_rst
"
$FUNCNAME
"
"
$rst
"
txhash
=
$(
echo
"
${
resp
}
"
| jq
-r
".result"
)
echo
"tx hash is
$txhash
"
}
oracle_QueryOraclesByID
()
{
event_id
=
$1
local
req
=
'"method":"Chain33.Query", "params":[{"execer":"oracle","funcName":"QueryOraclesByIDs","payload":{"eventID":["'
"
$event_id
"
'"]}}]'
echo
"#request:
$req
"
resp
=
$(
curl
-ksd
"{
$req
}"
${
MAIN_HTTP
})
echo
"#response:
$resp
"
ok
=
$(
jq
'(.error|not) and (.result.status[0] | [has("eventID", "status", "type", "subType", "source"),true] | unique | length == 1)'
<<<
"
$resp
"
)
[
"
$ok
"
==
true
]
rst
=
$?
echo_rst
"
$FUNCNAME
"
"
$rst
"
}
}
function
block_wait
()
{
function
block_wait
()
{
...
@@ -116,33 +148,71 @@ function block_wait() {
...
@@ -116,33 +148,71 @@ function block_wait() {
echo
"wait new block
$count
s, cur height=
$expect
,old=
$cur_height
"
echo
"wait new block
$count
s, cur height=
$expect
,old=
$cur_height
"
}
}
# 查询交易的执行结果
# 根据传入的规则,校验查询的结果 (参数1: 校验规则 参数2: 预期匹配结果)
function
queryTransaction
()
{
function
queryTransaction
()
{
validator
=
$1
block_wait 1
expectRes
=
$2
local
txhash
=
"
$1
"
res
=
$(
curl
-s
--data-binary
'{"jsonrpc":"2.0","id":2,"method":"Chain33.QueryTransaction","params":[{"hash":"'
${
txHash
}
'"}]}'
-H
'content-type:text/plain;'
${
MAIN_HTTP
}
| jq
-r
"
${
validator
}
"
)
local
req
=
'"method":"Chain33.QueryTransaction","params":[{"hash":"'
"
$txhash
"
'"}]'
if
[
${
res
}
!=
${
expectRes
}
]
;
then
local times
=
10
while
true
;
do
ret
=
$(
curl
-ksd
"{
$req
}"
${
MAIN_HTTP
}
| jq
-r
".result.tx.hash"
)
if
[
"
${
ret
}
"
!=
"
${
1
}
"
]
;
then
block_wait 1
times
=
$((
times
-
1
))
if
[
$times
-le
0
]
;
then
echo
"====query tx=
$1
failed"
echo
"req=
$req
"
curl
-ksd
"{
$req
}"
${
MAIN_HTTP
}
return
1
return
1
exit
1
fi
else
else
oracle_publishers_addr
=
$(
curl
-s
--data-binary
'{"jsonrpc":"2.0","id":2,"method":"Chain33.QueryTransaction","params":[{"hash":"'
${
txHash
}
'"}]}'
-H
'content-type:text/plain;'
${
MAIN_HTTP
}
| jq
-r
".result.receipt.logs[1].log.current.arr.value"
)
echo
"====query tx=
$1
success"
echo
$oracle_publishers_addr
return
0
return
0
break
fi
fi
done
}
}
function
run_test
()
{
function
run_test
()
{
local
ip
=
$1
# 增加发布人
oracle_AddPublisher
"
$ip
"
oracle_AddPublisher
oracle_sendPublishEvent
"
$ip
"
# 生成发布事件的交易
oracle_publish_transaction
# 预发布事件结果交易
oracle_prePublishResult_transaction
"
$eventId
"
# 事件正式发布
oracle_publishResult_transaction
"
$eventId
"
# 根据ID查询事件
block_wait 1
oracle_QueryOraclesByID
"
$eventId
"
# 生成发布事件的交易
oracle_publish_transaction
# 取消事件发布
oracle_eventAbort_transaction
"
$eventId
"
# 根据ID查询事件
block_wait 1
oracle_QueryOraclesByID
"
$eventId
"
# 生成发布事件的交易
oracle_publish_transaction
# 预发布事件结果交易
oracle_prePublishResult_transaction
"
$eventId
"
# 取消事件预发布
oracle_resultAbort_transaction
"
$eventId
"
# 根据ID查询事件
block_wait 1
oracle_QueryOraclesByID
"
$eventId
"
}
}
function
main
()
{
function
main
()
{
local
ip
=
$1
MAIN_HTTP
=
"http://
$ip
:8801"
MAIN_HTTP
=
"
$1
"
echo
"=========== # oracle rpc test ============="
echo
"main_ip=
$MAIN_HTTP
"
echo
"main_ip=
$MAIN_HTTP
"
run_test
"
$MAIN_HTTP
"
echo
"=========== # oracle rpc test start============="
run_test
if
[
-n
"
$CASE_ERR
"
]
;
then
if
[
-n
"
$CASE_ERR
"
]
;
then
echo
-e
"
${
RED
}
=============Oracle Rpc Test Fail=============
${
NOC
}
"
echo
-e
"
${
RED
}
=============Oracle Rpc Test Fail=============
${
NOC
}
"
...
@@ -150,6 +220,7 @@ function main() {
...
@@ -150,6 +220,7 @@ function main() {
else
else
echo
-e
"
${
GRE
}
=============Oracle Rpc Test Pass==============
${
NOC
}
"
echo
-e
"
${
GRE
}
=============Oracle Rpc Test Pass==============
${
NOC
}
"
fi
fi
echo
"=========== # oracle rpc test end============="
}
}
main
"
$1
"
main
"
$1
"
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment