keys: implement PublicKeys.Copy()

Implement convenient wrapper over explicit allocation and copying.
This commit is contained in:
Evgenii Stratonikov 2020-06-29 10:44:31 +03:00
parent bbe02ac584
commit 8c18142e8a
4 changed files with 26 additions and 5 deletions

View file

@ -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.

View file

@ -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{}

View file

@ -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)

View file

@ -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)