forked from TrueCloudLab/neoneo-go
keys: implement PublicKeys.Copy()
Implement convenient wrapper over explicit allocation and copying.
This commit is contained in:
parent
bbe02ac584
commit
8c18142e8a
4 changed files with 26 additions and 5 deletions
|
@ -1243,9 +1243,7 @@ func (bc *Blockchain) PoolTx(t *transaction.Transaction) error {
|
||||||
|
|
||||||
//GetStandByValidators returns validators from the configuration.
|
//GetStandByValidators returns validators from the configuration.
|
||||||
func (bc *Blockchain) GetStandByValidators() keys.PublicKeys {
|
func (bc *Blockchain) GetStandByValidators() keys.PublicKeys {
|
||||||
res := make(keys.PublicKeys, len(bc.sbValidators))
|
return bc.sbValidators.Copy()
|
||||||
copy(res, bc.sbValidators)
|
|
||||||
return res
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetValidators returns next block validators.
|
// GetValidators returns next block validators.
|
||||||
|
|
|
@ -55,6 +55,13 @@ func (keys PublicKeys) Contains(pKey *PublicKey) bool {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Copy returns copy of keys.
|
||||||
|
func (keys PublicKeys) Copy() PublicKeys {
|
||||||
|
res := make(PublicKeys, len(keys))
|
||||||
|
copy(res, keys)
|
||||||
|
return res
|
||||||
|
}
|
||||||
|
|
||||||
// Unique returns set of public keys.
|
// Unique returns set of public keys.
|
||||||
func (keys PublicKeys) Unique() PublicKeys {
|
func (keys PublicKeys) Unique() PublicKeys {
|
||||||
unique := PublicKeys{}
|
unique := PublicKeys{}
|
||||||
|
|
|
@ -37,6 +37,23 @@ func TestEncodeDecodePublicKey(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestPublicKeys_Copy(t *testing.T) {
|
||||||
|
pubs := make(PublicKeys, 5)
|
||||||
|
for i := range pubs {
|
||||||
|
priv, err := NewPrivateKey()
|
||||||
|
require.NoError(t, err)
|
||||||
|
pubs[i] = priv.PublicKey()
|
||||||
|
}
|
||||||
|
|
||||||
|
cp := pubs.Copy()
|
||||||
|
priv, err := NewPrivateKey()
|
||||||
|
require.NoError(t, err)
|
||||||
|
cp[0] = priv.PublicKey()
|
||||||
|
|
||||||
|
require.NotEqual(t, pubs[0], cp[0])
|
||||||
|
require.Equal(t, pubs[1:], cp[1:])
|
||||||
|
}
|
||||||
|
|
||||||
func TestNewPublicKeyFromBytes(t *testing.T) {
|
func TestNewPublicKeyFromBytes(t *testing.T) {
|
||||||
priv, err := NewPrivateKey()
|
priv, err := NewPrivateKey()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
|
@ -70,8 +70,7 @@ func TestParameterContext_AddSignatureMultisig(t *testing.T) {
|
||||||
tx := getContractTx()
|
tx := getContractTx()
|
||||||
c := NewParameterContext("Neo.Core.ContractTransaction", tx)
|
c := NewParameterContext("Neo.Core.ContractTransaction", tx)
|
||||||
privs, pubs := getPrivateKeys(t, 4)
|
privs, pubs := getPrivateKeys(t, 4)
|
||||||
pubsCopy := make(keys.PublicKeys, len(pubs))
|
pubsCopy := keys.PublicKeys(pubs).Copy()
|
||||||
copy(pubsCopy, pubs)
|
|
||||||
script, err := smartcontract.CreateMultiSigRedeemScript(3, pubsCopy)
|
script, err := smartcontract.CreateMultiSigRedeemScript(3, pubsCopy)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue