Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/develop' into feat/enable-dpos
Browse files Browse the repository at this point in the history
  • Loading branch information
jonastheis committed Nov 15, 2023
2 parents 756a696 + ea175ab commit 65fce74
Show file tree
Hide file tree
Showing 5 changed files with 121 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,18 @@ services:
--indexer.db.sqlite.path=database/indexer
--restAPI.bindAddress=inx-indexer:9091

inx-mqtt:
container_name: inx-mqtt
image: iotaledger/inx-mqtt:2.0-alpha
stop_grace_period: 1m
restart: unless-stopped
depends_on:
iota-core:
condition: service_healthy
command: >
--inx.address=iota-core:9029
--mqtt.websocket.bindAddress=inx-mqtt:1888

{% if 'node-04' in inventory_hostname %}
inx-blockissuer:
container_name: inx-blockissuer
Expand Down
4 changes: 4 additions & 0 deletions pkg/protocol/engine/ledger/ledger/ledger.go
Original file line number Diff line number Diff line change
Expand Up @@ -755,6 +755,10 @@ func (l *Ledger) resolveState(stateRef mempool.StateReference) *promise.Promise[
}

func (l *Ledger) blockPreAccepted(block *blocks.Block) {
if _, isValidationBlock := block.ValidationBlock(); !isValidationBlock {
return
}

voteRank := ledger.NewBlockVoteRank(block.ID(), block.ProtocolBlock().Header.IssuingTime)

committee, exists := l.sybilProtection.SeatManager().CommitteeInSlot(block.ID().Slot())
Expand Down
91 changes: 91 additions & 0 deletions pkg/tests/booker_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,97 @@ func Test_IssuingTransactionsOutOfOrder(t *testing.T) {
}, node1)
}

func Test_WeightPropagation(t *testing.T) {
ts := testsuite.NewTestSuite(t)
defer ts.Shutdown()

node1 := ts.AddValidatorNode("node1")
node2 := ts.AddValidatorNode("node2")

wallet := ts.AddGenesisWallet("default", node1)

ts.Run(true, map[string][]options.Option[protocol.Protocol]{})

ts.AssertSybilProtectionCommittee(0, []iotago.AccountID{
node1.Validator.AccountID,
node2.Validator.AccountID,
}, ts.Nodes()...)

// Create and issue double spends
{
tx1 := wallet.CreateBasicOutputsEquallyFromInputs("tx1", 1, "Genesis:0")
tx2 := wallet.CreateBasicOutputsEquallyFromInputs("tx2", 1, "Genesis:0")

ts.IssuePayloadWithOptions("block1", wallet, tx1, mock.WithStrongParents(ts.BlockID("Genesis")))
ts.IssuePayloadWithOptions("block2", wallet, tx2, mock.WithStrongParents(ts.BlockID("Genesis")))

ts.AssertTransactionsExist(wallet.Transactions("tx1", "tx2"), true, node1, node2)
ts.AssertTransactionsInCacheBooked(wallet.Transactions("tx1", "tx2"), true, node1, node2)
ts.AssertTransactionsInCachePending(wallet.Transactions("tx1", "tx2"), true, node1, node2)
ts.AssertBlocksInCacheConflicts(map[*blocks.Block][]string{
ts.Block("block1"): {"tx1"},
ts.Block("block2"): {"tx2"},
}, node1, node2)

ts.AssertTransactionInCacheConflicts(map[*iotago.Transaction][]string{
wallet.Transaction("tx2"): {"tx2"},
wallet.Transaction("tx1"): {"tx1"},
}, node1, node2)
}

// Issue some more blocks and assert that conflicts are propagated to blocks.
{

ts.IssuePayloadWithOptions("block3-basic", ts.Wallet("node1"), &iotago.TaggedData{}, mock.WithStrongParents(ts.BlockID("block1")))
ts.IssuePayloadWithOptions("block4-basic", ts.Wallet("node2"), &iotago.TaggedData{}, mock.WithStrongParents(ts.BlockID("block2")))

ts.AssertBlocksInCacheConflicts(map[*blocks.Block][]string{
ts.Block("block3-basic"): {"tx1"},
ts.Block("block4-basic"): {"tx2"},
}, node1, node2)
ts.AssertConflictsInCacheAcceptanceState([]string{"tx1", "tx2"}, acceptance.Pending, ts.Nodes()...)
ts.AssertTransactionsInCachePending(wallet.Transactions("tx1", "tx2"), true, node1, node2)
}

// Issue valid blocks that should resolve the conflict, but basic blocks don't carry any weight..
{
ts.IssuePayloadWithOptions("block5-basic", ts.Wallet("node1"), &iotago.TaggedData{}, mock.WithStrongParents(ts.BlockIDs("block4-basic")...), mock.WithShallowLikeParents(ts.BlockID("block2")))
ts.IssuePayloadWithOptions("block6-basic", ts.Wallet("node2"), &iotago.TaggedData{}, mock.WithStrongParents(ts.BlockIDs("block5-basic")...))

ts.AssertBlocksInCacheConflicts(map[*blocks.Block][]string{
ts.Block("block6-basic"): {"tx2"},
}, ts.Nodes()...)

// Make sure that neither approval (conflict weight),
// nor witness (block weight) was not propagated using basic blocks and caused acceptance.
ts.AssertConflictsInCacheAcceptanceState([]string{"tx1", "tx2"}, acceptance.Pending, ts.Nodes()...)
ts.AssertTransactionsInCacheAccepted(wallet.Transactions("tx2"), false, node1, node2)
ts.AssertTransactionsInCacheRejected(wallet.Transactions("tx1"), false, node1, node2)
ts.AssertTransactionsInCachePending(wallet.Transactions("tx1", "tx2"), true, node1, node2)
ts.AssertBlocksInCacheAccepted(ts.Blocks("block3-basic", "block4-basic", "block5-basic", "block6-basic"), false, ts.Nodes()...)
ts.AssertBlocksInCachePreAccepted(ts.Blocks("block3-basic", "block4-basic", "block5-basic", "block6-basic"), false, ts.Nodes()...)
}

// Issue validator blocks that are subjectively invalid, but accept the basic blocks.
// Make sure that the pre-accepted basic blocks do not apply approval weight - the conflicts should remain unresolved.
// If basic blocks carry approval or witness weight, then the test will fail.
{
ts.IssueValidationBlock("block8", node1, mock.WithStrongParents(ts.BlockIDs("block3-basic", "block6-basic")...))
ts.IssueValidationBlock("block9", node2, mock.WithStrongParents(ts.BlockID("block8")))
ts.IssueValidationBlock("block10", node1, mock.WithStrongParents(ts.BlockID("block9")))

ts.AssertBlocksInCacheConflicts(map[*blocks.Block][]string{
ts.Block("block8"): {"tx1", "tx2"},
ts.Block("block9"): {"tx1", "tx2"},
ts.Block("block10"): {"tx1", "tx2"},
}, node1, node2)

ts.AssertBlocksInCachePreAccepted(ts.Blocks("block3-basic", "block4-basic", "block5-basic", "block6-basic"), true, node1, node2)
ts.AssertBlocksInCacheAccepted(ts.Blocks("block3-basic", "block4-basic", "block5-basic", "block6-basic"), true, node1, node2)
ts.AssertTransactionsInCachePending(wallet.Transactions("tx1", "tx2"), true, node1, node2)
}
}

func Test_DoubleSpend(t *testing.T) {
ts := testsuite.NewTestSuite(t)
defer ts.Shutdown()
Expand Down
13 changes: 13 additions & 0 deletions tools/docker-network/docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -194,6 +194,19 @@ services:
--inx.address=node-1-validator:9029
--restAPI.bindAddress=inx-indexer:9011
inx-mqtt:
image: iotaledger/inx-mqtt:2.0-alpha
stop_grace_period: 1m
restart: unless-stopped
depends_on:
node-1-validator:
condition: service_healthy
networks:
- iota-core
command: >
--inx.address=node-1-validator:9029
--mqtt.websocket.bindAddress=inx-mqtt:1888
inx-blockissuer:
image: iotaledger/inx-blockissuer:1.0-alpha
stop_grace_period: 1m
Expand Down
2 changes: 1 addition & 1 deletion tools/docker-network/run.sh
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ fi
echo $DOCKER_BUILD_CONTEXT $DOCKERFILE_PATH
docker compose build --build-arg WITH_GO_WORK=${WITH_GO_WORK:-0} --build-arg DOCKER_BUILD_CONTEXT=${DOCKER_BUILD_CONTEXT} --build-arg DOCKERFILE_PATH=${DOCKERFILE_PATH}

docker compose pull inx-indexer inx-blockissuer inx-faucet inx-validator-1
docker compose pull inx-indexer inx-mqtt inx-blockissuer inx-faucet inx-validator-1

# check exit code of builder
if [ $? -ne 0 ]; then
Expand Down

0 comments on commit 65fce74

Please sign in to comment.