mukan-ibc/modules/light-clients/06-solomachine/proof_test.go
Mukan Erkin Törük 6852832fe8
Some checks failed
CodeQL / Analyze (push) Waiting to run
Docker Build & Push Simapp (main) / docker-build (push) Waiting to run
golangci-lint / lint (push) Waiting to run
Tests / Code Coverage / build (amd64) (push) Waiting to run
Tests / Code Coverage / build (arm64) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[additional-args:-tags="test_e2e" name:e2e path:./e2e]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:08-wasm path:./modules/light-clients/08-wasm]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:ibc-go path:.]) (push) Waiting to run
Deploy to GitHub Pages / Deploy to GitHub Pages (push) Has been cancelled
Buf-Push / push (push) Has been cancelled
initial: sovereign Mukan Network fork
2026-05-11 03:18:28 +03:00

68 lines
1.9 KiB
Go

package solomachine_test
import (
"errors"
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
"github.com/cosmos/cosmos-sdk/types/tx/signing"
solomachine "github.com/cosmos/ibc-go/v10/modules/light-clients/06-solomachine"
)
func (suite *SoloMachineTestSuite) TestVerifySignature() {
cdc := suite.chainA.App.AppCodec()
signBytes := []byte("sign bytes")
singleSignature := suite.solomachine.GenerateSignature(signBytes)
singleSigData, err := solomachine.UnmarshalSignatureData(cdc, singleSignature)
suite.Require().NoError(err)
multiSignature := suite.solomachineMulti.GenerateSignature(signBytes)
multiSigData, err := solomachine.UnmarshalSignatureData(cdc, multiSignature)
suite.Require().NoError(err)
testCases := []struct {
name string
publicKey cryptotypes.PubKey
sigData signing.SignatureData
expErr error
}{
{
"single signature with regular public key",
suite.solomachine.PublicKey,
singleSigData,
nil,
},
{
"multi signature with multisig public key",
suite.solomachineMulti.PublicKey,
multiSigData,
nil,
},
{
"single signature with multisig public key",
suite.solomachineMulti.PublicKey,
singleSigData,
errors.New("invalid signature data type, expected *signing.MultiSignatureData, got *signing.MultiSignatureData: signature verification failed"),
},
{
"multi signature with regular public key",
suite.solomachine.PublicKey,
multiSigData,
errors.New("invalid signature data type, expected *signing.SingleSignatureData, got *signing.SingleSignatureData: signature verification failed"),
},
}
for _, tc := range testCases {
suite.Run(tc.name, func() {
err := solomachine.VerifySignature(tc.publicKey, signBytes, tc.sigData)
if tc.expErr == nil {
suite.Require().NoError(err)
} else {
suite.Require().Error(err)
suite.Require().ErrorContains(err, tc.expErr.Error())
}
})
}
}