mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-05-23 15:26:42 +00:00

* [NOD-1575] Implement Clone and Equal for all model types * [NOD-1575] Add assertion for transaction ID equality * [NOD-1575] Use DomainTransaction.Equal to compare to expected coinbase transaction * [NOD-1575] Add TestDomainBlockHeader_Clone * [NOD-1575] Don't clone nil values * [NOD-1575] Add type assertions * [NOD-1575] Don't clone nil values * [NOD-1575] Add missing Equals * [NOD-1575] Add length checks * [NOD-1575] Update comment * [NOD-1575] Check length for TransactionAcceptanceData * [NOD-1575] Explicitly clone nils where needed * [NOD-1575] Clone tx id * [NOD-1575] Flip condition * Nod 1576 make coverage tests for equal clone inside model externalapi (#1177) * [NOD-1576] Make coverage tests for equal and clone inside model and externalapi * Some formatting and naming fixes * Made transactionToCompare type exported * Added some tests and made some changes to the tests code * No changes made * Some formatting and naming changes made * Made better test coverage for externalapi clone and equal functions * Changed expected result for two cases * Added equal and clone functions tests for ghostdag and utxodiff * Added tests * [NOD-1576] Implement reachabilitydata equal/clone unit tests * [NOD-1576] Full coverage of reachabilitydata equal/clone unit tests * Made changes and handling panic to transaction_equal_clone_test.go and formating of utxodiff_equal_clone_test.go * Added recoverForEqual2 for handling panic to transaction_equal_clone_test.go * [NOD-1576] Full coverage of transaction equal unit test * [NOD-1576] Add expects panic * [NOD-1576] Allow composites in go vet * [NOD-1576] Code review fixes (#1223) * [NOD-1576] Code review fixes * [NOD-1576] Code review fixes part 2 * [NOD-1576] Fix wrong name Co-authored-by: karim1king <karimkaspersky@yahoo.com> Co-authored-by: Ori Newman <orinewman1@gmail.com> Co-authored-by: Karim <karim1king@users.noreply.github.com> * Fix merge errors * Use Equal where possible * Use Equal where possible * Use Equal where possible Co-authored-by: andrey-hash <74914043+andrey-hash@users.noreply.github.com> Co-authored-by: karim1king <karimkaspersky@yahoo.com> Co-authored-by: Karim <karim1king@users.noreply.github.com>
128 lines
3.4 KiB
Go
128 lines
3.4 KiB
Go
package externalapi
|
|
|
|
// AcceptanceData stores data about which transactions were accepted by a block.
|
|
// It's ordered in the same way as the block merge set blues.
|
|
type AcceptanceData []*BlockAcceptanceData
|
|
|
|
// If this doesn't compile, it means the type definition has been changed, so it's
|
|
// an indication to update Equal and Clone accordingly.
|
|
var _ AcceptanceData = []*BlockAcceptanceData{}
|
|
|
|
// Equal returns whether ad equals to other
|
|
func (ad AcceptanceData) Equal(other AcceptanceData) bool {
|
|
if len(ad) != len(other) {
|
|
return false
|
|
}
|
|
|
|
for i, blockAcceptanceData := range ad {
|
|
if !blockAcceptanceData.Equal(other[i]) {
|
|
return false
|
|
}
|
|
}
|
|
|
|
return true
|
|
}
|
|
|
|
// Clone clones the AcceptanceData
|
|
func (ad AcceptanceData) Clone() AcceptanceData {
|
|
clone := make(AcceptanceData, len(ad))
|
|
for i, blockAcceptanceData := range ad {
|
|
clone[i] = blockAcceptanceData.Clone()
|
|
}
|
|
|
|
return clone
|
|
}
|
|
|
|
// BlockAcceptanceData stores all transactions in a block with an indication
|
|
// if they were accepted or not by some other block
|
|
type BlockAcceptanceData struct {
|
|
BlockHash *DomainHash
|
|
TransactionAcceptanceData []*TransactionAcceptanceData
|
|
}
|
|
|
|
// If this doesn't compile, it means the type definition has been changed, so it's
|
|
// an indication to update Equal and Clone accordingly.
|
|
var _ = &BlockAcceptanceData{&DomainHash{}, []*TransactionAcceptanceData{}}
|
|
|
|
// Equal returns whether bad equals to other
|
|
func (bad *BlockAcceptanceData) Equal(other *BlockAcceptanceData) bool {
|
|
if bad == nil || other == nil {
|
|
return bad == other
|
|
}
|
|
|
|
if !bad.BlockHash.Equal(other.BlockHash) {
|
|
return false
|
|
}
|
|
|
|
if len(bad.TransactionAcceptanceData) != len(other.TransactionAcceptanceData) {
|
|
return false
|
|
}
|
|
|
|
for i, acceptanceData := range bad.TransactionAcceptanceData {
|
|
if !acceptanceData.Equal(other.TransactionAcceptanceData[i]) {
|
|
return false
|
|
}
|
|
}
|
|
|
|
return true
|
|
}
|
|
|
|
// Clone returns a clone of BlockAcceptanceData
|
|
func (bad *BlockAcceptanceData) Clone() *BlockAcceptanceData {
|
|
if bad == nil {
|
|
return nil
|
|
}
|
|
|
|
clone := &BlockAcceptanceData{
|
|
BlockHash: bad.BlockHash,
|
|
TransactionAcceptanceData: make([]*TransactionAcceptanceData, len(bad.TransactionAcceptanceData)),
|
|
}
|
|
for i, acceptanceData := range bad.TransactionAcceptanceData {
|
|
clone.TransactionAcceptanceData[i] = acceptanceData.Clone()
|
|
}
|
|
|
|
return clone
|
|
}
|
|
|
|
// TransactionAcceptanceData stores a transaction together with an indication
|
|
// if it was accepted or not by some block
|
|
type TransactionAcceptanceData struct {
|
|
Transaction *DomainTransaction
|
|
Fee uint64
|
|
IsAccepted bool
|
|
}
|
|
|
|
// If this doesn't compile, it means the type definition has been changed, so it's
|
|
// an indication to update Equal and Clone accordingly.
|
|
var _ = &TransactionAcceptanceData{&DomainTransaction{}, 0, false}
|
|
|
|
// Equal returns whether tad equals to other
|
|
func (tad *TransactionAcceptanceData) Equal(other *TransactionAcceptanceData) bool {
|
|
if tad == nil || other == nil {
|
|
return tad == other
|
|
}
|
|
|
|
if !tad.Transaction.Equal(other.Transaction) {
|
|
return false
|
|
}
|
|
|
|
if tad.Fee != other.Fee {
|
|
return false
|
|
}
|
|
|
|
if tad.IsAccepted != other.IsAccepted {
|
|
return false
|
|
}
|
|
|
|
return true
|
|
}
|
|
|
|
// Clone returns a clone of TransactionAcceptanceData
|
|
func (tad *TransactionAcceptanceData) Clone() *TransactionAcceptanceData {
|
|
return &TransactionAcceptanceData{
|
|
Transaction: tad.Transaction.Clone(),
|
|
Fee: tad.Fee,
|
|
IsAccepted: tad.IsAccepted,
|
|
}
|
|
}
|