1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
use serde_json::Value;
use std::collections::HashMap;
use std::env;
use std::fs::File;
use std::io::{BufRead, BufReader};
use std::process::Command;
fn get_last_metrics(metric: &str, db: &str, name: &str, branch: &str) -> Result<String, String> {
let query = format!(
r#"SELECT last("{}") FROM "{}"."autogen"."{}" WHERE "branch"='{}'"#,
metric, db, name, branch
);
let response = solana_metrics::query(&query)?;
match serde_json::from_str(&response) {
Result::Ok(v) => {
let v: Value = v;
let data = &v["results"][0]["series"][0]["values"][0][1];
if data.is_null() {
return Result::Err("Key not found".to_string());
}
Result::Ok(data.to_string())
}
Result::Err(err) => Result::Err(err.to_string()),
}
}
fn main() {
let args: Vec<String> = env::args().collect();
let fname = &args[1];
let file = match File::open(fname) {
Err(why) => panic!("couldn't open {}: {:?}", fname, why),
Ok(file) => file,
};
let branch = &args[2];
let upload_metrics = args.len() > 2;
let git_output = Command::new("git")
.args(&["rev-parse", "HEAD"])
.output()
.expect("failed to execute git rev-parse");
let git_commit_hash = String::from_utf8_lossy(&git_output.stdout);
let trimmed_hash = git_commit_hash.trim().to_string();
let mut last_commit = None;
let mut results = HashMap::new();
let db = env::var("INFLUX_DATABASE").unwrap_or_else(|_| "scratch".to_string());
for line in BufReader::new(file).lines() {
if let Ok(v) = serde_json::from_str(&line.unwrap()) {
let v: Value = v;
if v["type"] == "bench" {
let name = v["name"].as_str().unwrap().trim_matches('\"').to_string();
if last_commit.is_none() {
last_commit = get_last_metrics(&"commit".to_string(), &db, &name, &branch).ok();
}
let median: i64 = v["median"].to_string().parse().unwrap();
let deviation: i64 = v["deviation"].to_string().parse().unwrap();
if upload_metrics {
panic!("TODO...");
}
let last_median = get_last_metrics(&"median".to_string(), &db, &name, &branch)
.unwrap_or_default();
let last_deviation =
get_last_metrics(&"deviation".to_string(), &db, &name, &branch)
.unwrap_or_default();
results.insert(name, (median, deviation, last_median, last_deviation));
}
}
}
if let Some(commit) = last_commit {
println!(
"Comparing current commits: {} against baseline {} on {} branch",
trimmed_hash, commit, branch
);
println!("bench_name, median, last_median, deviation, last_deviation");
for (entry, values) in results {
println!(
"{}, {:#10?}, {:#10?}, {:#10?}, {:#10?}",
entry,
values.0,
values.2.parse::<i32>().unwrap_or_default(),
values.1,
values.3.parse::<i32>().unwrap_or_default(),
);
}
} else {
println!("No previous results found for {} branch", branch);
println!("hash: {}", trimmed_hash);
println!("bench_name, median, deviation");
for (entry, values) in results {
println!("{}, {:10?}, {:10?}", entry, values.0, values.1);
}
}
solana_metrics::flush();
}