From 00c1a371d2860409b111a9ecfde163101cb304f8 Mon Sep 17 00:00:00 2001 From: rhuairahrighairigh Date: Fri, 10 Jan 2020 13:13:04 +0000 Subject: [PATCH] add params validation --- x/auction/types/params.go | 35 +++++++++++++++++++------------ x/auction/types/params_test.go | 38 ++++++++++++++++++++++++++++++++++ 2 files changed, 60 insertions(+), 13 deletions(-) create mode 100644 x/auction/types/params_test.go diff --git a/x/auction/types/params.go b/x/auction/types/params.go index 22d01736..5f52f258 100644 --- a/x/auction/types/params.go +++ b/x/auction/types/params.go @@ -5,6 +5,7 @@ import ( "fmt" "time" + sdk "github.com/cosmos/cosmos-sdk/types" "github.com/cosmos/cosmos-sdk/x/params/subspace" ) @@ -19,7 +20,7 @@ const ( // Parameter keys var ( // ParamStoreKeyParams Param store key for auction params - KeyAuctionBidDuration = []byte("MaxBidDuration") + KeyAuctionBidDuration = []byte("BidDuration") KeyAuctionDuration = []byte("MaxAuctionDuration") ) @@ -28,14 +29,14 @@ var _ subspace.ParamSet = &Params{} // Params is the governance parameters for the auction module. type Params struct { MaxAuctionDuration time.Duration `json:"max_auction_duration" yaml:"max_auction_duration"` // max length of auction - MaxBidDuration time.Duration `json:"max_bid_duration" yaml:"max_bid_duration"` // additional time added to the auction end time after each bid, capped by the expiry. + BidDuration time.Duration `json:"bid_duration" yaml:"bid_duration"` // additional time added to the auction end time after each bid, capped by the expiry. } // NewParams returns a new Params object. func NewParams(maxAuctionDuration time.Duration, bidDuration time.Duration) Params { return Params{ MaxAuctionDuration: maxAuctionDuration, - MaxBidDuration: bidDuration, + BidDuration: bidDuration, } } @@ -54,29 +55,37 @@ func ParamKeyTable() subspace.KeyTable { // ParamSetPairs implements the ParamSet interface and returns all the key/value pairs. // nolint -func (ap *Params) ParamSetPairs() subspace.ParamSetPairs { +func (p *Params) ParamSetPairs() subspace.ParamSetPairs { return subspace.ParamSetPairs{ - {KeyAuctionBidDuration, &ap.MaxBidDuration}, - {KeyAuctionDuration, &ap.MaxAuctionDuration}, + {KeyAuctionBidDuration, &p.BidDuration}, + {KeyAuctionDuration, &p.MaxAuctionDuration}, } } // Equal returns a boolean determining if two Params types are identical. -func (ap Params) Equal(ap2 Params) bool { - bz1 := ModuleCdc.MustMarshalBinaryLengthPrefixed(&ap) - bz2 := ModuleCdc.MustMarshalBinaryLengthPrefixed(&ap2) +func (p Params) Equal(p2 Params) bool { + bz1 := ModuleCdc.MustMarshalBinaryLengthPrefixed(&p) + bz2 := ModuleCdc.MustMarshalBinaryLengthPrefixed(&p2) return bytes.Equal(bz1, bz2) } // String implements stringer interface -func (ap Params) String() string { +func (p Params) String() string { return fmt.Sprintf(`Auction Params: Max Auction Duration: %s - Max Bid Duration: %s`, ap.MaxAuctionDuration, ap.MaxBidDuration) + Bid Duration: %s`, p.MaxAuctionDuration, p.BidDuration) } // Validate checks that the parameters have valid values. -func (ap Params) Validate() error { - // TODO check durations are within acceptable limits, if needed +func (p Params) Validate() error { + if p.BidDuration < 0 { + return sdk.ErrInternal("bid duration cannot be negative") + } + if p.MaxAuctionDuration < 0 { + return sdk.ErrInternal("max auction duration cannot be negative") + } + if p.BidDuration > p.MaxAuctionDuration { + return sdk.ErrInternal("bid duration param cannot be larger than max auction duration") + } return nil } diff --git a/x/auction/types/params_test.go b/x/auction/types/params_test.go new file mode 100644 index 00000000..0f642875 --- /dev/null +++ b/x/auction/types/params_test.go @@ -0,0 +1,38 @@ +package types + +import ( + "github.com/stretchr/testify/require" + "testing" + "time" +) + +func TestParams_Validate(t *testing.T) { + type fields struct { + } + testCases := []struct { + name string + MaxAuctionDuration time.Duration + BidDuration time.Duration + expectErr bool + }{ + {"normal", 24 * time.Hour, 1 * time.Hour, false}, + {"negativeBid", 24 * time.Hour, -1 * time.Hour, true}, + {"negativeAuction", -24 * time.Hour, 1 * time.Hour, true}, + {"bid>auction", 1 * time.Hour, 24 * time.Hour, true}, + {"zeros", 0, 0, false}, + } + for _, tc := range testCases { + t.Run(tc.name, func(t *testing.T) { + p := Params{ + MaxAuctionDuration: tc.MaxAuctionDuration, + BidDuration: tc.BidDuration, + } + err := p.Validate() + if tc.expectErr { + require.Error(t, err) + } else { + require.NoError(t, err) + } + }) + } +}