From bc0538c137f4973c7f2a038925cbc0a272d8441f 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 | 12 ++++++------ .../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, 32 insertions(+), 17 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index da7ad532da1..bb737e9148e 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..eaa3bad15ca 100644 --- a/besu/src/main/java/org/hyperledger/besu/services/TraceServiceImpl.java +++ b/besu/src/main/java/org/hyperledger/besu/services/TraceServiceImpl.java @@ -17,6 +17,7 @@ import static com.google.common.base.Preconditions.checkArgument; import static org.hyperledger.besu.ethereum.mainnet.feemarket.ExcessBlobGasCalculator.calculateExcessBlobGasForParent; +import org.hyperledger.besu.datatypes.Address; import org.hyperledger.besu.datatypes.BlobGas; import org.hyperledger.besu.datatypes.Hash; import org.hyperledger.besu.datatypes.Wei; @@ -152,16 +153,13 @@ public void trace( .toList(); Tracer.processTracing( blockchainQueries, - blocks.get(0).getHash(), + blocks.getFirst().getHash(), traceableState -> { final WorldUpdater worldStateUpdater = traceableState.updater(); final ChainUpdater chainUpdater = new ChainUpdater(traceableState, worldStateUpdater); beforeTracing.accept(worldStateUpdater); final List results = new ArrayList<>(); - blocks.forEach( - block -> { - results.addAll(trace(blockchain, block, chainUpdater, tracer)); - }); + blocks.forEach(block -> results.addAll(trace(blockchain, block, chainUpdater, tracer))); afterTracing.accept(chainUpdater.getNextUpdater()); return Optional.of(results); }); @@ -191,7 +189,9 @@ 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()); + final Address miningBeneficiary = + protocolSpec.getMiningBeneficiaryCalculator().calculateBeneficiary(block.getHeader()); + tracer.traceStartBlock(block.getHeader(), block.getBody(), miningBeneficiary); 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() {