Skip to content
Snippets Groups Projects
  • Jonas Theis's avatar
    ef1754f0
    Value tangle unit tests (#434) · ef1754f0
    Jonas Theis authored
    * Feat: initial commit
    
    * Feat: added setPreferred to TransactionMetadata
    
    * Feat: added a Conflicting() method to the transactionMetadata
    
    * Fix: fixed logic bug
    
    * Feat: refactored fcob
    
    * Refactor: refactored additional code
    
    * Fix: fixed a bug in ForeachConsumers
    
    * Refactor: cleaned up code
    
    * Feat: implemented FCOB consensus into the valuetransfer dapp
    
    * Refactor: refactored FCOB
    
    * Docs: added some additional comments
    
    * Docs: fixed comments
    
    * add branch manager conflict test
    
    * cleans failing test
    
    * Refactor: commit before branch change
    
    * Fix: fixed bug in AggregateBranches
    
    * assert aggr. branch IDs
    
    * expands branch conflict detection test
    
    * add visualisation of branch graph of test
    
    * Feat: added PayloadLiked Event
    
    * Refactor: fixed some missing comments + added liked to marshal
    
    * Feat: reworked the preferred and liked propagation
    
    * Refactor: cleaned up some logic
    
    * Refactor: simplified code
    
    * Refactor: cleaned up more stuff :P
    
    * Refactor: refactor
    
    * Feat: moved test + refactored fcob
    
    * adds more tests
    
    * fixes liked state not getting updated correctly of conflict members
    
    * adds additional liked/preferred propagation test
    
    * Fix: fixed missing preferred propagation to aggregated branches
    
    * Fix: fixed a few bugs in liked propagation
    
    * adapt to new hive.go version
    
    * upgrade hive.go
    
    * Feat: started implementing a wallet
    
    * Feat: extended wallet files
    
    * remove weird test
    
    * use mem db for tests
    
    * more tests
    
    * use store backed sequence
    
    * add option to use in-memory database
    
    * address review comments
    
    * First tests for individual components of AttachPayloadSync
    
    * Fix: fixed missing events in branchmanaer
    
    * Feat: propagate changes from branch to transaction
    
    * Add tests for checkTransactionOutputs
    
    * Feat: started implementing confirmed propagation
    
    * Fix: fixed unreachable code
    
    * Add more tests
    
    * Refactor: refactored some code according to wolfgangs review
    
    * Refactor: cleaned up the code according to DRY
    
    * Refactor: refactored according to wollac
    
    * Refactor: refactored according to wollac
    
    * Refactor: refactored according to wollac
    
    * Refactor: refactored the code to make it more readable
    
    * Refactor: added some doc comments + cleaned up some more code
    
    * :white_check_mark: adds orderedMap unit tests
    
    * :rotating_light: Fix linter warnings
    
    * test: Add queue unit tests
    
    * Add more tests
    
    * :lipstick: Adjust imports order
    
    * WIP more tests
    
    * :white_check_mark: Add TestBookTransaction
    
    * :white_check_mark: Update TestBookTransaction
    
    * Add more tests
    
    * :construction: WIP tests
    
    * :white_check_mark: Add TestCalculateBranchOfTransaction
    
    * :white_check_mark: Add TestMoveTransactionToBranch
    
    * :white_check_mark: Add TestFork
    
    * :white_check_mark: Add TestBookPayload
    
    * Add test for checkPayloadSolidity
    
    * :white_check_mark: Add TestSetTransactionPreferred
    
    * Add more tests
    
    * :white_check_mark: Fix Tangle test
    
    * Feat: started implementing lucas test cases
    
    * Feat: fixed some issued + further tests
    
    * Feat: started adding invalid txs check
    
    * Feat: added removal logic for invalid transactions
    
    * Refactor: removed Println
    
    * :white_check_mark: Add test for 2nd Reattachment
    
    * :white_check_mark: Add aggregated branches test cases
    
    * Feat: added a method to generate AggregatedBranchIDs
    
    * :art: Use GenerateAggregatedBranchID in test
    
    * Feat: refactored delete logic
    
    * Fix: fixed broken test
    
    * Feat: added final test cases for invalid txs / payloads
    
    * :construction:
    
     WIP
    
    * Value tangle concurrency tests (#451)
    
    * Add simple concurrency test
    
    * Add reverse and concurrent transaction and value object solidification tests and fix bug when value object was visited more than once
    
    * Add some documentation to make tests easily understandable
    
    * WIP propagation tests but fixed already couple of bugs
    
    * Fix: fixed some bugs
    
    * Feat: added propagation to inclusion states to tx and its outputs
    
    * Feat: finished the propagation down to the tx and its outputs
    
    * WIP propagation tests and fix bugs
    
    * Feat: fixed some issues and introduced a Debugger
    
    * Refactor: added a few comments
    
    * Split massive test file into slightly more digestible chunks
    
    * Clean up propagation tests
    
    * Feat: fixed bugs
    
    * Feat: enabled missing tests
    
    * Add some documentation and missing checks for aggregated branches
    
    * Clean up tangle tests
    
    * Fix: finalized wasn't propagated when a branch was rejected
    
    * WIP debugging concurrency bug of death
    
    * Feat: added more reliable fails in test case
    
    * Fix: fixes a race condition in solidification
    
    * Clean up test
    
    Co-authored-by: default avatarHans Moog <hm@mkjc.net>
    Co-authored-by: default avatarLuca Moser <moser.luca@gmail.com>
    Co-authored-by: default avatarWolfgang Welz <welzwo@gmail.com>
    Co-authored-by: default avatarcapossele <angelocapossele@gmail.com>
    Co-authored-by: default avatarjkrvivian <jkrvivian@gmail.com>
    Value tangle unit tests (#434)
    Jonas Theis authored
    * Feat: initial commit
    
    * Feat: added setPreferred to TransactionMetadata
    
    * Feat: added a Conflicting() method to the transactionMetadata
    
    * Fix: fixed logic bug
    
    * Feat: refactored fcob
    
    * Refactor: refactored additional code
    
    * Fix: fixed a bug in ForeachConsumers
    
    * Refactor: cleaned up code
    
    * Feat: implemented FCOB consensus into the valuetransfer dapp
    
    * Refactor: refactored FCOB
    
    * Docs: added some additional comments
    
    * Docs: fixed comments
    
    * add branch manager conflict test
    
    * cleans failing test
    
    * Refactor: commit before branch change
    
    * Fix: fixed bug in AggregateBranches
    
    * assert aggr. branch IDs
    
    * expands branch conflict detection test
    
    * add visualisation of branch graph of test
    
    * Feat: added PayloadLiked Event
    
    * Refactor: fixed some missing comments + added liked to marshal
    
    * Feat: reworked the preferred and liked propagation
    
    * Refactor: cleaned up some logic
    
    * Refactor: simplified code
    
    * Refactor: cleaned up more stuff :P
    
    * Refactor: refactor
    
    * Feat: moved test + refactored fcob
    
    * adds more tests
    
    * fixes liked state not getting updated correctly of conflict members
    
    * adds additional liked/preferred propagation test
    
    * Fix: fixed missing preferred propagation to aggregated branches
    
    * Fix: fixed a few bugs in liked propagation
    
    * adapt to new hive.go version
    
    * upgrade hive.go
    
    * Feat: started implementing a wallet
    
    * Feat: extended wallet files
    
    * remove weird test
    
    * use mem db for tests
    
    * more tests
    
    * use store backed sequence
    
    * add option to use in-memory database
    
    * address review comments
    
    * First tests for individual components of AttachPayloadSync
    
    * Fix: fixed missing events in branchmanaer
    
    * Feat: propagate changes from branch to transaction
    
    * Add tests for checkTransactionOutputs
    
    * Feat: started implementing confirmed propagation
    
    * Fix: fixed unreachable code
    
    * Add more tests
    
    * Refactor: refactored some code according to wolfgangs review
    
    * Refactor: cleaned up the code according to DRY
    
    * Refactor: refactored according to wollac
    
    * Refactor: refactored according to wollac
    
    * Refactor: refactored according to wollac
    
    * Refactor: refactored the code to make it more readable
    
    * Refactor: added some doc comments + cleaned up some more code
    
    * :white_check_mark: adds orderedMap unit tests
    
    * :rotating_light: Fix linter warnings
    
    * test: Add queue unit tests
    
    * Add more tests
    
    * :lipstick: Adjust imports order
    
    * WIP more tests
    
    * :white_check_mark: Add TestBookTransaction
    
    * :white_check_mark: Update TestBookTransaction
    
    * Add more tests
    
    * :construction: WIP tests
    
    * :white_check_mark: Add TestCalculateBranchOfTransaction
    
    * :white_check_mark: Add TestMoveTransactionToBranch
    
    * :white_check_mark: Add TestFork
    
    * :white_check_mark: Add TestBookPayload
    
    * Add test for checkPayloadSolidity
    
    * :white_check_mark: Add TestSetTransactionPreferred
    
    * Add more tests
    
    * :white_check_mark: Fix Tangle test
    
    * Feat: started implementing lucas test cases
    
    * Feat: fixed some issued + further tests
    
    * Feat: started adding invalid txs check
    
    * Feat: added removal logic for invalid transactions
    
    * Refactor: removed Println
    
    * :white_check_mark: Add test for 2nd Reattachment
    
    * :white_check_mark: Add aggregated branches test cases
    
    * Feat: added a method to generate AggregatedBranchIDs
    
    * :art: Use GenerateAggregatedBranchID in test
    
    * Feat: refactored delete logic
    
    * Fix: fixed broken test
    
    * Feat: added final test cases for invalid txs / payloads
    
    * :construction:
    
     WIP
    
    * Value tangle concurrency tests (#451)
    
    * Add simple concurrency test
    
    * Add reverse and concurrent transaction and value object solidification tests and fix bug when value object was visited more than once
    
    * Add some documentation to make tests easily understandable
    
    * WIP propagation tests but fixed already couple of bugs
    
    * Fix: fixed some bugs
    
    * Feat: added propagation to inclusion states to tx and its outputs
    
    * Feat: finished the propagation down to the tx and its outputs
    
    * WIP propagation tests and fix bugs
    
    * Feat: fixed some issues and introduced a Debugger
    
    * Refactor: added a few comments
    
    * Split massive test file into slightly more digestible chunks
    
    * Clean up propagation tests
    
    * Feat: fixed bugs
    
    * Feat: enabled missing tests
    
    * Add some documentation and missing checks for aggregated branches
    
    * Clean up tangle tests
    
    * Fix: finalized wasn't propagated when a branch was rejected
    
    * WIP debugging concurrency bug of death
    
    * Feat: added more reliable fails in test case
    
    * Fix: fixes a race condition in solidification
    
    * Clean up test
    
    Co-authored-by: default avatarHans Moog <hm@mkjc.net>
    Co-authored-by: default avatarLuca Moser <moser.luca@gmail.com>
    Co-authored-by: default avatarWolfgang Welz <welzwo@gmail.com>
    Co-authored-by: default avatarcapossele <angelocapossele@gmail.com>
    Co-authored-by: default avatarjkrvivian <jkrvivian@gmail.com>
debugger.go 3.42 KiB
package tangle

import (
	"fmt"
	"strings"
)

// Debugger represents a utility that allows us to print debug messages and function calls.
type Debugger struct {
	aliases map[interface{}]string
	enabled bool
	indent  int
}

// NewDebugger is the constructor of a debugger instance.
func NewDebugger() *Debugger {
	return (&Debugger{}).ResetAliases()
}

// Enable sets the debugger to print the debug information.
func (debugger *Debugger) Enable() {
	debugger.enabled = true

	fmt.Println("[DEBUGGER::ENABLED]")
}

// Disable sets the debugger to not print any debug information.
func (debugger *Debugger) Disable() {
	fmt.Println("[DEBUGGER::DISABLED]")
	debugger.enabled = false
}

// ResetAliases removes any previously registered aliases. This can be useful if the same debugger instance is for
// example used in different tests or test cases.
func (debugger *Debugger) ResetAliases() *Debugger {
	debugger.aliases = make(map[interface{}]string)

	return debugger
}

// RegisterAlias registers a string representation for the given element. This can be used to create a string
// representation for things like ids in the form of byte slices.
func (debugger *Debugger) RegisterAlias(element interface{}, alias string) {
	debugger.aliases[element] = alias
}

// FunctionCall prints debug information about a function call. It automatically indents all following debug outputs
// until Return() is called. The best way to use this is by starting a function call with a construct like:
//
// defer debugger.FunctionCall("myFunction", param1, param2).Return()
func (debugger *Debugger) FunctionCall(identifier string, params ...interface{}) *Debugger {
	if !debugger.enabled {
		return debugger
	}

	debugger.Print(identifier + "(" + debugger.paramsAsCommaSeparatedList(params...) + ") {")
	debugger.indent++

	return debugger
}

// Return prints debug information about a FunctionCall() the was finished. It reduces the indentation for consecutive
// debug outputs.
func (debugger *Debugger) Return() *Debugger {
	if !debugger.enabled {
		return debugger
	}

	debugger.indent--
	debugger.Print("}")

	return debugger
}

// Print prints an arbitrary debug message that can for example be used to print an information when a certain part of
// the code is executed.
func (debugger *Debugger) Print(identifier string, params ...interface{}) {
	if !debugger.enabled {
		return
	}

	if len(params) >= 1 {
		debugger.print(identifier + " = " + debugger.paramsAsCommaSeparatedList(params...))
	} else {
		debugger.print(identifier)
	}
}

// print is an internal utility function that actually prints the given string to stdout.
func (debugger *Debugger) print(stringToPrint string) {
	fmt.Println("[DEBUGGER] " + strings.Repeat("    ", debugger.indent) + stringToPrint)
}

// paramsAsCommaSeparatedList creates a comma separated list of the given parameters.
func (debugger *Debugger) paramsAsCommaSeparatedList(params ...interface{}) string {
	paramsAsStrings := make([]string, len(params))
	for i, param := range params {
		paramsAsStrings[i] = debugger.paramAsString(param)
	}

	return strings.Join(paramsAsStrings, ", ")
}

// paramAsString returns a string representation of an arbitrary parameter.
func (debugger *Debugger) paramAsString(param interface{}) string {
	defer func() { recover() }()
	if alias, aliasExists := debugger.aliases[param]; aliasExists {
		return alias
	}

	return fmt.Sprint(param)
}

// debugger contains the default global debugger instance.
var debugger = NewDebugger()