• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

tari-project / tari / 14642108223

24 Apr 2025 12:52PM UTC coverage: 73.398% (+1.1%) from 72.346%
14642108223

push

github

web-flow
feat(grpc): return best block height from synced node (#6984)

Description
---
Adds `tip_height` and `local_height` to `get_sync_status`

Motivation and Context
---
TU checks flag `initial_sync_achieved` from `get_tip_info` and also
calls `get_sync_progress` to get `tip_height` but if
`initial_sync_achieved` is true then these 2 fields are 0 and we can't
check tip after syncing.

How Has This Been Tested?
---

What process can a PR reviewer use to test or verify this change?
---



Breaking Changes
---

- [x] None
- [ ] Requires data directory on base node to be deleted
- [ ] Requires hard fork
- [ ] Other - Please specify


<!-- This is an auto-generated comment: release notes by coderabbit.ai
-->

## Summary by CodeRabbit

- **Bug Fixes**
- Improved accuracy of sync progress reporting by displaying the actual
best block height when the node is synced, instead of showing zero
values.

<!-- end of auto-generated comment: release notes by coderabbit.ai -->

81382 of 110877 relevant lines covered (73.4%)

279101.7 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

0.0
/base_layer/core/src/base_node/comms_interface/comms_response.rs
1
// Copyright 2019. The Tari Project
2
//
3
// Redistribution and use in source and binary forms, with or without modification, are permitted provided that the
4
// following conditions are met:
5
//
6
// 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following
7
// disclaimer.
8
//
9
// 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the
10
// following disclaimer in the documentation and/or other materials provided with the distribution.
11
//
12
// 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote
13
// products derived from this software without specific prior written permission.
14
//
15
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
16
// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
17
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
18
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
19
// SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
20
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
21
// USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
22

23
use std::{
24
    fmt::{self, Display, Formatter},
25
    sync::Arc,
26
};
27

28
use tari_common_types::{
29
    chain_metadata::ChainMetadata,
30
    types::{CompressedPublicKey, HashOutput, PrivateKey},
31
};
32

33
use crate::{
34
    blocks::{Block, ChainHeader, HistoricalBlock, NewBlockTemplate},
35
    chain_storage::TemplateRegistrationEntry,
36
    proof_of_work::Difficulty,
37
    transactions::transaction_components::{Transaction, TransactionKernel, TransactionOutput},
38
};
39

40
/// API Response enum
41
#[allow(clippy::large_enum_variant)]
42
#[derive(Debug, Clone)]
43
pub enum NodeCommsResponse {
44
    ChainMetadata(ChainMetadata),
45
    TransactionKernels(Vec<TransactionKernel>),
46
    BlockHeaders(Vec<ChainHeader>),
47
    BlockHeader(Option<ChainHeader>),
48
    Block(Box<Option<Block>>),
49
    TransactionOutputs(Vec<TransactionOutput>),
50
    HistoricalBlocks(Vec<HistoricalBlock>),
51
    HistoricalBlock(Box<Option<HistoricalBlock>>),
52
    NewBlockTemplate(NewBlockTemplate),
53
    NewBlock {
54
        success: bool,
55
        error: Option<String>,
56
        block: Option<Block>,
57
    },
58
    TargetDifficulty(Difficulty),
59
    MmrNodes(Vec<HashOutput>, Vec<u8>),
60
    FetchMempoolTransactionsByExcessSigsResponse(FetchMempoolTransactionsResponse),
61
    FetchValidatorNodesKeysResponse(Vec<(CompressedPublicKey, [u8; 32])>),
62
    GetShardKeyResponse(Option<[u8; 32]>),
63
    FetchTemplateRegistrationsResponse(Vec<TemplateRegistrationEntry>),
64
}
65

66
impl Display for NodeCommsResponse {
67
    fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result {
×
68
        #[allow(clippy::enum_glob_use)]
69
        use NodeCommsResponse::*;
70
        match self {
×
71
            ChainMetadata(_) => write!(f, "ChainMetadata"),
×
72
            TransactionKernels(_) => write!(f, "TransactionKernel"),
×
73
            BlockHeaders(_) => write!(f, "BlockHeaders"),
×
74
            BlockHeader(_) => write!(f, "BlockHeader"),
×
75
            Block(_) => write!(f, "Block"),
×
76
            HistoricalBlock(_) => write!(f, "HistoricalBlock"),
×
77
            TransactionOutputs(_) => write!(f, "TransactionOutputs"),
×
78
            HistoricalBlocks(_) => write!(f, "HistoricalBlocks"),
×
79
            NewBlockTemplate(_) => write!(f, "NewBlockTemplate"),
×
80
            NewBlock {
81
                success,
×
82
                error,
×
83
                block: _,
×
84
            } => write!(
×
85
                f,
×
86
                "NewBlock({},{},...)",
×
87
                success,
×
88
                error.as_ref().unwrap_or(&"Unspecified".to_string())
×
89
            ),
×
90
            TargetDifficulty(_) => write!(f, "TargetDifficulty"),
×
91
            MmrNodes(_, _) => write!(f, "MmrNodes"),
×
92
            FetchMempoolTransactionsByExcessSigsResponse(resp) => write!(
×
93
                f,
×
94
                "FetchMempoolTransactionsByExcessSigsResponse({} transaction(s), {} not found)",
×
95
                resp.transactions.len(),
×
96
                resp.not_found.len()
×
97
            ),
×
98
            FetchValidatorNodesKeysResponse(_) => write!(f, "FetchValidatorNodesKeysResponse"),
×
99
            GetShardKeyResponse(_) => write!(f, "GetShardKeyResponse"),
×
100
            FetchTemplateRegistrationsResponse(_) => write!(f, "FetchTemplateRegistrationsResponse"),
×
101
        }
102
    }
×
103
}
104

105
/// Container struct for mempool transaction responses
106
#[derive(Debug, Clone)]
107
pub struct FetchMempoolTransactionsResponse {
108
    pub transactions: Vec<Arc<Transaction>>,
109
    pub not_found: Vec<PrivateKey>,
110
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc