mirror of
				https://github.com/kaspanet/kaspad.git
				synced 2025-10-14 00:59:33 +00:00 
			
		
		
		
	 1cd82fcd3b
			
		
	
	
		1cd82fcd3b
		
	
	
	
	
		
			
			* [DEV-91] add tests for RemoveOrphansByTag * [DEV-91] Add tests for orphan tx expiration * [DEV-91] add TestDoubleSpends * [DEV-91] add TestFetchTransaction * [DEV-91] added a test for MinHighPriority * [DEV-91] test unparsable scripts * [DEV-91] test MaxOrphanTxs=0 * [DEV-91] add TestRemoveTransaction * [DEV-105] use utxodiff in mempool instead of utxoview * [DEV-105] get rid of utxoview * [DEV-105] fix tests to use utxoset * [DEV-105] remove utxoview type * [DEV-105] move DagSetup to test_utils.go * [DEV-105] add comments and add blockdag/test_utils_test.go * [DEV-105] change checkPoolDoubleSpend to check utxodiff * [DEV-105] add restoreInputs arg to removeTransaction * [DEV-91] add restoreInputs arg to removeTransaction in unit tests * [DEV-105] add restoreInputs arg to removeTransaction * [DEV-105] give more descriptive names to vars * [DEV-115] close txChan outside of HandleNewBlock * [DEV-105] rename DagSetup -> DAGSetup * [DEV-91] remove IsSpentInDiff * [DEV-91] fix comment * [DEV-91] Make IsPushOnlyScript return an error if the script cannot be parsed * [DEV-91] add more tests for IsPushOnlyScript * [DEV-91] fix comments
		
			
				
	
	
		
			134 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright (c) 2014-2016 The btcsuite developers
 | |
| // Use of this source code is governed by an ISC
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package mempool
 | |
| 
 | |
| import (
 | |
| 	"github.com/daglabs/btcd/blockdag"
 | |
| 	"github.com/daglabs/btcd/wire"
 | |
| )
 | |
| 
 | |
| // RuleError identifies a rule violation.  It is used to indicate that
 | |
| // processing of a transaction failed due to one of the many validation
 | |
| // rules.  The caller can use type assertions to determine if a failure was
 | |
| // specifically due to a rule violation and use the Err field to access the
 | |
| // underlying error, which will be either a TxRuleError or a
 | |
| // blockchain.RuleError.
 | |
| type RuleError struct {
 | |
| 	Err error
 | |
| }
 | |
| 
 | |
| // Error satisfies the error interface and prints human-readable errors.
 | |
| func (e RuleError) Error() string {
 | |
| 	if e.Err == nil {
 | |
| 		return "<nil>"
 | |
| 	}
 | |
| 	return e.Err.Error()
 | |
| }
 | |
| 
 | |
| // TxRuleError identifies a rule violation.  It is used to indicate that
 | |
| // processing of a transaction failed due to one of the many validation
 | |
| // rules.  The caller can use type assertions to determine if a failure was
 | |
| // specifically due to a rule violation and access the ErrorCode field to
 | |
| // ascertain the specific reason for the rule violation.
 | |
| type TxRuleError struct {
 | |
| 	RejectCode  wire.RejectCode // The code to send with reject messages
 | |
| 	Description string          // Human readable description of the issue
 | |
| }
 | |
| 
 | |
| // Error satisfies the error interface and prints human-readable errors.
 | |
| func (e TxRuleError) Error() string {
 | |
| 	return e.Description
 | |
| }
 | |
| 
 | |
| // txRuleError creates an underlying TxRuleError with the given a set of
 | |
| // arguments and returns a RuleError that encapsulates it.
 | |
| func txRuleError(c wire.RejectCode, desc string) RuleError {
 | |
| 	return RuleError{
 | |
| 		Err: TxRuleError{RejectCode: c, Description: desc},
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // dagRuleError returns a RuleError that encapsulates the given
 | |
| // blockdag.RuleError.
 | |
| func dagRuleError(dagErr blockdag.RuleError) RuleError {
 | |
| 	return RuleError{
 | |
| 		Err: dagErr,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // extractRejectCode attempts to return a relevant reject code for a given error
 | |
| // by examining the error for known types.  It will return true if a code
 | |
| // was successfully extracted.
 | |
| func extractRejectCode(err error) (wire.RejectCode, bool) {
 | |
| 	// Pull the underlying error out of a RuleError.
 | |
| 	if rerr, ok := err.(RuleError); ok {
 | |
| 		err = rerr.Err
 | |
| 	}
 | |
| 
 | |
| 	switch err := err.(type) {
 | |
| 	case blockdag.RuleError:
 | |
| 		// Convert the chain error to a reject code.
 | |
| 		var code wire.RejectCode
 | |
| 		switch err.ErrorCode {
 | |
| 		// Rejected due to duplicate.
 | |
| 		case blockdag.ErrDuplicateBlock:
 | |
| 			code = wire.RejectDuplicate
 | |
| 
 | |
| 		// Rejected due to obsolete version.
 | |
| 		case blockdag.ErrBlockVersionTooOld:
 | |
| 			code = wire.RejectObsolete
 | |
| 
 | |
| 		// Rejected due to checkpoint.
 | |
| 		case blockdag.ErrCheckpointTimeTooOld:
 | |
| 			fallthrough
 | |
| 		case blockdag.ErrDifficultyTooLow:
 | |
| 			fallthrough
 | |
| 		case blockdag.ErrBadCheckpoint:
 | |
| 			fallthrough
 | |
| 		case blockdag.ErrForkTooOld:
 | |
| 			code = wire.RejectCheckpoint
 | |
| 
 | |
| 		// Everything else is due to the block or transaction being invalid.
 | |
| 		default:
 | |
| 			code = wire.RejectInvalid
 | |
| 		}
 | |
| 
 | |
| 		return code, true
 | |
| 
 | |
| 	case TxRuleError:
 | |
| 		return err.RejectCode, true
 | |
| 
 | |
| 	case nil:
 | |
| 		return wire.RejectInvalid, false
 | |
| 	}
 | |
| 
 | |
| 	return wire.RejectInvalid, false
 | |
| }
 | |
| 
 | |
| // ErrToRejectErr examines the underlying type of the error and returns a reject
 | |
| // code and string appropriate to be sent in a wire.MsgReject message.
 | |
| func ErrToRejectErr(err error) (wire.RejectCode, string) {
 | |
| 	// Return the reject code along with the error text if it can be
 | |
| 	// extracted from the error.
 | |
| 	rejectCode, found := extractRejectCode(err)
 | |
| 	if found {
 | |
| 		return rejectCode, err.Error()
 | |
| 	}
 | |
| 
 | |
| 	// Return a generic rejected string if there is no error.  This really
 | |
| 	// should not happen unless the code elsewhere is not setting an error
 | |
| 	// as it should be, but it's best to be safe and simply return a generic
 | |
| 	// string rather than allowing the following code that dereferences the
 | |
| 	// err to panic.
 | |
| 	if err == nil {
 | |
| 		return wire.RejectInvalid, "rejected"
 | |
| 	}
 | |
| 
 | |
| 	// When the underlying error is not one of the above cases, just return
 | |
| 	// wire.RejectInvalid with a generic rejected string plus the error
 | |
| 	// text.
 | |
| 	return wire.RejectInvalid, "rejected: " + err.Error()
 | |
| }
 |