Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(prover_cli): Stuck status #2441

Merged
merged 165 commits into from
Aug 19, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
165 commits
Select commit Hold shift + click to select a range
17e564c
fmt
ColoCarletti Apr 8, 2024
245b0a4
wip
ColoCarletti Apr 8, 2024
8e84243
add cargo.toml cargo.lock
ColoCarletti Apr 8, 2024
17517b1
go back to anihow
ColoCarletti Apr 8, 2024
4ab7ce8
fmt
ColoCarletti Apr 8, 2024
4655201
rm tool workspace
ColoCarletti Apr 9, 2024
c32d1aa
fmt
ColoCarletti Apr 10, 2024
8e49e04
zk fmt
ColoCarletti Apr 10, 2024
80e13da
fix typo
ColoCarletti Apr 10, 2024
0f2ebd8
move query to prover_dal
ColoCarletti Apr 12, 2024
69d2104
remove --all flag
Apr 15, 2024
c9e6e5e
change command name
ColoCarletti Apr 16, 2024
83fab40
merge main
ColoCarletti Apr 16, 2024
cdbb467
fmt
ColoCarletti Apr 16, 2024
d1f3994
add sqlx query json
ColoCarletti Apr 16, 2024
4ee3ff2
Merge branch 'main' into prover_cli_status_command
ilitteri Apr 16, 2024
fff3910
update README
ColoCarletti Apr 16, 2024
ef906b9
zk fmt
ColoCarletti Apr 16, 2024
3758547
Merge branch 'prover_cli_status_command' of github.com:matter-labs/zk…
ColoCarletti Apr 16, 2024
b3051b2
remove eol
ColoCarletti Apr 16, 2024
ee9d35b
Move jobs cmd to status cmd module
Apr 16, 2024
82faf32
Refactor status cmd
Apr 16, 2024
aa44864
Update Cargo.lock
Apr 16, 2024
3fe32b6
zk fmt
Apr 16, 2024
d43dd15
Merge pull request #1705 from matter-labs/il-refactor-prover-cli-stat…
ilitteri Apr 17, 2024
70b0348
Merge branch 'main' into prover_cli_status_command
ilitteri Apr 17, 2024
585059b
Merge branch 'main' into prover_cli_status_command
ilitteri Apr 17, 2024
9977e95
Refactor
Apr 18, 2024
ee88cfe
Merge branch 'main' into prover_cli_status_command
ilitteri Apr 18, 2024
075e6dc
Merge branch 'main' into prover_cli_status_command
ColoCarletti Apr 19, 2024
0120a09
fix typo
ColoCarletti Apr 19, 2024
9a11a94
modify query to include aggregation_round
ColoCarletti Apr 19, 2024
1c92e95
change query return type
ColoCarletti Apr 24, 2024
05e1636
Update Cargo files
Apr 24, 2024
58d47ad
Setle status cmd baseline
Apr 24, 2024
f778759
Add status cmd utils
Apr 24, 2024
e945df2
Add status utils
Apr 24, 2024
6585378
zk fmt
Apr 24, 2024
47df898
Document enums
Apr 24, 2024
ceae289
Add BatchDataBuilder struct
Apr 24, 2024
f6d7b9a
Add TaskStatus::Custom enum variant
Apr 24, 2024
8e16d35
Fix BatchDataBuilder
Apr 24, 2024
a76cb32
Rollback
Apr 24, 2024
c460029
impl From<ProofCompressionJobStatus> for TaskStatus
Apr 24, 2024
e76da1f
Fix TaskStatus::Custom fmt
Apr 24, 2024
4be214e
Add query for getting proof compression job info for a batch
Apr 25, 2024
e9e197f
Add query for getting proof compression job info for a batch
Apr 25, 2024
7c9a499
Handle proof compression job status for batches
Apr 25, 2024
17b5875
Fix get_proof_compression_job_status_for_batch
Apr 25, 2024
3fdc055
Remove BatchDataBuilder struct
Apr 25, 2024
a2ad3f9
Merge branch 'prover_cli_status_command' of github.com:matter-labs/zk…
Apr 25, 2024
3093cde
Fix
Apr 25, 2024
fde3be1
Move prover_dal types to basic_types::prover_dal module
ilitteri Apr 25, 2024
efd70ac
Refactor query
ilitteri Apr 25, 2024
6ec0ac3
Merge pull request #1789 from matter-labs/prover_cli_compressor_status
ilitteri Apr 25, 2024
1830ced
add bwg query
ColoCarletti Apr 25, 2024
a6105b8
merge compresor job
ColoCarletti Apr 25, 2024
bbe5dc3
add status for prover jobs
ColoCarletti Apr 26, 2024
111884b
add title for prover jobs
ColoCarletti Apr 26, 2024
9fef23d
Refactor
ilitteri Apr 26, 2024
01ecd2f
add leaf query
ColoCarletti Apr 29, 2024
25e089b
Merge branch 'prover_cli_status_command' into prover_cli_status_comma…
ColoCarletti Apr 29, 2024
590c58b
fix merge
ColoCarletti Apr 29, 2024
e08b05e
add querys
ColoCarletti Apr 29, 2024
cf069b9
fix witnes jobs status
ColoCarletti Apr 30, 2024
6ad5566
rm comments
ColoCarletti Apr 30, 2024
a3f1938
Fix & refactors
ilitteri Apr 30, 2024
78c7cd8
zk lint rust
ilitteri Apr 30, 2024
33729b8
Fix import
ilitteri Apr 30, 2024
1efde33
Merge branch 'prover_cli_status_command' of github.com:matter-labs/zk…
ilitteri Apr 30, 2024
112ae93
fix import
ColoCarletti Apr 30, 2024
e1854fa
zk lint rust
ilitteri Apr 30, 2024
ccab3d3
Merge branch 'prover_cli_status_command_lwg' of github.com:matter-lab…
ColoCarletti Apr 30, 2024
fa26c26
fix wg task types
ColoCarletti Apr 30, 2024
dbaf3b4
Merge pull request #1830 from matter-labs/prover_cli_status_command_lwg
ColoCarletti Apr 30, 2024
4124f63
Merge main
ColoCarletti Apr 30, 2024
a4fde1f
update README
ColoCarletti Apr 30, 2024
10fdcb9
fix EIP Blob use
ColoCarletti Apr 30, 2024
8a1101f
fix typos
ColoCarletti Apr 30, 2024
c1282a5
Merge branch 'main' into prover_cli_status_command
ilitteri May 2, 2024
1bbde93
Fix typo
ilitteri May 2, 2024
16be778
Merge branch 'main' into prover_cli_status_command
ilitteri May 2, 2024
1fc445c
Initial test code
ilitteri May 2, 2024
4a7e58a
Basic status tests
ilitteri May 2, 2024
43565ec
Stop reseting the prover db when running zk test prover
ilitteri May 3, 2024
c1ea0b9
Add dev dependency
ilitteri May 3, 2024
a3808eb
Merge branch 'main' of github.com:matter-labs/zksync-era into prover_…
ilitteri May 3, 2024
7f6a53d
Update tests
ilitteri May 3, 2024
5dee362
Fix
ilitteri May 3, 2024
dee2192
Merge branch 'main' of github.com:matter-labs/zksync-era into prover_…
ilitteri May 6, 2024
00269ff
Remove old constants
ilitteri May 6, 2024
488f6e5
zk fmt
ColoCarletti May 24, 2024
c601ca9
Merge branch 'main' into prover_cli_tests
ColoCarletti May 28, 2024
4bc1c65
Merge branch 'main' into prover_cli_tests
ColoCarletti May 31, 2024
0c323fa
Merge branch 'main' into prover_cli_tests
ColoCarletti Jun 4, 2024
26987be
merge main
ColoCarletti Jun 6, 2024
b9d4d3d
Merge branch 'main' into prover_cli_tests
ColoCarletti Jun 6, 2024
c568f61
add db to prover tests
ColoCarletti Jun 6, 2024
0d6fe06
fix dependencies after merge
ColoCarletti Jun 6, 2024
6639833
fix l1 import
ColoCarletti Jun 6, 2024
4ed261d
update batch tests
ColoCarletti Jun 6, 2024
62b46e7
add --test-threads=1 flag
ColoCarletti Jun 6, 2024
92a5c73
fix batch command
ColoCarletti Jun 6, 2024
3038d1b
add test db connection
ColoCarletti Jun 6, 2024
b49820f
fix queued status
ColoCarletti Jun 13, 2024
f149dd2
fmt
ColoCarletti Jun 13, 2024
0125dd2
fix imports
ColoCarletti Jun 13, 2024
0532ec9
add status tests
ColoCarletti Jun 13, 2024
87aa6dd
rm env set
ColoCarletti Jun 13, 2024
9a77683
fix config command
ColoCarletti Jun 13, 2024
291d89b
remove unused fn
ColoCarletti Jun 13, 2024
d05ca3c
add verbose tests
ColoCarletti Jun 14, 2024
4000fda
Merge branch 'main' into prover_cli_tests
ColoCarletti Jun 14, 2024
aee6fe3
finish verbose tests
ColoCarletti Jun 18, 2024
d993ce1
Merge branch 'main' into prover_cli_tests
ColoCarletti Jun 18, 2024
9fb189b
Merge branch 'main' into prover_cli_tests
ColoCarletti Jun 19, 2024
77e9e53
merge main
ColoCarletti Jun 24, 2024
a053b9c
Merge branch 'main' into prover_cli_tests
ColoCarletti Jun 25, 2024
f87058d
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 2, 2024
4d5df76
Merge branch 'prover_cli_tests' of github.com:matter-labs/zksync-era …
ColoCarletti Jul 2, 2024
d01de36
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 2, 2024
4c573bb
Merge branch 'main' into prover_cli_tests
EmilLuta Jul 3, 2024
27ae83f
fix imports
ColoCarletti Jul 4, 2024
16a0398
update Cargo.lock
ColoCarletti Jul 4, 2024
2fda18c
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 4, 2024
b88f594
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 12, 2024
d747119
add witness_inputs_blob_url parameter
ColoCarletti Jul 12, 2024
7389589
change test db url
ColoCarletti Jul 12, 2024
b49e977
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 12, 2024
76f4d9f
add prover_test_pool
ColoCarletti Jul 12, 2024
069c401
Merge branch 'prover_cli_tests' of github.com:matter-labs/zksync-era …
ColoCarletti Jul 12, 2024
6a00610
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 15, 2024
161d521
remove sqlx from .toml
ColoCarletti Jul 15, 2024
1a26d96
update cargo.lock
ColoCarletti Jul 16, 2024
b53b137
Merge branch 'main' into prover_cli_stuck_status
ColoCarletti Jul 16, 2024
e3a7c4a
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 17, 2024
312b57a
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 23, 2024
7b60969
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 23, 2024
95aa565
Move prover_cli tests to new directory.
ColoCarletti Jul 23, 2024
7b0b20e
Merge branch 'prover_cli_tests' of github.com:matter-labs/zksync-era …
ColoCarletti Jul 23, 2024
a84ab6f
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 23, 2024
14415d8
Merge branch 'main' into prover_cli_stuck_status
ColoCarletti Jul 23, 2024
a927082
Merge branch 'main' into prover_cli_tests
ColoCarletti Jul 25, 2024
b1fb279
move querys into prover_dal
ColoCarletti Jul 31, 2024
0075155
move batch test to test dir
ColoCarletti Aug 1, 2024
af08b08
Add a method to create a PoverCLI from string
ColoCarletti Aug 1, 2024
981e02e
use nextest in prover tests
ColoCarletti Aug 1, 2024
2646cbf
fix plicongif
ColoCarletti Aug 2, 2024
734c569
Merge branch 'main' into prover_cli_tests
ColoCarletti Aug 6, 2024
717a1b2
Change structs to pub
ColoCarletti Aug 6, 2024
cd18de4
Merge branch 'main' into prover_cli_tests
ColoCarletti Aug 7, 2024
ebb4fac
Merge branch 'main' into prover_cli_tests
ColoCarletti Aug 8, 2024
ea6b2c7
Merge branch 'prover_cli_tests' of github.com:matter-labs/zksync-era …
ColoCarletti Aug 13, 2024
f136f81
Merge branch 'main' into prover_cli_tests
ColoCarletti Aug 13, 2024
6da8084
updte Cargo.locl
ColoCarletti Aug 13, 2024
b1694d5
Modify the tests so that they can run asynchronously
ColoCarletti Aug 13, 2024
d7c6326
fix flaky test
ColoCarletti Aug 13, 2024
815e816
Merge branch 'prover_cli_tests' into prover_cli_stuck_status
ColoCarletti Aug 13, 2024
41b9712
marge prover_cli_tests
ColoCarletti Aug 13, 2024
89ca726
zk fmt
ColoCarletti Aug 13, 2024
bc89324
fix queue status
ColoCarletti Aug 13, 2024
16956c0
add tests
ColoCarletti Aug 15, 2024
db8aad5
Merge branch 'main' into prover_cli_stuck_status
ColoCarletti Aug 16, 2024
8e900fa
Merge branch 'main' into prover_cli_stuck_status
ColoCarletti Aug 16, 2024
b899d62
clippy
ColoCarletti Aug 16, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
55 changes: 55 additions & 0 deletions core/lib/basic_types/src/prover_dal.rs
Original file line number Diff line number Diff line change
Expand Up @@ -260,6 +260,11 @@ pub struct ProverJobFriInfo {
pub picked_by: Option<String>,
}

pub trait Stallable {
fn get_status(&self) -> WitnessJobStatus;
fn get_attempts(&self) -> u32;
}

#[derive(Debug, Clone)]
pub struct BasicWitnessGeneratorJobInfo {
pub l1_batch_number: L1BatchNumber,
Expand All @@ -275,6 +280,16 @@ pub struct BasicWitnessGeneratorJobInfo {
pub picked_by: Option<String>,
}

impl Stallable for BasicWitnessGeneratorJobInfo {
fn get_status(&self) -> WitnessJobStatus {
self.status.clone()
}

fn get_attempts(&self) -> u32 {
self.attempts
}
}

#[derive(Debug, Clone)]
pub struct LeafWitnessGeneratorJobInfo {
pub id: u32,
Expand All @@ -293,6 +308,16 @@ pub struct LeafWitnessGeneratorJobInfo {
pub picked_by: Option<String>,
}

impl Stallable for LeafWitnessGeneratorJobInfo {
fn get_status(&self) -> WitnessJobStatus {
self.status.clone()
}

fn get_attempts(&self) -> u32 {
self.attempts
}
}

#[derive(Debug, Clone)]
pub struct NodeWitnessGeneratorJobInfo {
pub id: u32,
Expand All @@ -312,6 +337,16 @@ pub struct NodeWitnessGeneratorJobInfo {
pub picked_by: Option<String>,
}

impl Stallable for NodeWitnessGeneratorJobInfo {
fn get_status(&self) -> WitnessJobStatus {
self.status.clone()
}

fn get_attempts(&self) -> u32 {
self.attempts
}
}

#[derive(Debug, Clone)]
pub struct RecursionTipWitnessGeneratorJobInfo {
pub l1_batch_number: L1BatchNumber,
Expand All @@ -327,6 +362,16 @@ pub struct RecursionTipWitnessGeneratorJobInfo {
pub picked_by: Option<String>,
}

impl Stallable for RecursionTipWitnessGeneratorJobInfo {
fn get_status(&self) -> WitnessJobStatus {
self.status.clone()
}

fn get_attempts(&self) -> u32 {
self.attempts
}
}

#[derive(Debug, Clone)]
pub struct SchedulerWitnessGeneratorJobInfo {
pub l1_batch_number: L1BatchNumber,
Expand All @@ -342,6 +387,16 @@ pub struct SchedulerWitnessGeneratorJobInfo {
pub picked_by: Option<String>,
}

impl Stallable for SchedulerWitnessGeneratorJobInfo {
fn get_status(&self) -> WitnessJobStatus {
self.status.clone()
}

fn get_attempts(&self) -> u32 {
self.attempts
}
}

#[derive(Debug, EnumString, Display, Clone)]
pub enum ProofCompressionJobStatus {
#[strum(serialize = "queued")]
Expand Down
130 changes: 74 additions & 56 deletions prover/crates/bin/prover_cli/src/commands/status/batch.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ use anyhow::Context as _;
use circuit_definitions::zkevm_circuits::scheduler::aux::BaseLayerCircuitType;
use clap::Args as ClapArgs;
use colored::*;
use zksync_config::configs::FriProverConfig;
use zksync_env_config::FromEnv;
use zksync_prover_dal::{Connection, ConnectionPool, Prover, ProverDal};
use zksync_types::{
basic_fri_types::AggregationRound,
Expand All @@ -16,8 +18,11 @@ use zksync_types::{
L1BatchNumber,
};

use super::utils::{BatchData, StageInfo, Status};
use crate::cli::ProverCLIConfig;
use super::utils::{get_prover_job_status, BatchData, StageInfo, Status};
use crate::{
cli::ProverCLIConfig,
commands::status::utils::{get_prover_jobs_status_from_vec, get_witness_generator_job_status},
};

#[derive(ClapArgs)]
pub struct Args {
Expand All @@ -36,7 +41,7 @@ pub(crate) async fn run(args: Args, config: ProverCLIConfig) -> anyhow::Result<(
format!("Batch {} Status", batch_data.batch_number).bold()
);

if let Status::Custom(msg) = batch_data.compressor.witness_generator_jobs_status() {
if let Status::Custom(msg) = batch_data.compressor.witness_generator_jobs_status(10) {
if msg.contains("Sent to server") {
println!("> Proof sent to server ✅");
continue;
Expand All @@ -45,7 +50,7 @@ pub(crate) async fn run(args: Args, config: ProverCLIConfig) -> anyhow::Result<(

let basic_witness_generator_status = batch_data
.basic_witness_generator
.witness_generator_jobs_status();
.witness_generator_jobs_status(10);
if matches!(basic_witness_generator_status, Status::JobsNotFound) {
println!("> No batch found. 🚫");
continue;
Expand Down Expand Up @@ -205,25 +210,21 @@ fn display_batch_status(batch_data: BatchData) {
}

fn display_status_for_stage(stage_info: StageInfo) {
let max_attempts = FriProverConfig::from_env()
.expect("Fail to read prover config.")
.max_attempts;
display_aggregation_round(&stage_info);
match stage_info.witness_generator_jobs_status() {
let status = stage_info.witness_generator_jobs_status(max_attempts);
match status {
Status::Custom(msg) => {
println!("{}: {} \n", stage_info.to_string().bold(), msg);
}
Status::Queued | Status::WaitingForProofs | Status::Stuck | Status::JobsNotFound => {
println!(
"{}: {}",
stage_info.to_string().bold(),
stage_info.witness_generator_jobs_status()
)
println!("{}: {}", stage_info.to_string().bold(), status)
}
Status::InProgress | Status::Successful => {
println!(
"{}: {}",
stage_info.to_string().bold(),
stage_info.witness_generator_jobs_status()
);
if let Some(job_status) = stage_info.prover_jobs_status() {
println!("{}: {}", stage_info.to_string().bold(), status);
if let Some(job_status) = stage_info.prover_jobs_status(max_attempts) {
println!("> {}: {}", "Prover Jobs".to_owned().bold(), job_status);
}
}
Expand All @@ -240,53 +241,51 @@ fn display_batch_info(batch_data: BatchData) {
}

fn display_info_for_stage(stage_info: StageInfo) {
let max_attempts = FriProverConfig::from_env()
.expect("Fail to read prover config.")
.max_attempts;
display_aggregation_round(&stage_info);
match stage_info.witness_generator_jobs_status() {
let status = stage_info.witness_generator_jobs_status(max_attempts);
match status {
Status::Custom(msg) => {
println!("{}: {}", stage_info.to_string().bold(), msg);
}
Status::Queued | Status::WaitingForProofs | Status::Stuck | Status::JobsNotFound => {
println!(
" > {}: {}",
stage_info.to_string().bold(),
stage_info.witness_generator_jobs_status()
)
Status::Queued | Status::WaitingForProofs | Status::JobsNotFound => {
println!(" > {}: {}", stage_info.to_string().bold(), status)
}
Status::InProgress => {
println!(
"v {}: {}",
stage_info.to_string().bold(),
stage_info.witness_generator_jobs_status()
);
Status::InProgress | Status::Stuck => {
println!("v {}: {}", stage_info.to_string().bold(), status);
match stage_info {
StageInfo::BasicWitnessGenerator {
prover_jobs_info, ..
} => {
display_prover_jobs_info(prover_jobs_info);
display_prover_jobs_info(prover_jobs_info, max_attempts);
}
StageInfo::LeafWitnessGenerator {
witness_generator_jobs_info,
prover_jobs_info,
} => {
display_leaf_witness_generator_jobs_info(witness_generator_jobs_info);
display_prover_jobs_info(prover_jobs_info);
display_leaf_witness_generator_jobs_info(
witness_generator_jobs_info,
max_attempts,
);
display_prover_jobs_info(prover_jobs_info, max_attempts);
}
StageInfo::NodeWitnessGenerator {
witness_generator_jobs_info,
prover_jobs_info,
} => {
display_node_witness_generator_jobs_info(witness_generator_jobs_info);
display_prover_jobs_info(prover_jobs_info);
display_node_witness_generator_jobs_info(
witness_generator_jobs_info,
max_attempts,
);
display_prover_jobs_info(prover_jobs_info, max_attempts);
}
_ => (),
}
}
Status::Successful => {
println!(
"> {}: {}",
stage_info.to_string().bold(),
stage_info.witness_generator_jobs_status()
);
println!("> {}: {}", stage_info.to_string().bold(), status);
match stage_info {
StageInfo::BasicWitnessGenerator {
prover_jobs_info, ..
Expand All @@ -296,55 +295,58 @@ fn display_info_for_stage(stage_info: StageInfo) {
}
| StageInfo::NodeWitnessGenerator {
prover_jobs_info, ..
} => display_prover_jobs_info(prover_jobs_info),
} => display_prover_jobs_info(prover_jobs_info, max_attempts),
_ => (),
}
}
}
}

fn display_leaf_witness_generator_jobs_info(
mut leaf_witness_generators_jobs_info: Vec<LeafWitnessGeneratorJobInfo>,
mut jobs_info: Vec<LeafWitnessGeneratorJobInfo>,
max_attempts: u32,
) {
leaf_witness_generators_jobs_info.sort_by_key(|job| job.circuit_id);
jobs_info.sort_by_key(|job| job.circuit_id);

leaf_witness_generators_jobs_info.iter().for_each(|job| {
jobs_info.iter().for_each(|job| {
println!(
" > {}: {}",
format!(
"{:?}",
BaseLayerCircuitType::from_numeric_value(job.circuit_id as u8)
)
.bold(),
Status::from(job.status.clone())
get_witness_generator_job_status(job, max_attempts)
)
});
}

fn display_node_witness_generator_jobs_info(
mut node_witness_generators_jobs_info: Vec<NodeWitnessGeneratorJobInfo>,
mut jobs_info: Vec<NodeWitnessGeneratorJobInfo>,
max_attempts: u32,
) {
node_witness_generators_jobs_info.sort_by_key(|job| job.circuit_id);
jobs_info.sort_by_key(|job| job.circuit_id);

node_witness_generators_jobs_info.iter().for_each(|job| {
jobs_info.iter().for_each(|job| {
println!(
" > {}: {}",
format!(
"{:?}",
BaseLayerCircuitType::from_numeric_value(job.circuit_id as u8)
)
.bold(),
Status::from(job.status.clone())
get_witness_generator_job_status(job, max_attempts)
)
});
}

fn display_prover_jobs_info(prover_jobs_info: Vec<ProverJobFriInfo>) {
let prover_jobs_status = Status::from(prover_jobs_info.clone());
fn display_prover_jobs_info(prover_jobs_info: Vec<ProverJobFriInfo>, max_attempts: u32) {
let prover_jobs_status = get_prover_jobs_status_from_vec(&prover_jobs_info, max_attempts);

if matches!(prover_jobs_status, Status::Successful)
|| matches!(prover_jobs_status, Status::JobsNotFound)
{
if matches!(
prover_jobs_status,
Status::Successful | Status::JobsNotFound
) {
println!(
"> {}: {prover_jobs_status}",
"Prover Jobs".to_owned().bold()
Expand All @@ -366,7 +368,7 @@ fn display_prover_jobs_info(prover_jobs_info: Vec<ProverJobFriInfo>) {
});

for (circuit_id, prover_jobs_info) in jobs_by_circuit_id {
let status = Status::from(prover_jobs_info.clone());
let status = get_prover_jobs_status_from_vec(&prover_jobs_info, max_attempts);
println!(
" > {}: {}",
format!(
Expand All @@ -376,8 +378,10 @@ fn display_prover_jobs_info(prover_jobs_info: Vec<ProverJobFriInfo>) {
.bold(),
status
);
if matches!(status, Status::InProgress) {
display_job_status_count(prover_jobs_info);
match status {
Status::InProgress => display_job_status_count(prover_jobs_info),
Status::Stuck => display_stuck_jobs(prover_jobs_info, max_attempts),
_ => (),
}
}
}
Expand All @@ -400,6 +404,20 @@ fn display_job_status_count(jobs: Vec<ProverJobFriInfo>) {
println!(" - Failed: {}", jobs_counts.failed);
}

fn display_stuck_jobs(jobs: Vec<ProverJobFriInfo>, max_attempts: u32) {
jobs.iter().for_each(|job| {
if matches!(
get_prover_job_status(job.clone(), max_attempts),
Status::Stuck
) {
println!(
" - Prover Job: {} stuck after {} attempts",
job.id, job.attempts
);
}
})
}

fn display_aggregation_round(stage_info: &StageInfo) {
if let Some(aggregation_round) = stage_info.aggregation_round() {
println!(
Expand Down
Loading
Loading