aboutsummaryrefslogtreecommitdiffstats
path: root/integration_test/node.go
Commit message (Collapse)AuthorAgeFilesLines
* big-bang: single chain (#446)Mission Liao2019-02-191-355/+0
|
* core: remove Governance.NotifyRoundHeight (#431)Mission Liao2019-01-241-2/+2
|
* core: fix issue (#427)Mission Liao2019-01-211-3/+0
| | | | | | | | * Dropped block should not be added to db - Here "dropped" means a block is older than current tip of that chain. * "Acking blocks doesn't exist" should be treated as an error when adding a block
* core: Fix BA3.0 (#420)Jimmy Hu2019-01-151-1/+1
| | | | | | | | | | | | | | | | | | * Add Restart to Ticker * Change pre allocated size * Return NextTime from lattice * Few hacky fixes for BA * PullVote in FastRollback state * Add shallowBlock for agreementResult * Extend period * Fixup
* utils: move authenticator to utils package (#378)Mission Liao2018-12-221-1/+1
|
* db: rename blockdb to db (#367)Mission Liao2018-12-131-8/+8
| | | | | | | | | | * Rename blockdb package to db * Rename 'BlockDB' to 'DB' * Make all methods in db specific for ''block'. * Rename db.BlockDatabase to db.Database * Rename revealer to block-revealer * Rename test.Revealer to test.BlockRevealer
* utils: add utils package (#327)Mission Liao2018-11-141-1/+2
|
* core: lattice-data: fix details and add test (#299)haoping-ku2018-11-061-0/+1
|
* core: block deliver with position (#289)Mission Liao2018-11-021-1/+1
| | | | | This info is required when application layer needs to do something related to the underlying DAG, not just compaction chain.
* Rename repo to dexon-consensusWei-Ning Huang2018-11-021-11/+11
|
* core: core.Lattice supports config change (#276)Mission Liao2018-11-011-70/+189
| | | | | | | | | | | Besides making core.Lattice supports config change, This PR also include the first test for below scenario: - Configuration changes are registered before test running - Those changes are carried/broadcasted as payload of blocks - Only one node would initiate these changes, however, all nodes would finally receive/apply those changes to their own test.Governance instance.
* test: Handle blocks that should retry sanity check later. (#267)Mission Liao2018-10-271-10/+34
|
* core: Leader selector will retry sanityCheck (#261)Jimmy Hu2018-10-261-1/+1
|
* core: lattice sync (#257)Jimmy Hu2018-10-251-21/+15
|
* core: reduce calls to Application.VerifyBlock (#247)Mission Liao2018-10-241-1/+1
| | | | | | * remove sanity check when adding blocks. * call VerifyBlock after lattice's sanity check. * remove checkRelation flag.
* core: initial commit for logger (#228)Mission Liao2018-10-191-1/+2
| | | | | | | | | | | | | * Replace "log.*" with logger. * Add simple logger to log with log package. * Add debug logs to all calls to these interfaces: - core.Application - core.Governance - core.Network * Add Stringer to these types: - types.DKGComplaint - types.AgreementResult - types.DKGMasterPublicKey - types.DKGFinalize
* core: Some sync functions (#220)Jimmy Hu2018-10-171-1/+1
|
* core: genesis consensus timestamp (#217)Mission Liao2018-10-171-1/+1
| | | | | | | | | | * Refine the initial value for empty time slot. * Fix DATA RACE netowrkConnection is reset for each test, however, our Consensus instance is not stopped after one test is finished, they might continue use network interface for a while.
* core: latticeData supports config change (#190)Mission Liao2018-10-121-2/+2
| | | | | | | | | | | | | | | * Add test for num of chains changes. * Return error in latticeData.prepareBlock * Compare two positions * Modify chainStatus from height-based to index-based. * Fix consensus to use round variable * Remove sanity check in chainStatus * Fixup: refine sanity check - verify if round switching is required or not by chainTip's config. - make the logic in sanity check more clear - pospone acking relationship checking, they are more expensive to check.
* core: change interface (#193)Mission Liao2018-10-111-1/+1
| | | | | | | * Extract types.FinalizationResult * Change interface: - Application.BlockConfirmed returns whole block. - Application.BlockDelivered returns partial result.
* core: find block in db (#174)Mission Liao2018-10-051-1/+4
| | | | | | | | | | | | | | | | | | | | * Make sure block pool is large enough It's safe to use a larger blockPool when the number of chains is smaller. * Construct latticeData via config. * Seek acked blocks in blockdb when unable to find them in memory cache. In previous implementation, we assume our cache in memory is enough to perform DAG's sanity check. However, it's no longer true when the number of chains might be changed between rounds. * Simplify purge. Remove the relation to purge block by chainStatus.
* core: publish round based config (#165)Mission Liao2018-10-031-0/+2
|
* core: remove shard (#161)Mission Liao2018-10-021-7/+7
|
* core: replace reliable-broadcast with shard (#159)Mission Liao2018-10-021-4/+2
|
* core: integrate authenticator (#150)Mission Liao2018-09-301-1/+1
|
* core: hide types.NodeID from full node. (#147)Mission Liao2018-09-281-1/+5
| | | | | | | | | * Refine core.Governance interface - Remove types.NodeID from interface declaration. - All parameter should be round based. * Add core.NodeSetCache * Agreement accepts map of nodeID directly. * test.Transport.Peers method return public keys.
* core: update governance interface and config (#145)Wei-Ning Huang2018-09-271-1/+1
| | | | | | 1) Remove RoundHeight from config. 2) NotarySet is not from governance contract, we get Node set intead. Notary set is caculated from the NodeSet using CRS. 3) CRS is not in the governance interface.
* crypto: sigtopub to crypto package. remove SigToPubFn (#141)Jimmy Hu2018-09-261-2/+0
|
* core: move crypto to core/crypto (#140)Mission Liao2018-09-261-2/+2
| | | | | | | | | - Move key-holder to authenticator Make core.keyHolder public as core.Authenticator, it is not required to make this part an interface. - Make private when there is no need to go public. - Fix data race
* core: update governance interface to consider genesis state (#136)Wei-Ning Huang2018-09-251-1/+1
|
* Fix naming of methods (#134)Mission Liao2018-09-251-1/+1
| | | | | | - BlockDeliver -> BlockDelivered - TotalOrderingDeliver -> TotalOrderingDelivered - WitnessAckDeliver -> WitnessAckDelivered - VerifyPayload -> VerifyPayloads
* core: add debug (#133)Mission Liao2018-09-251-1/+2
| | | | | | | | | | | | | | | | | | | | | * Split interface * Rename nonblocking-application to nonblocking Parts needs nonblocking gets more. * Implement core.nonBlocking based on interface split * Fix: the witness parent hash could be parent on compaction chain. * Rename Application.DeliverBlock to BlockDeliver To sync with naming of other methods. * Change methods' fingerprint - BlockConfirmed provides block hash only. - BlockDeliver provde a whole block.
* core: add shard (#127)Mission Liao2018-09-211-30/+81
| | | | | | | A shard is basically DEXON v1 components, except the strongly acked part, including: - maintaining lattice structure - total ordering - generate consensus timestamp
* Rename validator* to node* (#120)Mission Liao2018-09-201-0/+161