forked from the-distro/ofborg
add basic structured logging to comment poster
This commit is contained in:
parent
2b59f86125
commit
cb9a125cdc
|
@ -133,6 +133,13 @@ impl BuildResult {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn pr(&self) -> Pr {
|
||||||
|
match self {
|
||||||
|
BuildResult::Legacy { pr, .. } => pr.to_owned(),
|
||||||
|
BuildResult::V1 { pr, .. } => pr.to_owned(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn status(&self) -> BuildStatus {
|
pub fn status(&self) -> BuildStatus {
|
||||||
match *self {
|
match *self {
|
||||||
BuildResult::Legacy {
|
BuildResult::Legacy {
|
||||||
|
|
|
@ -6,7 +6,7 @@ use crate::worker;
|
||||||
|
|
||||||
use chrono::{DateTime, Utc};
|
use chrono::{DateTime, Utc};
|
||||||
use hubcaps::checks::{CheckRunOptions, CheckRunState, Conclusion, Output};
|
use hubcaps::checks::{CheckRunOptions, CheckRunState, Conclusion, Output};
|
||||||
use tracing::info;
|
use tracing::{debug, debug_span, info};
|
||||||
|
|
||||||
pub struct GitHubCommentPoster {
|
pub struct GitHubCommentPoster {
|
||||||
github_vend: GithubAppVendingMachine,
|
github_vend: GithubAppVendingMachine,
|
||||||
|
@ -50,22 +50,33 @@ impl worker::SimpleWorker for GitHubCommentPoster {
|
||||||
let mut checks: Vec<CheckRunOptions> = vec![];
|
let mut checks: Vec<CheckRunOptions> = vec![];
|
||||||
let repo: Repo;
|
let repo: Repo;
|
||||||
|
|
||||||
match job {
|
let pr = match job {
|
||||||
PostableEvent::BuildQueued(queued_job) => {
|
PostableEvent::BuildQueued(queued_job) => {
|
||||||
repo = queued_job.job.repo.clone();
|
repo = queued_job.job.repo.clone();
|
||||||
for architecture in queued_job.architectures.iter() {
|
for architecture in queued_job.architectures.iter() {
|
||||||
checks.push(job_to_check(&queued_job.job, &architecture, Utc::now()));
|
checks.push(job_to_check(&queued_job.job, &architecture, Utc::now()));
|
||||||
}
|
}
|
||||||
|
queued_job.job.pr.to_owned()
|
||||||
}
|
}
|
||||||
PostableEvent::BuildFinished(finished_job) => {
|
PostableEvent::BuildFinished(finished_job) => {
|
||||||
let result = finished_job.legacy();
|
let result = finished_job.legacy();
|
||||||
repo = result.repo.clone();
|
repo = result.repo.clone();
|
||||||
checks.push(result_to_check(&result, Utc::now()));
|
checks.push(result_to_check(&result, Utc::now()));
|
||||||
|
finished_job.pr()
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
|
let span = debug_span!("job", pr = ?pr.number);
|
||||||
|
let _enter = span.enter();
|
||||||
|
|
||||||
for check in checks {
|
for check in checks {
|
||||||
info!(":{:?}", check);
|
info!(
|
||||||
|
"check {:?} {} {}",
|
||||||
|
check.status,
|
||||||
|
check.name,
|
||||||
|
check.details_url.as_ref().unwrap_or(&String::from("-"))
|
||||||
|
);
|
||||||
|
debug!("{:?}", check);
|
||||||
|
|
||||||
let check_create_attempt = self
|
let check_create_attempt = self
|
||||||
.github_vend
|
.github_vend
|
||||||
|
|
Loading…
Reference in a new issue