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
9771febb
Commit
9771febb
authored
Aug 23, 2019
by
liuyuhang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add change test
parent
05b8ae47
Show whitespace changes
Inline
Side-by-side
Showing
18 changed files
with
949 additions
and
54 deletions
+949
-54
round_state.go
plugin/consensus/tendermint/types/round_state.go
+0
-0
proposal_change.go
plugin/dapp/autonomy/commands/proposal_change.go
+4
-4
proposal_project.go
plugin/dapp/autonomy/commands/proposal_project.go
+2
-1
proposal_rule.go
plugin/dapp/autonomy/commands/proposal_rule.go
+2
-1
boardaction.go
plugin/dapp/autonomy/executor/boardaction.go
+1
-1
boardaction_test.go
plugin/dapp/autonomy/executor/boardaction_test.go
+47
-20
change_test.go
plugin/dapp/autonomy/executor/change_test.go
+388
-0
changeaction.go
plugin/dapp/autonomy/executor/changeaction.go
+12
-14
changeaction_test.go
plugin/dapp/autonomy/executor/changeaction_test.go
+485
-0
exec.go
plugin/dapp/autonomy/executor/exec.go
+0
-1
exec_local.go
plugin/dapp/autonomy/executor/exec_local.go
+0
-1
kv.go
plugin/dapp/autonomy/executor/kv.go
+0
-0
projectaction.go
plugin/dapp/autonomy/executor/projectaction.go
+5
-5
query.go
plugin/dapp/autonomy/executor/query.go
+0
-0
ruleaction.go
plugin/dapp/autonomy/executor/ruleaction.go
+3
-4
ruleaction_test.go
plugin/dapp/autonomy/executor/ruleaction_test.go
+0
-0
const.go
plugin/dapp/autonomy/types/const.go
+0
-2
certutils.go
...rt/authority/tools/cryptogen/generator/utils/certutils.go
+0
-0
No files found.
plugin/consensus/tendermint/types/round_state.go
View file @
9771febb
plugin/dapp/autonomy/commands/proposal_change.go
View file @
9771febb
...
...
@@ -58,14 +58,14 @@ func proposalChange(cmd *cobra.Command, args []string) {
if
len
(
per
)
==
2
{
if
per
[
1
]
==
"true"
{
change
:=
&
auty
.
Change
{
Cancel
:
true
,
Addr
:
per
[
0
],
Cancel
:
true
,
Addr
:
per
[
0
],
}
changes
=
append
(
changes
,
change
)
}
else
if
per
[
1
]
==
"false"
{
change
:=
&
auty
.
Change
{
Cancel
:
false
,
Addr
:
per
[
0
],
Cancel
:
false
,
Addr
:
per
[
0
],
}
changes
=
append
(
changes
,
change
)
}
...
...
plugin/dapp/autonomy/commands/proposal_project.go
View file @
9771febb
...
...
@@ -7,12 +7,13 @@ package commands
import
(
"encoding/json"
"strings"
jsonrpc
"github.com/33cn/chain33/rpc/jsonclient"
rpctypes
"github.com/33cn/chain33/rpc/types"
"github.com/33cn/chain33/types"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
"github.com/spf13/cobra"
"strings"
)
// ProposalProjectCmd 创建提案命令
...
...
plugin/dapp/autonomy/commands/proposal_rule.go
View file @
9771febb
...
...
@@ -7,12 +7,13 @@ package commands
import
(
"encoding/json"
"strings"
jsonrpc
"github.com/33cn/chain33/rpc/jsonclient"
rpctypes
"github.com/33cn/chain33/rpc/types"
"github.com/33cn/chain33/types"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
"github.com/spf13/cobra"
"strings"
)
// ProposalRuleCmd 创建提案命令
...
...
plugin/dapp/autonomy/executor/boardaction.go
View file @
9771febb
...
...
@@ -398,7 +398,7 @@ func (a *action) verifyMinerAddr(addrs []string, bindAddr string) (string, error
}
tkBind
:=
&
ticketTy
.
TicketBind
{}
err
=
types
.
Decode
(
value
,
tkBind
)
if
err
!=
nil
||
tkBind
.
MinerAddress
!=
bindAddr
{
if
err
!=
nil
||
tkBind
.
MinerAddress
!=
bindAddr
{
return
addr
,
auty
.
ErrBindAddr
}
}
...
...
plugin/dapp/autonomy/executor/boardaction_test.go
View file @
9771febb
...
...
@@ -20,10 +20,10 @@ import (
"github.com/33cn/chain33/types"
"github.com/33cn/chain33/util"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
ticket
"github.com/33cn/plugin/plugin/dapp/ticket/executor"
ticketTy
"github.com/33cn/plugin/plugin/dapp/ticket/types"
"github.com/stretchr/testify/mock"
"github.com/stretchr/testify/require"
ticketTy
"github.com/33cn/plugin/plugin/dapp/ticket/types"
ticket
"github.com/33cn/plugin/plugin/dapp/ticket/executor"
)
// ExecEnv exec environment
...
...
@@ -58,30 +58,57 @@ var (
PrivKey9
=
"0x128de4afa7c061c00d854a1bca51b58e80a2c292583739e5aebf4c0f778959e1"
PrivKey10
=
"0x1c3e6cac2f887e1ab9180e2d5772dc4ba01accb8d4df434faba097003eb35482"
Addr1
=
"12HKLEn6g4FH39yUbHh4EVJWcFo5CXg22d"
Addr2
=
"1Ka7EPFRqs3v9yreXG6qA4RQbNmbPJCZPj"
Addr3
=
"12cjnN5D4DPdBQSwh6vjwJbtsW4EJALTMv"
Addr4
=
"1Luh4AziYyaC5zP3hUXtXFZS873xAxm6rH"
Addr5
=
"1NNaYHkscJaLJ2wUrFNeh6cQXBS4TrFYeB"
Addr6
=
"1L1puAUjfmtDECKo2C1qLWsAMZtDGTBWf6"
Addr7
=
"1LNf9AVXzUMQkQM5hgGLhkdrVtD8UMBSUm"
Addr8
=
"1PcGKYYoLn1PLLJJodc1UpgWGeFAQasAkx"
Addr9
=
"1BM2xhBk95qoae8zKNDWwAVGgBERhb7DQu"
Addr10
=
"1Q9sQwothzM1gKSzkVZ8Dt1tqKX1uzSagx"
PrivKey11
=
"0xfd0c4a8a1efcd221ee0f36b7d4f57d8ff843cb8bc193b39c7863332d355acafa"
PrivKey12
=
"0x4c9691bf6acc908ef5c07abcad23cf7f98e46e84101aa5059322aa53eb4dc471"
PrivKey13
=
"0x50b9c6a4358ef8ffc96d5831a8dfd5e0fae504d49e20c5eafd12b6015423de33"
PrivKey14
=
"0x96e3c766850a915fe4718b890d96208d5d1a3694b2597e08165480b5b48b84cb"
PrivKey15
=
"0xeac5e45243c3920cf8a98f3d3a2e3a9b43f30a21769b57f734213913511e7575"
PrivKey16
=
"0xd2aaa6f050a4db13fbd2c8bf87cbb96e217289172baca6c12e8a8b0680b9aa1a"
PrivKey17
=
"0x33b3b977c657435a49773b5605a704ad5fdca0fa34fe36a02ea0f13a49099832"
Addr11
=
"15VUiygdxMSZ3rykwe742yomp2cPJ9Tfve"
Addr12
=
"1DyR84CU5AHbGXLEnhHMwMvWNMeunLZsuJ"
Addr13
=
"132pBvrgSYgHASxzoeL3bqnsqUpaBbUktm"
Addr14
=
"1DEV4XwdBUWRkMuy4ARRiEAoxQ2LoDByNG"
Addr15
=
"18Y87cw2hiYC71bvpD872oYMYXtw66Qp6o"
Addr16
=
"1Fghq6cgdJEDr6gQBmvba3t6aXAkyZyjr2"
Addr17
=
"142KsfJLvEA5FJxAgKm9ZDtFVjkRaPdu82"
boards
=
[]
string
{
AddrA
,
AddrB
,
AddrC
,
AddrD
,
"12HKLEn6g4FH39yUbHh4EVJWcFo5CXg22d"
,
"1Ka7EPFRqs3v9yreXG6qA4RQbNmbPJCZPj"
,
"12cjnN5D4DPdBQSwh6vjwJbtsW4EJALTMv"
,
"1Luh4AziYyaC5zP3hUXtXFZS873xAxm6rH"
,
"1NNaYHkscJaLJ2wUrFNeh6cQXBS4TrFYeB"
,
"1L1puAUjfmtDECKo2C1qLWsAMZtDGTBWf6"
,
"1LNf9AVXzUMQkQM5hgGLhkdrVtD8UMBSUm"
,
"1PcGKYYoLn1PLLJJodc1UpgWGeFAQasAkx"
,
"1BM2xhBk95qoae8zKNDWwAVGgBERhb7DQu"
,
"1Q9sQwothzM1gKSzkVZ8Dt1tqKX1uzSagx"
,
"15VUiygdxMSZ3rykwe742yomp2cPJ9Tfve"
,
"1DyR84CU5AHbGXLEnhHMwMvWNMeunLZsuJ"
,
"132pBvrgSYgHASxzoeL3bqnsqUpaBbUktm"
,
"1DEV4XwdBUWRkMuy4ARRiEAoxQ2LoDByNG"
,
"18Y87cw2hiYC71bvpD872oYMYXtw66Qp6o"
,
"1Fghq6cgdJEDr6gQBmvba3t6aXAkyZyjr2"
,
"142KsfJLvEA5FJxAgKm9ZDtFVjkRaPdu82"
,
Addr1
,
Addr2
,
Addr3
,
Addr4
,
Addr5
,
Addr6
,
Addr7
,
Addr8
,
Addr9
,
Addr10
,
Addr11
,
Addr12
,
Addr13
,
Addr14
,
Addr15
,
Addr16
,
Addr17
,
}
total
=
types
.
Coin
*
30000
)
...
...
plugin/dapp/autonomy/executor/change_test.go
0 → 100644
View file @
9771febb
// Copyright Fuzamei Corp. 2018 All Rights Reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package
executor
import
(
"testing"
"github.com/33cn/chain33/common/db"
"github.com/33cn/chain33/system/dapp"
"github.com/33cn/chain33/types"
"github.com/33cn/chain33/util"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func
TestExecLocalChange
(
t
*
testing
.
T
)
{
testexecLocalChange
(
t
,
false
)
testexecLocalChange
(
t
,
true
)
}
func
testexecLocalChange
(
t
*
testing
.
T
,
auto
bool
)
{
_
,
sdb
,
kvdb
:=
util
.
CreateTestDB
()
au
:=
&
Autonomy
{}
au
.
SetLocalDB
(
kvdb
)
//TyLogPropChange
cur
:=
&
auty
.
AutonomyProposalChange
{
PropChange
:
&
auty
.
ProposalChange
{},
CurRule
:
&
auty
.
RuleConfig
{},
VoteResult
:
&
auty
.
VoteResult
{},
Status
:
auty
.
AutonomyStatusProposalChange
,
Address
:
"11111111111111"
,
Height
:
1
,
Index
:
2
,
}
receiptChange
:=
&
auty
.
ReceiptProposalChange
{
Prev
:
nil
,
Current
:
cur
,
}
receipt
:=
&
types
.
ReceiptData
{
Logs
:
[]
*
types
.
ReceiptLog
{
{
Ty
:
auty
.
TyLogPropChange
,
Log
:
types
.
Encode
(
receiptChange
)},
},
}
var
set
*
types
.
LocalDBSet
var
err
error
if
!
auto
{
set
,
err
=
au
.
execLocalChange
(
receipt
)
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
}
else
{
tx
,
err
:=
types
.
CreateFormatTx
(
types
.
ExecName
(
auty
.
AutonomyX
),
nil
)
assert
.
NoError
(
t
,
err
)
set
,
err
=
au
.
execAutoLocalChange
(
tx
,
receipt
)
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
}
//save to database
saveKvs
(
sdb
,
set
.
KV
)
// check
checkExecLocalChange
(
t
,
kvdb
,
cur
)
// TyLogRvkPropChange
pre1
:=
copyAutonomyProposalChange
(
cur
)
cur
.
Status
=
auty
.
AutonomyStatusRvkPropChange
receiptChange1
:=
&
auty
.
ReceiptProposalChange
{
Prev
:
pre1
,
Current
:
cur
,
}
if
!
auto
{
set
,
err
=
au
.
execLocalChange
(
&
types
.
ReceiptData
{
Logs
:
[]
*
types
.
ReceiptLog
{
{
Ty
:
auty
.
TyLogRvkPropChange
,
Log
:
types
.
Encode
(
receiptChange1
)},
},
})
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
}
else
{
tx
,
err
:=
types
.
CreateFormatTx
(
types
.
ExecName
(
auty
.
AutonomyX
),
nil
)
assert
.
NoError
(
t
,
err
)
set
,
err
=
au
.
execAutoLocalChange
(
tx
,
&
types
.
ReceiptData
{
Logs
:
[]
*
types
.
ReceiptLog
{
{
Ty
:
auty
.
TyLogRvkPropChange
,
Log
:
types
.
Encode
(
receiptChange1
)},
},
})
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
}
//save to database
saveKvs
(
sdb
,
set
.
KV
)
// check
checkExecLocalChange
(
t
,
kvdb
,
cur
)
// TyLogVotePropChange
cur
.
Status
=
auty
.
AutonomyStatusProposalChange
pre2
:=
copyAutonomyProposalChange
(
cur
)
cur
.
Status
=
auty
.
AutonomyStatusVotePropChange
cur
.
Address
=
"2222222222222"
receiptChange2
:=
&
auty
.
ReceiptProposalChange
{
Prev
:
pre2
,
Current
:
cur
,
}
if
!
auto
{
set
,
err
=
au
.
execLocalChange
(
&
types
.
ReceiptData
{
Logs
:
[]
*
types
.
ReceiptLog
{
{
Ty
:
auty
.
TyLogVotePropChange
,
Log
:
types
.
Encode
(
receiptChange2
)},
},
})
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
}
else
{
tx
,
err
:=
types
.
CreateFormatTx
(
types
.
ExecName
(
auty
.
AutonomyX
),
nil
)
assert
.
NoError
(
t
,
err
)
set
,
err
=
au
.
execAutoLocalChange
(
tx
,
&
types
.
ReceiptData
{
Logs
:
[]
*
types
.
ReceiptLog
{
{
Ty
:
auty
.
TyLogVotePropChange
,
Log
:
types
.
Encode
(
receiptChange2
)},
},
})
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
}
//save to database
saveKvs
(
sdb
,
set
.
KV
)
// check
checkExecLocalChange
(
t
,
kvdb
,
cur
)
}
func
TestExecDelLocalChange
(
t
*
testing
.
T
)
{
testexecDelLocalChange
(
t
)
}
func
testexecDelLocalChange
(
t
*
testing
.
T
)
{
_
,
sdb
,
kvdb
:=
util
.
CreateTestDB
()
au
:=
&
Autonomy
{}
au
.
SetLocalDB
(
kvdb
)
//TyLogPropChange
cur
:=
&
auty
.
AutonomyProposalChange
{
PropChange
:
&
auty
.
ProposalChange
{},
CurRule
:
&
auty
.
RuleConfig
{},
VoteResult
:
&
auty
.
VoteResult
{},
Status
:
auty
.
AutonomyStatusProposalChange
,
Address
:
"11111111111111"
,
Height
:
1
,
Index
:
2
,
}
receiptChange
:=
&
auty
.
ReceiptProposalChange
{
Prev
:
nil
,
Current
:
cur
,
}
receipt
:=
&
types
.
ReceiptData
{
Logs
:
[]
*
types
.
ReceiptLog
{
{
Ty
:
auty
.
TyLogPropChange
,
Log
:
types
.
Encode
(
receiptChange
)},
},
}
// 先执行local然后进行删除
tx
,
err
:=
types
.
CreateFormatTx
(
types
.
ExecName
(
auty
.
AutonomyX
),
nil
)
assert
.
NoError
(
t
,
err
)
set
,
err
:=
au
.
execAutoLocalChange
(
tx
,
receipt
)
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
saveKvs
(
sdb
,
set
.
KV
)
set
,
err
=
au
.
execAutoDelLocal
(
tx
,
receipt
)
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
saveKvs
(
sdb
,
set
.
KV
)
// check
table
:=
NewChangeTable
(
au
.
GetLocalDB
())
query
:=
table
.
GetQuery
(
kvdb
)
_
,
err
=
query
.
ListIndex
(
"primary"
,
nil
,
nil
,
10
,
0
)
assert
.
Equal
(
t
,
err
,
types
.
ErrNotFound
)
_
,
err
=
query
.
ListIndex
(
"addr"
,
nil
,
nil
,
10
,
0
)
assert
.
Equal
(
t
,
err
,
types
.
ErrNotFound
)
_
,
err
=
query
.
ListIndex
(
"status"
,
nil
,
nil
,
10
,
0
)
assert
.
Equal
(
t
,
err
,
types
.
ErrNotFound
)
_
,
err
=
query
.
ListIndex
(
"addr_status"
,
nil
,
nil
,
10
,
0
)
assert
.
Equal
(
t
,
err
,
types
.
ErrNotFound
)
// TyLogVotePropChange
pre1
:=
copyAutonomyProposalChange
(
cur
)
cur
.
Status
=
auty
.
AutonomyStatusVotePropChange
receiptChange2
:=
&
auty
.
ReceiptProposalChange
{
Prev
:
pre1
,
Current
:
cur
,
}
recpt
:=
&
types
.
ReceiptData
{
Logs
:
[]
*
types
.
ReceiptLog
{
{
Ty
:
auty
.
TyLogVotePropChange
,
Log
:
types
.
Encode
(
receiptChange2
)},
}}
// 先执行local然后进行删除
// 自动回退测试时候,需要先设置一个前置状态
tx
,
err
=
types
.
CreateFormatTx
(
types
.
ExecName
(
auty
.
AutonomyX
),
nil
)
assert
.
NoError
(
t
,
err
)
set
,
err
=
au
.
execAutoLocalChange
(
tx
,
receipt
)
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
saveKvs
(
sdb
,
set
.
KV
)
// 正常测试退回
tx
,
err
=
types
.
CreateFormatTx
(
types
.
ExecName
(
auty
.
AutonomyX
),
nil
)
assert
.
NoError
(
t
,
err
)
set
,
err
=
au
.
execAutoLocalChange
(
tx
,
recpt
)
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
saveKvs
(
sdb
,
set
.
KV
)
// check
checkExecLocalChange
(
t
,
kvdb
,
cur
)
set
,
err
=
au
.
execAutoDelLocal
(
tx
,
recpt
)
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
saveKvs
(
sdb
,
set
.
KV
)
// check
checkExecLocalChange
(
t
,
kvdb
,
pre1
)
}
func
TestGetProposalChange
(
t
*
testing
.
T
)
{
au
:=
&
Autonomy
{
dapp
.
DriverBase
{},
}
_
,
storedb
,
_
:=
util
.
CreateTestDB
()
au
.
SetStateDB
(
storedb
)
tx
:=
"1111111111111111111"
storedb
.
Set
(
propChangeID
(
tx
),
types
.
Encode
(
&
auty
.
AutonomyProposalChange
{}))
rsp
,
err
:=
au
.
getProposalChange
(
&
types
.
ReqString
{
Data
:
tx
})
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
rsp
)
require
.
Equal
(
t
,
len
(
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
),
1
)
}
func
TestListProposalChange
(
t
*
testing
.
T
)
{
au
:=
&
Autonomy
{
dapp
.
DriverBase
{},
}
_
,
sdb
,
kvdb
:=
util
.
CreateTestDB
()
au
.
SetLocalDB
(
kvdb
)
type
statu
struct
{
status
int32
height
int64
index
int64
}
testcase1
:=
[]
statu
{
{
auty
.
AutonomyStatusRvkPropChange
,
10
,
2
},
{
auty
.
AutonomyStatusVotePropChange
,
15
,
1
},
{
auty
.
AutonomyStatusTmintPropChange
,
20
,
1
},
}
testcase2
:=
[]
statu
{
{
auty
.
AutonomyStatusProposalChange
,
10
,
1
},
{
auty
.
AutonomyStatusProposalChange
,
20
,
2
},
{
auty
.
AutonomyStatusProposalChange
,
20
,
5
},
}
var
testcase
[]
statu
testcase
=
append
(
testcase
,
testcase1
...
)
testcase
=
append
(
testcase
,
testcase2
...
)
cur
:=
&
auty
.
AutonomyProposalChange
{
PropChange
:
&
auty
.
ProposalChange
{},
CurRule
:
&
auty
.
RuleConfig
{},
VoteResult
:
&
auty
.
VoteResult
{},
Status
:
auty
.
AutonomyStatusProposalChange
,
Address
:
"11111111111111"
,
Height
:
1
,
Index
:
2
,
}
//将数据保存下去
var
kvs
[]
*
types
.
KeyValue
table
:=
NewChangeTable
(
kvdb
)
for
_
,
tcase
:=
range
testcase
{
cur
.
Status
=
tcase
.
status
cur
.
Height
=
tcase
.
height
cur
.
Index
=
int32
(
tcase
.
index
)
err
:=
table
.
Replace
(
cur
)
require
.
NoError
(
t
,
err
)
kv
,
err
:=
table
.
Save
()
require
.
NoError
(
t
,
err
)
kvs
=
append
(
kvs
,
kv
...
)
}
saveKvs
(
sdb
,
kvs
)
// 反向查找
req
:=
&
auty
.
ReqQueryProposalChange
{
Status
:
auty
.
AutonomyStatusProposalChange
,
Count
:
10
,
Direction
:
0
,
Index
:
-
1
,
}
rsp
,
err
:=
au
.
listProposalChange
(
req
)
require
.
NoError
(
t
,
err
)
require
.
Equal
(
t
,
len
(
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
),
len
(
testcase2
))
k
:=
2
for
_
,
tcase
:=
range
testcase2
{
require
.
Equal
(
t
,
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
[
k
]
.
Height
,
tcase
.
height
)
require
.
Equal
(
t
,
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
[
k
]
.
Index
,
int32
(
tcase
.
index
))
k
--
}
// 正向查找
req
=
&
auty
.
ReqQueryProposalChange
{
Status
:
auty
.
AutonomyStatusProposalChange
,
Count
:
10
,
Direction
:
1
,
Index
:
-
1
,
}
rsp
,
err
=
au
.
listProposalChange
(
req
)
require
.
NoError
(
t
,
err
)
require
.
Equal
(
t
,
len
(
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
),
len
(
testcase2
))
for
i
,
tcase
:=
range
testcase2
{
require
.
Equal
(
t
,
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
[
i
]
.
Height
,
tcase
.
height
)
require
.
Equal
(
t
,
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
[
i
]
.
Index
,
int32
(
tcase
.
index
))
}
// 翻页查找
req
=
&
auty
.
ReqQueryProposalChange
{
Status
:
auty
.
AutonomyStatusProposalChange
,
Count
:
1
,
Direction
:
0
,
Index
:
-
1
,
}
rsp
,
err
=
au
.
listProposalChange
(
req
)
require
.
NoError
(
t
,
err
)
require
.
Equal
(
t
,
len
(
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
),
1
)
height
:=
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
[
0
]
.
Height
index
:=
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
[
0
]
.
Index
require
.
Equal
(
t
,
height
,
testcase2
[
2
]
.
height
)
require
.
Equal
(
t
,
index
,
int32
(
testcase2
[
2
]
.
index
))
//
req
=
&
auty
.
ReqQueryProposalChange
{
Status
:
auty
.
AutonomyStatusProposalChange
,
Count
:
10
,
Direction
:
0
,
Height
:
height
,
Index
:
index
,
}
rsp
,
err
=
au
.
listProposalChange
(
req
)
require
.
NoError
(
t
,
err
)
require
.
Equal
(
t
,
len
(
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
),
2
)
require
.
Equal
(
t
,
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
[
0
]
.
Height
,
testcase2
[
1
]
.
height
)
require
.
Equal
(
t
,
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
[
0
]
.
Index
,
int32
(
testcase2
[
1
]
.
index
))
require
.
Equal
(
t
,
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
[
1
]
.
Height
,
testcase2
[
0
]
.
height
)
require
.
Equal
(
t
,
rsp
.
(
*
auty
.
ReplyQueryProposalChange
)
.
PropChanges
[
1
]
.
Index
,
int32
(
testcase2
[
0
]
.
index
))
}
func
checkExecLocalChange
(
t
*
testing
.
T
,
kvdb
db
.
KVDB
,
cur
*
auty
.
AutonomyProposalChange
)
{
table
:=
NewChangeTable
(
kvdb
)
query
:=
table
.
GetQuery
(
kvdb
)
rows
,
err
:=
query
.
ListIndex
(
"primary"
,
nil
,
nil
,
10
,
0
)
assert
.
Equal
(
t
,
err
,
nil
)
assert
.
Equal
(
t
,
string
(
rows
[
0
]
.
Primary
),
dapp
.
HeightIndexStr
(
1
,
2
))
rows
,
err
=
query
.
ListIndex
(
"addr"
,
nil
,
nil
,
10
,
0
)
assert
.
Equal
(
t
,
err
,
nil
)
assert
.
Equal
(
t
,
1
,
len
(
rows
))
rows
,
err
=
query
.
ListIndex
(
"status"
,
nil
,
nil
,
10
,
0
)
assert
.
Equal
(
t
,
err
,
nil
)
assert
.
Equal
(
t
,
1
,
len
(
rows
))
rows
,
err
=
query
.
ListIndex
(
"addr_status"
,
nil
,
nil
,
10
,
0
)
assert
.
Equal
(
t
,
err
,
nil
)
assert
.
Equal
(
t
,
1
,
len
(
rows
))
prop
,
ok
:=
rows
[
0
]
.
Data
.
(
*
auty
.
AutonomyProposalChange
)
assert
.
Equal
(
t
,
true
,
ok
)
assert
.
Equal
(
t
,
prop
.
Status
,
cur
.
Status
)
assert
.
Equal
(
t
,
prop
.
Address
,
cur
.
Address
)
assert
.
Equal
(
t
,
prop
.
Height
,
cur
.
Height
)
assert
.
Equal
(
t
,
prop
.
Index
,
cur
.
Index
)
}
plugin/dapp/autonomy/executor/changeaction.go
View file @
9771febb
...
...
@@ -8,10 +8,8 @@ import (
"github.com/33cn/chain33/common"
"github.com/33cn/chain33/types"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
)
func
(
a
*
action
)
propChange
(
prob
*
auty
.
ProposalChange
)
(
*
types
.
Receipt
,
error
)
{
//如果全小于等于0,则说明该提案规则参数不正确
if
prob
==
nil
||
len
(
prob
.
Changes
)
==
0
{
...
...
@@ -59,7 +57,7 @@ func (a *action) propChange(prob *auty.ProposalChange) (*types.Receipt, error) {
PropChange
:
prob
,
CurRule
:
rule
,
Board
:
new
,
VoteResult
:
&
auty
.
VoteResult
{
TotalVotes
:
int32
(
len
(
act
.
Boards
))},
VoteResult
:
&
auty
.
VoteResult
{
TotalVotes
:
int32
(
len
(
act
.
Boards
))},
Status
:
auty
.
AutonomyStatusProposalChange
,
Address
:
a
.
fromaddr
,
Height
:
a
.
height
,
...
...
@@ -168,15 +166,10 @@ func (a *action) votePropChange(voteProb *auty.VoteProposalChange) (*types.Recei
// 更新投票记录
votes
.
Address
=
append
(
votes
.
Address
,
a
.
fromaddr
)
// 获取可投票数
vtCouts
,
err
:=
a
.
getAddressVotes
(
a
.
fromaddr
,
start
)
if
err
!=
nil
{
return
nil
,
err
}
if
voteProb
.
Approve
{
cur
.
VoteResult
.
ApproveVotes
+=
vtCouts
cur
.
VoteResult
.
ApproveVotes
++
}
else
{
cur
.
VoteResult
.
OpposeVotes
+=
vtCouts
cur
.
VoteResult
.
OpposeVotes
++
}
var
logs
[]
*
types
.
ReceiptLog
...
...
@@ -359,13 +352,14 @@ func copyAutonomyProposalChange(cur *auty.AutonomyProposalChange) *auty.Autonomy
}
newAut
:=
*
cur
if
cur
.
PropChange
!=
nil
{
newPropChange
:=
*
cur
.
GetPropChange
()
newPropChange
:=
*
cur
.
PropChange
newAut
.
PropChange
=
&
newPropChange
if
cur
.
PropChange
.
Changes
!=
nil
{
chs
:=
cur
.
GetPropChange
()
.
GetChanges
()
for
_
,
ch
:=
range
chs
{
newAut
.
PropChange
.
Changes
=
make
([]
*
auty
.
Change
,
len
(
cur
.
PropChange
.
Changes
))
chs
:=
cur
.
PropChange
.
Changes
for
i
,
ch
:=
range
chs
{
newch
:=
*
ch
newAut
.
PropChange
.
Changes
=
append
(
newAut
.
PropChange
.
Changes
,
&
newch
)
newAut
.
PropChange
.
Changes
[
i
]
=
&
newch
}
}
}
...
...
@@ -375,6 +369,10 @@ func copyAutonomyProposalChange(cur *auty.AutonomyProposalChange) *auty.Autonomy
}
if
cur
.
Board
!=
nil
{
newBoard
:=
*
cur
.
GetBoard
()
newBoard
.
Boards
=
make
([]
string
,
len
(
cur
.
Board
.
Boards
))
copy
(
newBoard
.
Boards
,
cur
.
Board
.
Boards
)
newBoard
.
Revboards
=
make
([]
string
,
len
(
cur
.
Board
.
Revboards
))
copy
(
newBoard
.
Revboards
,
cur
.
Board
.
Revboards
)
newAut
.
Board
=
&
newBoard
}
if
cur
.
VoteResult
!=
nil
{
...
...
plugin/dapp/autonomy/executor/changeaction_test.go
0 → 100644
View file @
9771febb
// Copyright Fuzamei Corp. 2018 All Rights Reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package
executor
import
(
"testing"
"github.com/33cn/chain33/account"
apimock
"github.com/33cn/chain33/client/mocks"
"github.com/33cn/chain33/common"
"github.com/33cn/chain33/common/address"
dbm
"github.com/33cn/chain33/common/db"
_
"github.com/33cn/chain33/system"
drivers
"github.com/33cn/chain33/system/dapp"
"github.com/33cn/chain33/types"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/mock"
"github.com/stretchr/testify/require"
)
func
InitChange
(
t
*
testing
.
T
,
stateDB
dbm
.
KV
)
{
act
:=
&
auty
.
ActiveBoard
{
Boards
:
boards
,
}
err
:=
stateDB
.
Set
(
activeBoardID
(),
types
.
Encode
(
act
))
assert
.
NoError
(
t
,
err
)
}
func
TestRevokeProposalChange
(
t
*
testing
.
T
)
{
env
,
exec
,
stateDB
,
kvdb
:=
InitEnv
()
InitChange
(
t
,
stateDB
)
// PropChange
testPropChange
(
t
,
env
,
exec
,
stateDB
,
kvdb
,
true
)
//RevokeProposalChange
revokeProposalChange
(
t
,
env
,
exec
,
stateDB
,
kvdb
,
false
)
}
func
TestVoteProposalChange
(
t
*
testing
.
T
)
{
env
,
exec
,
stateDB
,
kvdb
:=
InitEnv
()
InitChange
(
t
,
stateDB
)
// PropChange
testPropChange
(
t
,
env
,
exec
,
stateDB
,
kvdb
,
true
)
//voteProposalChange
voteProposalChange
(
t
,
env
,
exec
,
stateDB
,
kvdb
,
true
)
}
func
TestTerminateProposalChange
(
t
*
testing
.
T
)
{
env
,
exec
,
stateDB
,
kvdb
:=
InitEnv
()
InitChange
(
t
,
stateDB
)
// PropChange
testPropChange
(
t
,
env
,
exec
,
stateDB
,
kvdb
,
true
)
//terminateProposalChange
terminateProposalChange
(
t
,
env
,
exec
,
stateDB
,
kvdb
,
true
)
}
func
testPropChange
(
t
*
testing
.
T
,
env
*
ExecEnv
,
exec
drivers
.
Driver
,
stateDB
dbm
.
KV
,
kvdb
dbm
.
KVDB
,
save
bool
)
{
opt1
:=
&
auty
.
ProposalChange
{
Year
:
2019
,
Month
:
7
,
Day
:
10
,
Changes
:
[]
*
auty
.
Change
{{
Cancel
:
true
,
Addr
:
AddrA
}},
StartBlockHeight
:
env
.
blockHeight
+
5
,
EndBlockHeight
:
env
.
blockHeight
+
10
,
}
pbtx
,
err
:=
propChangeTx
(
opt1
)
require
.
NoError
(
t
,
err
)
pbtx
,
err
=
signTx
(
pbtx
,
PrivKeyA
)
require
.
NoError
(
t
,
err
)
exec
.
SetEnv
(
env
.
blockHeight
,
env
.
blockTime
,
env
.
difficulty
)
receipt
,
err
:=
exec
.
Exec
(
pbtx
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
receipt
)
if
save
{
for
_
,
kv
:=
range
receipt
.
KV
{
stateDB
.
Set
(
kv
.
Key
,
kv
.
Value
)
}
}
// local
receiptData
:=
&
types
.
ReceiptData
{
Ty
:
receipt
.
Ty
,
Logs
:
receipt
.
Logs
}
set
,
err
:=
exec
.
ExecLocal
(
pbtx
,
receiptData
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
if
save
{
for
_
,
kv
:=
range
set
.
KV
{
kvdb
.
Set
(
kv
.
Key
,
kv
.
Value
)
}
}
// 更新tahash
env
.
txHash
=
common
.
ToHex
(
pbtx
.
Hash
())
env
.
startHeight
=
opt1
.
StartBlockHeight
env
.
endHeight
=
opt1
.
EndBlockHeight
// check
accCoin
:=
account
.
NewCoinsAccount
()
accCoin
.
SetDB
(
stateDB
)
account
:=
accCoin
.
LoadExecAccount
(
AddrA
,
address
.
ExecAddress
(
auty
.
AutonomyX
))
require
.
Equal
(
t
,
proposalAmount
,
account
.
Frozen
)
}
func
propChangeTx
(
parm
*
auty
.
ProposalChange
)
(
*
types
.
Transaction
,
error
)
{
if
parm
==
nil
{
return
nil
,
types
.
ErrInvalidParam
}
val
:=
&
auty
.
AutonomyAction
{
Ty
:
auty
.
AutonomyActionPropChange
,
Value
:
&
auty
.
AutonomyAction_PropChange
{
PropChange
:
parm
},
}
return
types
.
CreateFormatTx
(
types
.
ExecName
(
auty
.
AutonomyX
),
types
.
Encode
(
val
))
}
func
revokeProposalChange
(
t
*
testing
.
T
,
env
*
ExecEnv
,
exec
drivers
.
Driver
,
stateDB
dbm
.
KV
,
kvdb
dbm
.
KVDB
,
save
bool
)
{
proposalID
:=
env
.
txHash
opt2
:=
&
auty
.
RevokeProposalChange
{
ProposalID
:
proposalID
,
}
rtx
,
err
:=
revokeProposalChangeTx
(
opt2
)
require
.
NoError
(
t
,
err
)
rtx
,
err
=
signTx
(
rtx
,
PrivKeyA
)
require
.
NoError
(
t
,
err
)
exec
.
SetEnv
(
env
.
blockHeight
,
env
.
blockTime
,
env
.
difficulty
)
receipt
,
err
:=
exec
.
Exec
(
rtx
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
receipt
)
if
save
{
for
_
,
kv
:=
range
receipt
.
KV
{
stateDB
.
Set
(
kv
.
Key
,
kv
.
Value
)
}
}
receiptData
:=
&
types
.
ReceiptData
{
Ty
:
receipt
.
Ty
,
Logs
:
receipt
.
Logs
}
set
,
err
:=
exec
.
ExecLocal
(
rtx
,
receiptData
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
if
save
{
for
_
,
kv
:=
range
set
.
KV
{
kvdb
.
Set
(
kv
.
Key
,
kv
.
Value
)
}
}
// del
set
,
err
=
exec
.
ExecDelLocal
(
rtx
,
receiptData
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
// check
accCoin
:=
account
.
NewCoinsAccount
()
accCoin
.
SetDB
(
stateDB
)
account
:=
accCoin
.
LoadExecAccount
(
AddrA
,
address
.
ExecAddress
(
auty
.
AutonomyX
))
require
.
Equal
(
t
,
int64
(
0
),
account
.
Frozen
)
}
func
revokeProposalChangeTx
(
parm
*
auty
.
RevokeProposalChange
)
(
*
types
.
Transaction
,
error
)
{
if
parm
==
nil
{
return
nil
,
types
.
ErrInvalidParam
}
val
:=
&
auty
.
AutonomyAction
{
Ty
:
auty
.
AutonomyActionRvkPropChange
,
Value
:
&
auty
.
AutonomyAction_RvkPropChange
{
RvkPropChange
:
parm
},
}
return
types
.
CreateFormatTx
(
types
.
ExecName
(
auty
.
AutonomyX
),
types
.
Encode
(
val
))
}
func
voteProposalChange
(
t
*
testing
.
T
,
env
*
ExecEnv
,
exec
drivers
.
Driver
,
stateDB
dbm
.
KV
,
kvdb
dbm
.
KVDB
,
save
bool
)
{
api
:=
new
(
apimock
.
QueueProtocolAPI
)
api
.
On
(
"StoreList"
,
mock
.
Anything
)
.
Return
(
&
types
.
StoreListReply
{},
nil
)
api
.
On
(
"GetLastHeader"
,
mock
.
Anything
)
.
Return
(
&
types
.
Header
{
StateHash
:
[]
byte
(
""
)},
nil
)
hear
:=
&
types
.
Header
{
StateHash
:
[]
byte
(
""
)}
api
.
On
(
"GetHeaders"
,
mock
.
Anything
)
.
Return
(
&
types
.
Headers
{
Items
:
[]
*
types
.
Header
{
hear
}},
nil
)
acc
:=
&
types
.
Account
{
Currency
:
0
,
Balance
:
total
*
4
,
}
val
:=
types
.
Encode
(
acc
)
values
:=
[][]
byte
{
val
}
api
.
On
(
"StoreGet"
,
mock
.
Anything
)
.
Return
(
&
types
.
StoreReplyValue
{
Values
:
values
},
nil
)
.
Once
()
acc
=
&
types
.
Account
{
Currency
:
0
,
Frozen
:
total
,
}
val1
:=
types
.
Encode
(
acc
)
values1
:=
[][]
byte
{
val1
}
api
.
On
(
"StoreGet"
,
mock
.
Anything
)
.
Return
(
&
types
.
StoreReplyValue
{
Values
:
values1
},
nil
)
.
Once
()
exec
.
SetAPI
(
api
)
proposalID
:=
env
.
txHash
type
record
struct
{
priv
string
appr
bool
}
records
:=
[]
record
{
//{PrivKeyA, false},
{
PrivKeyB
,
true
},
{
PrivKeyC
,
true
},
{
PrivKeyD
,
true
},
{
PrivKey1
,
false
},
{
PrivKey2
,
true
},
{
PrivKey3
,
true
},
{
PrivKey4
,
true
},
{
PrivKey5
,
true
},
{
PrivKey6
,
true
},
{
PrivKey7
,
true
},
{
PrivKey8
,
true
},
{
PrivKey9
,
true
},
{
PrivKey10
,
true
},
{
PrivKey11
,
true
},
{
PrivKey12
,
true
},
}
for
_
,
record
:=
range
records
{
opt
:=
&
auty
.
VoteProposalChange
{
ProposalID
:
proposalID
,
Approve
:
record
.
appr
,
}
tx
,
err
:=
voteProposalChangeTx
(
opt
)
require
.
NoError
(
t
,
err
)
tx
,
err
=
signTx
(
tx
,
record
.
priv
)
require
.
NoError
(
t
,
err
)
// 设定当前高度为投票高度
exec
.
SetEnv
(
env
.
startHeight
,
env
.
blockTime
,
env
.
difficulty
)
receipt
,
err
:=
exec
.
Exec
(
tx
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
receipt
)
if
save
{
for
_
,
kv
:=
range
receipt
.
KV
{
stateDB
.
Set
(
kv
.
Key
,
kv
.
Value
)
}
}
receiptData
:=
&
types
.
ReceiptData
{
Ty
:
receipt
.
Ty
,
Logs
:
receipt
.
Logs
}
set
,
err
:=
exec
.
ExecLocal
(
tx
,
receiptData
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
if
save
{
for
_
,
kv
:=
range
set
.
KV
{
kvdb
.
Set
(
kv
.
Key
,
kv
.
Value
)
}
}
// del
set
,
err
=
exec
.
ExecDelLocal
(
tx
,
receiptData
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
// 每次需要重新设置
acc
:=
&
types
.
Account
{
Currency
:
0
,
Frozen
:
total
,
}
val
:=
types
.
Encode
(
acc
)
values
:=
[][]
byte
{
val
}
api
.
On
(
"StoreGet"
,
mock
.
Anything
)
.
Return
(
&
types
.
StoreReplyValue
{
Values
:
values
},
nil
)
.
Once
()
exec
.
SetAPI
(
api
)
}
// check
// balance
accCoin
:=
account
.
NewCoinsAccount
()
accCoin
.
SetDB
(
stateDB
)
account
:=
accCoin
.
LoadExecAccount
(
AddrA
,
address
.
ExecAddress
(
auty
.
AutonomyX
))
require
.
Equal
(
t
,
int64
(
0
),
account
.
Frozen
)
account
=
accCoin
.
LoadExecAccount
(
autonomyFundAddr
,
address
.
ExecAddress
(
auty
.
AutonomyX
))
require
.
Equal
(
t
,
int64
(
proposalAmount
),
account
.
Balance
)
// status
value
,
err
:=
stateDB
.
Get
(
propChangeID
(
proposalID
))
require
.
NoError
(
t
,
err
)
cur
:=
&
auty
.
AutonomyProposalChange
{}
err
=
types
.
Decode
(
value
,
cur
)
require
.
NoError
(
t
,
err
)
require
.
Equal
(
t
,
int32
(
auty
.
AutonomyStatusTmintPropChange
),
cur
.
Status
)
require
.
Equal
(
t
,
AddrA
,
cur
.
Address
)
require
.
Equal
(
t
,
true
,
cur
.
VoteResult
.
Pass
)
value
,
err
=
stateDB
.
Get
(
activeBoardID
())
require
.
NoError
(
t
,
err
)
act
:=
&
auty
.
ActiveBoard
{}
err
=
types
.
Decode
(
value
,
act
)
require
.
NoError
(
t
,
err
)
require
.
Equal
(
t
,
act
.
Revboards
[
0
],
AddrA
)
require
.
Equal
(
t
,
len
(
act
.
Boards
),
len
(
boards
)
-
1
)
}
func
voteProposalChangeTx
(
parm
*
auty
.
VoteProposalChange
)
(
*
types
.
Transaction
,
error
)
{
if
parm
==
nil
{
return
nil
,
types
.
ErrInvalidParam
}
val
:=
&
auty
.
AutonomyAction
{
Ty
:
auty
.
AutonomyActionVotePropChange
,
Value
:
&
auty
.
AutonomyAction_VotePropChange
{
VotePropChange
:
parm
},
}
return
types
.
CreateFormatTx
(
types
.
ExecName
(
auty
.
AutonomyX
),
types
.
Encode
(
val
))
}
func
terminateProposalChange
(
t
*
testing
.
T
,
env
*
ExecEnv
,
exec
drivers
.
Driver
,
stateDB
dbm
.
KV
,
kvdb
dbm
.
KVDB
,
save
bool
)
{
api
:=
new
(
apimock
.
QueueProtocolAPI
)
api
.
On
(
"StoreList"
,
mock
.
Anything
)
.
Return
(
&
types
.
StoreListReply
{},
nil
)
api
.
On
(
"GetLastHeader"
,
mock
.
Anything
)
.
Return
(
&
types
.
Header
{
StateHash
:
[]
byte
(
""
)},
nil
)
hear
:=
&
types
.
Header
{
StateHash
:
[]
byte
(
""
)}
api
.
On
(
"GetHeaders"
,
mock
.
Anything
)
.
Return
(
&
types
.
Headers
{
Items
:
[]
*
types
.
Header
{
hear
}},
nil
)
acc
:=
&
types
.
Account
{
Currency
:
0
,
Balance
:
total
*
4
,
}
val
:=
types
.
Encode
(
acc
)
values
:=
[][]
byte
{
val
}
api
.
On
(
"StoreGet"
,
mock
.
Anything
)
.
Return
(
&
types
.
StoreReplyValue
{
Values
:
values
},
nil
)
.
Once
()
exec
.
SetAPI
(
api
)
proposalID
:=
env
.
txHash
opt
:=
&
auty
.
TerminateProposalChange
{
ProposalID
:
proposalID
,
}
tx
,
err
:=
terminateProposalChangeTx
(
opt
)
require
.
NoError
(
t
,
err
)
tx
,
err
=
signTx
(
tx
,
PrivKeyA
)
require
.
NoError
(
t
,
err
)
exec
.
SetEnv
(
env
.
endHeight
+
1
,
env
.
blockTime
,
env
.
difficulty
)
receipt
,
err
:=
exec
.
Exec
(
tx
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
receipt
)
if
save
{
for
_
,
kv
:=
range
receipt
.
KV
{
stateDB
.
Set
(
kv
.
Key
,
kv
.
Value
)
}
}
receiptData
:=
&
types
.
ReceiptData
{
Ty
:
receipt
.
Ty
,
Logs
:
receipt
.
Logs
}
set
,
err
:=
exec
.
ExecLocal
(
tx
,
receiptData
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
if
save
{
for
_
,
kv
:=
range
set
.
KV
{
kvdb
.
Set
(
kv
.
Key
,
kv
.
Value
)
}
}
// del
set
,
err
=
exec
.
ExecDelLocal
(
tx
,
receiptData
,
int
(
1
))
require
.
NoError
(
t
,
err
)
require
.
NotNil
(
t
,
set
)
// check
accCoin
:=
account
.
NewCoinsAccount
()
accCoin
.
SetDB
(
stateDB
)
account
:=
accCoin
.
LoadExecAccount
(
AddrA
,
address
.
ExecAddress
(
auty
.
AutonomyX
))
require
.
Equal
(
t
,
int64
(
0
),
account
.
Frozen
)
}
func
terminateProposalChangeTx
(
parm
*
auty
.
TerminateProposalChange
)
(
*
types
.
Transaction
,
error
)
{
if
parm
==
nil
{
return
nil
,
types
.
ErrInvalidParam
}
val
:=
&
auty
.
AutonomyAction
{
Ty
:
auty
.
AutonomyActionTmintPropChange
,
Value
:
&
auty
.
AutonomyAction_TmintPropChange
{
TmintPropChange
:
parm
},
}
return
types
.
CreateFormatTx
(
types
.
ExecName
(
auty
.
AutonomyX
),
types
.
Encode
(
val
))
}
func
TestGetChangeReceiptLog
(
t
*
testing
.
T
)
{
pre
:=
&
auty
.
AutonomyProposalChange
{
PropChange
:
&
auty
.
ProposalChange
{
Year
:
1800
,
Month
:
1
},
VoteResult
:
&
auty
.
VoteResult
{
TotalVotes
:
100
},
Status
:
1
,
Address
:
"121"
,
}
cur
:=
&
auty
.
AutonomyProposalChange
{
PropChange
:
&
auty
.
ProposalChange
{
Year
:
1900
,
Month
:
1
},
VoteResult
:
&
auty
.
VoteResult
{
TotalVotes
:
100
},
Status
:
2
,
Address
:
"123"
,
}
log
:=
getChangeReceiptLog
(
pre
,
cur
,
2
)
require
.
Equal
(
t
,
int32
(
2
),
log
.
Ty
)
recpt
:=
&
auty
.
ReceiptProposalChange
{}
err
:=
types
.
Decode
(
log
.
Log
,
recpt
)
require
.
NoError
(
t
,
err
)
require
.
Equal
(
t
,
int32
(
1800
),
recpt
.
Prev
.
PropChange
.
Year
)
require
.
Equal
(
t
,
int32
(
1900
),
recpt
.
Current
.
PropChange
.
Year
)
}
func
TestCheckChangeable
(
t
*
testing
.
T
)
{
at
:=
newAutonomy
()
.
(
*
Autonomy
)
tx
:=
&
types
.
Transaction
{}
action
:=
newAction
(
at
,
tx
,
0
)
act
:=
&
auty
.
ActiveBoard
{
Boards
:
boards
,
}
// 正常撤销一个地址
changes
:=
[]
*
auty
.
Change
{{
Cancel
:
true
,
Addr
:
AddrA
}}
cur
,
err
:=
action
.
checkChangeable
(
act
,
changes
)
require
.
NoError
(
t
,
err
)
require
.
Equal
(
t
,
len
(
cur
.
Boards
),
len
(
boards
)
-
1
)
require
.
Equal
(
t
,
cur
.
Revboards
[
0
],
AddrA
)
// 恢复撤销地址
changes
=
[]
*
auty
.
Change
{
{
Cancel
:
false
,
Addr
:
AddrA
},
}
ncur
,
err
:=
action
.
checkChangeable
(
cur
,
changes
)
require
.
NoError
(
t
,
err
)
require
.
Equal
(
t
,
len
(
ncur
.
Boards
),
len
(
boards
))
require
.
Equal
(
t
,
len
(
ncur
.
Revboards
),
0
)
// 撤销两个地址,撤销不够最小minBoards
changes
=
[]
*
auty
.
Change
{
{
Cancel
:
true
,
Addr
:
AddrA
},
{
Cancel
:
true
,
Addr
:
AddrB
},
}
_
,
err
=
action
.
checkChangeable
(
act
,
changes
)
require
.
Equal
(
t
,
err
,
auty
.
ErrBoardNumber
)
// 恢复一个没有被撤销的地址
changes
=
[]
*
auty
.
Change
{
{
Cancel
:
false
,
Addr
:
AddrA
},
}
_
,
err
=
action
.
checkChangeable
(
act
,
changes
)
require
.
Equal
(
t
,
err
,
auty
.
ErrChangeBoardAddr
)
// 撤销一个不存在地址
changes
=
[]
*
auty
.
Change
{
{
Cancel
:
true
,
Addr
:
"1111111111"
},
}
_
,
err
=
action
.
checkChangeable
(
act
,
changes
)
require
.
Equal
(
t
,
err
,
auty
.
ErrChangeBoardAddr
)
}
func
TestCopyAutonomyProposalChange
(
t
*
testing
.
T
)
{
require
.
Nil
(
t
,
copyAutonomyProposalChange
(
nil
))
cur
:=
&
auty
.
AutonomyProposalChange
{
PropChange
:
&
auty
.
ProposalChange
{
Year
:
1900
,
Month
:
1
,
Changes
:
[]
*
auty
.
Change
{{
Cancel
:
true
,
Addr
:
"11"
},
{
Cancel
:
false
,
Addr
:
"12"
}},
},
CurRule
:
&
auty
.
RuleConfig
{
BoardApproveRatio
:
100
},
Board
:
&
auty
.
ActiveBoard
{
Boards
:
[]
string
{
"11"
,
"12"
},
Revboards
:
[]
string
{
"13"
,
"15"
},
Amount
:
100
,
},
VoteResult
:
&
auty
.
VoteResult
{
TotalVotes
:
100
},
Status
:
2
,
Address
:
"123"
,
}
pre
:=
copyAutonomyProposalChange
(
cur
)
cur
.
PropChange
.
Year
=
1800
cur
.
PropChange
.
Month
=
2
cur
.
PropChange
.
Changes
[
0
]
.
Cancel
=
false
cur
.
PropChange
.
Changes
[
0
]
.
Addr
=
"21"
cur
.
PropChange
.
Changes
[
1
]
.
Cancel
=
true
cur
.
PropChange
.
Changes
[
1
]
.
Addr
=
"22"
cur
.
CurRule
.
BoardApproveRatio
=
90
cur
.
Board
.
Boards
[
0
]
=
"21"
cur
.
Board
.
Boards
[
1
]
=
"22"
cur
.
Board
.
Revboards
[
0
]
=
"23"
cur
.
Board
.
Revboards
[
0
]
=
"25"
cur
.
Board
.
Amount
=
90
cur
.
VoteResult
.
TotalVotes
=
50
cur
.
Address
=
"234"
cur
.
Status
=
1
assert
.
Equal
(
t
,
1900
,
int
(
pre
.
PropChange
.
Year
))
assert
.
Equal
(
t
,
1
,
int
(
pre
.
PropChange
.
Month
))
assert
.
Equal
(
t
,
&
auty
.
Change
{
Cancel
:
true
,
Addr
:
"11"
},
pre
.
PropChange
.
Changes
[
0
])
assert
.
Equal
(
t
,
&
auty
.
Change
{
Cancel
:
false
,
Addr
:
"12"
},
pre
.
PropChange
.
Changes
[
1
])
assert
.
Equal
(
t
,
"11"
,
pre
.
Board
.
Boards
[
0
])
assert
.
Equal
(
t
,
"12"
,
pre
.
Board
.
Boards
[
1
])
assert
.
Equal
(
t
,
"13"
,
pre
.
Board
.
Revboards
[
0
])
assert
.
Equal
(
t
,
"15"
,
pre
.
Board
.
Revboards
[
1
])
assert
.
Equal
(
t
,
100
,
int
(
pre
.
Board
.
Amount
))
assert
.
Equal
(
t
,
100
,
int
(
pre
.
VoteResult
.
TotalVotes
))
assert
.
Equal
(
t
,
"123"
,
pre
.
Address
)
assert
.
Equal
(
t
,
2
,
int
(
pre
.
Status
))
}
plugin/dapp/autonomy/executor/exec.go
View file @
9771febb
...
...
@@ -105,7 +105,6 @@ func (a *Autonomy) Exec_CommentProp(payload *auty.Comment, tx *types.Transaction
return
action
.
commentProp
(
payload
)
}
// 提案修改董事会成员相关
// Exec_PropChange 创建提案规则
...
...
plugin/dapp/autonomy/executor/exec_local.go
View file @
9771febb
...
...
@@ -85,7 +85,6 @@ func (a *Autonomy) ExecLocal_CommentProp(payload *auty.Comment, tx *types.Transa
return
a
.
execAutoLocalCommentProp
(
tx
,
receiptData
)
}
// 提案修改董事会成员相关
// ExecLocal_PropChange 创建提案规则
...
...
plugin/dapp/autonomy/executor/kv.go
View file @
9771febb
plugin/dapp/autonomy/executor/projectaction.go
View file @
9771febb
...
...
@@ -37,10 +37,10 @@ func (a *action) propProject(prob *auty.ProposalProject) (*types.Receipt, error)
}
// 检查是否可以对已审批额度归0,如果可以则设置kv
var
kva
*
types
.
KeyValue
if
a
.
height
>
pboard
.
StartHeight
+
boardPeriod
{
if
a
.
height
>
pboard
.
StartHeight
+
boardPeriod
{
pboard
.
StartHeight
=
a
.
height
pboard
.
Amount
=
0
kva
=
&
types
.
KeyValue
{
Key
:
activeBoardID
(),
Value
:
types
.
Encode
(
pboard
)}
kva
=
&
types
.
KeyValue
{
Key
:
activeBoardID
(),
Value
:
types
.
Encode
(
pboard
)}
}
// 检查额度
pass
:=
a
.
checkPeriodAmount
(
pboard
,
prob
.
Amount
)
...
...
@@ -593,7 +593,7 @@ func (a *action) checkPeriodAmount(act *auty.ActiveBoard, amount int64) bool {
if
act
==
nil
{
return
false
}
if
act
.
Amount
+
amount
>=
maxBoardPeriodAmount
{
if
act
.
Amount
+
amount
>=
maxBoardPeriodAmount
{
return
false
}
return
true
...
...
@@ -604,10 +604,10 @@ func (a *action) updatePeriodAmount(amount int64) (*types.KeyValue, error) {
if
err
!=
nil
{
return
nil
,
err
}
if
a
.
height
>
act
.
StartHeight
+
boardPeriod
{
if
a
.
height
>
act
.
StartHeight
+
boardPeriod
{
act
.
StartHeight
=
a
.
height
act
.
Amount
=
0
}
act
.
Amount
+=
amount
return
&
types
.
KeyValue
{
Key
:
activeBoardID
(),
Value
:
types
.
Encode
(
act
)},
nil
return
&
types
.
KeyValue
{
Key
:
activeBoardID
(),
Value
:
types
.
Encode
(
act
)},
nil
}
plugin/dapp/autonomy/executor/query.go
View file @
9771febb
plugin/dapp/autonomy/executor/ruleaction.go
View file @
9771febb
...
...
@@ -9,8 +9,8 @@ import (
"github.com/33cn/chain33/types"
auty
"github.com/33cn/plugin/plugin/dapp/autonomy/types"
"github.com/33cn/chain33/system/dapp"
"github.com/33cn/chain33/common/address"
"github.com/33cn/chain33/system/dapp"
)
const
(
...
...
@@ -34,13 +34,12 @@ const (
minProposalAmount
=
types
.
Coin
*
20
// 最大提案金
maxProposalAmount
=
types
.
Coin
*
2000
)
func
(
a
*
action
)
propRule
(
prob
*
auty
.
ProposalRule
)
(
*
types
.
Receipt
,
error
)
{
//如果全小于等于0,则说明该提案规则参数不正确
if
prob
.
RuleCfg
==
nil
||
prob
.
RuleCfg
.
BoardApproveRatio
<=
0
&&
prob
.
RuleCfg
.
PubOpposeRatio
<=
0
&&
prob
.
RuleCfg
.
ProposalAmount
<=
0
&&
prob
.
RuleCfg
.
LargeProjectAmount
<=
0
&&
prob
.
RuleCfg
.
PublicPeriod
<=
0
{
prob
.
RuleCfg
.
ProposalAmount
<=
0
&&
prob
.
RuleCfg
.
LargeProjectAmount
<=
0
&&
prob
.
RuleCfg
.
PublicPeriod
<=
0
{
alog
.
Error
(
"propRule "
,
"ProposalRule RuleCfg invaild or have no modify param"
,
prob
.
RuleCfg
)
return
nil
,
types
.
ErrInvalidParam
}
...
...
@@ -48,7 +47,7 @@ func (a *action) propRule(prob *auty.ProposalRule) (*types.Receipt, error) {
prob
.
RuleCfg
.
PubOpposeRatio
>
maxPubOpposeRatio
||
prob
.
RuleCfg
.
PubOpposeRatio
<
minPubOpposeRatio
||
prob
.
RuleCfg
.
PublicPeriod
>
maxPublicPeriod
||
prob
.
RuleCfg
.
PublicPeriod
<
minPublicPeriod
||
prob
.
RuleCfg
.
LargeProjectAmount
>
maxLargeProjectAmount
||
prob
.
RuleCfg
.
LargeProjectAmount
<
minLargeProjectAmount
||
prob
.
RuleCfg
.
ProposalAmount
>
maxProposalAmount
||
prob
.
RuleCfg
.
ProposalAmount
<
minProposalAmount
{
prob
.
RuleCfg
.
ProposalAmount
>
maxProposalAmount
||
prob
.
RuleCfg
.
ProposalAmount
<
minProposalAmount
{
alog
.
Error
(
"propRule RuleCfg invaild"
,
"ruleCfg"
,
prob
.
RuleCfg
)
return
nil
,
types
.
ErrInvalidParam
}
...
...
plugin/dapp/autonomy/executor/ruleaction_test.go
View file @
9771febb
plugin/dapp/autonomy/types/const.go
View file @
9771febb
...
...
@@ -88,8 +88,6 @@ const (
AutonomyStatusTmintPropChange
)
const
(
// GetProposalBoard 用于在cmd里面的区分不同的查询
GetProposalBoard
=
"GetProposalBoard"
...
...
plugin/dapp/cert/authority/tools/cryptogen/generator/utils/certutils.go
View file @
9771febb
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