From 6710f5f0e7d1afd78a9da6579f1c0c203b51f18e Mon Sep 17 00:00:00 2001 From: Luis Pinto Date: Thu, 9 Jan 2025 23:30:03 +0000 Subject: [PATCH] Pass miningBeneficiary address to BlockAwareOperationTracer::traceStartBlock calls Signed-off-by: Luis Pinto --- CHANGELOG.md | 1 + .../hyperledger/besu/services/TraceServiceImpl.java | 2 +- .../besu/services/TraceServiceImplTest.java | 13 ++++++++++--- .../blockcreation/AbstractBlockCreator.java | 2 +- .../txselection/InterruptibleOperationTracer.java | 10 ++++++---- plugin-api/build.gradle | 2 +- .../services/tracer/BlockAwareOperationTracer.java | 9 +++++++-- 7 files changed, 27 insertions(+), 12 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index efaca489248..5f2bbb13f1c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,7 @@ ### Breaking Changes - `--host-whitelist` has been deprecated since 2020 and this option is removed. Use the equivalent `--host-allowlist` instead. +- Changed tracer API to include the mining beneficiary in BlockAwareOperationTracer::traceStartBlock [#8096](https://github.com/hyperledger/besu/pull/8096) ### Upcoming Breaking Changes - `MetricSystem::createLabelledGauge` is deprecated and will be removed in a future release, replace it with `MetricSystem::createLabelledSuppliedGauge` diff --git a/besu/src/main/java/org/hyperledger/besu/services/TraceServiceImpl.java b/besu/src/main/java/org/hyperledger/besu/services/TraceServiceImpl.java index 225825c72e0..28101a6034e 100644 --- a/besu/src/main/java/org/hyperledger/besu/services/TraceServiceImpl.java +++ b/besu/src/main/java/org/hyperledger/besu/services/TraceServiceImpl.java @@ -191,7 +191,7 @@ private List trace( final ProtocolSpec protocolSpec = protocolSchedule.getByBlockHeader(block.getHeader()); final MainnetTransactionProcessor transactionProcessor = protocolSpec.getTransactionProcessor(); final BlockHeader header = block.getHeader(); - tracer.traceStartBlock(block.getHeader(), block.getBody()); + tracer.traceStartBlock(block.getHeader(), block.getBody(), block.getHeader().getCoinbase()); block .getBody() diff --git a/besu/src/test/java/org/hyperledger/besu/services/TraceServiceImplTest.java b/besu/src/test/java/org/hyperledger/besu/services/TraceServiceImplTest.java index bcbf1c2fe70..21b36de45c8 100644 --- a/besu/src/test/java/org/hyperledger/besu/services/TraceServiceImplTest.java +++ b/besu/src/test/java/org/hyperledger/besu/services/TraceServiceImplTest.java @@ -114,7 +114,9 @@ void shouldRetrieveStateUpdatePostTracingForOneBlock() { final Block tracedBlock = blockchain.getBlockByNumber(blockNumber).get(); - verify(opTracer).traceStartBlock(tracedBlock.getHeader(), tracedBlock.getBody()); + verify(opTracer) + .traceStartBlock( + tracedBlock.getHeader(), tracedBlock.getBody(), tracedBlock.getHeader().getCoinbase()); tracedBlock .getBody() @@ -163,7 +165,11 @@ void shouldRetrieveStateUpdatePostTracingForAllBlocks() { .map(Optional::get) .forEach( tracedBlock -> { - verify(opTracer).traceStartBlock(tracedBlock.getHeader(), tracedBlock.getBody()); + verify(opTracer) + .traceStartBlock( + tracedBlock.getHeader(), + tracedBlock.getBody(), + tracedBlock.getHeader().getCoinbase()); tracedBlock .getBody() .getTransactions() @@ -312,7 +318,8 @@ public void traceEndTransaction( } @Override - public void traceStartBlock(final BlockHeader blockHeader, final BlockBody blockBody) { + public void traceStartBlock( + final BlockHeader blockHeader, final BlockBody blockBody, final Address miningBeneficiary) { if (!traceStartBlockCalled.add(blockHeader.getBlockHash())) { fail("traceStartBlock already called for block " + blockHeader); } diff --git a/ethereum/blockcreation/src/main/java/org/hyperledger/besu/ethereum/blockcreation/AbstractBlockCreator.java b/ethereum/blockcreation/src/main/java/org/hyperledger/besu/ethereum/blockcreation/AbstractBlockCreator.java index 2b9714384b3..e060b06954c 100644 --- a/ethereum/blockcreation/src/main/java/org/hyperledger/besu/ethereum/blockcreation/AbstractBlockCreator.java +++ b/ethereum/blockcreation/src/main/java/org/hyperledger/besu/ethereum/blockcreation/AbstractBlockCreator.java @@ -221,7 +221,7 @@ protected BlockCreationResult createBlock( final BlockAwareOperationTracer operationTracer = pluginTransactionSelector.getOperationTracer(); - operationTracer.traceStartBlock(processableBlockHeader); + operationTracer.traceStartBlock(processableBlockHeader, miningBeneficiary); timings.register("preTxsSelection"); final TransactionSelectionResults transactionResults = selectTransactions( diff --git a/ethereum/blockcreation/src/main/java/org/hyperledger/besu/ethereum/blockcreation/txselection/InterruptibleOperationTracer.java b/ethereum/blockcreation/src/main/java/org/hyperledger/besu/ethereum/blockcreation/txselection/InterruptibleOperationTracer.java index eb7f34bd9a0..eee35a4de35 100644 --- a/ethereum/blockcreation/src/main/java/org/hyperledger/besu/ethereum/blockcreation/txselection/InterruptibleOperationTracer.java +++ b/ethereum/blockcreation/src/main/java/org/hyperledger/besu/ethereum/blockcreation/txselection/InterruptibleOperationTracer.java @@ -41,8 +41,9 @@ public InterruptibleOperationTracer(final BlockAwareOperationTracer delegate) { } @Override - public void traceStartBlock(final BlockHeader blockHeader, final BlockBody blockBody) { - delegate.traceStartBlock(blockHeader, blockBody); + public void traceStartBlock( + final BlockHeader blockHeader, final BlockBody blockBody, final Address miningBeneficiary) { + delegate.traceStartBlock(blockHeader, blockBody, miningBeneficiary); } @Override @@ -51,8 +52,9 @@ public void traceEndBlock(final BlockHeader blockHeader, final BlockBody blockBo } @Override - public void traceStartBlock(final ProcessableBlockHeader processableBlockHeader) { - delegate.traceStartBlock(processableBlockHeader); + public void traceStartBlock( + final ProcessableBlockHeader processableBlockHeader, final Address miningBeneficiary) { + delegate.traceStartBlock(processableBlockHeader, miningBeneficiary); } @Override diff --git a/plugin-api/build.gradle b/plugin-api/build.gradle index 464f17e5607..7d304269ff7 100644 --- a/plugin-api/build.gradle +++ b/plugin-api/build.gradle @@ -71,7 +71,7 @@ Calculated : ${currentHash} tasks.register('checkAPIChanges', FileStateChecker) { description = "Checks that the API for the Plugin-API project does not change without deliberate thought" files = sourceSets.main.allJava.files - knownHash = 'By1EMWJvyXiRxNf52xZ0BUC2LpE6D4VlNHI0jYJryj0=' + knownHash = 'b/u9Ety5B+Ni8UwGhvU8dq4jcZtulNczsVQZgG0Q5fw=' } check.dependsOn('checkAPIChanges') diff --git a/plugin-api/src/main/java/org/hyperledger/besu/plugin/services/tracer/BlockAwareOperationTracer.java b/plugin-api/src/main/java/org/hyperledger/besu/plugin/services/tracer/BlockAwareOperationTracer.java index b84c4b69f32..9185d114370 100644 --- a/plugin-api/src/main/java/org/hyperledger/besu/plugin/services/tracer/BlockAwareOperationTracer.java +++ b/plugin-api/src/main/java/org/hyperledger/besu/plugin/services/tracer/BlockAwareOperationTracer.java @@ -14,6 +14,7 @@ */ package org.hyperledger.besu.plugin.services.tracer; +import org.hyperledger.besu.datatypes.Address; import org.hyperledger.besu.evm.tracing.OperationTracer; import org.hyperledger.besu.plugin.data.BlockBody; import org.hyperledger.besu.plugin.data.BlockHeader; @@ -37,8 +38,10 @@ public interface BlockAwareOperationTracer extends OperationTracer { * * @param blockHeader the header of the block which is traced * @param blockBody the body of the block which is traced + * @param miningBeneficiary the address of miner building the block */ - default void traceStartBlock(final BlockHeader blockHeader, final BlockBody blockBody) {} + default void traceStartBlock( + final BlockHeader blockHeader, final BlockBody blockBody, final Address miningBeneficiary) {} /** * Trace the end of a block. @@ -52,8 +55,10 @@ default void traceEndBlock(final BlockHeader blockHeader, final BlockBody blockB * When building a block this API is called at the start of the process * * @param processableBlockHeader the processable header + * @param miningBeneficiary the address of miner building the block */ - default void traceStartBlock(final ProcessableBlockHeader processableBlockHeader) {} + default void traceStartBlock( + final ProcessableBlockHeader processableBlockHeader, final Address miningBeneficiary) {} @Override default boolean isExtendedTracing() {