From c6e629b4ae7d7013581730ee747f3c0c613edeab Mon Sep 17 00:00:00 2001 From: Graham Christensen Date: Sat, 20 Jan 2018 12:12:58 -0500 Subject: [PATCH] Make logs routable by the comment filter --- ofborg/src/message/buildjob.rs | 1 + ofborg/src/tasks/build.rs | 20 ++++++++++++++++---- ofborg/src/tasks/githubcommentfilter.rs | 1 + 3 files changed, 18 insertions(+), 4 deletions(-) diff --git a/ofborg/src/message/buildjob.rs b/ofborg/src/message/buildjob.rs index c5c8075..afc2613 100644 --- a/ofborg/src/message/buildjob.rs +++ b/ofborg/src/message/buildjob.rs @@ -10,6 +10,7 @@ pub struct BuildJob { pub pr: Pr, pub subset: Option, pub attrs: Vec, + pub logs: Option<(String, String)>, // (Exchange, Routing Key) } pub fn from(data: &Vec) -> Result { diff --git a/ofborg/src/tasks/build.rs b/ofborg/src/tasks/build.rs index 7eb1895..30dc845 100644 --- a/ofborg/src/tasks/build.rs +++ b/ofborg/src/tasks/build.rs @@ -48,10 +48,14 @@ struct JobActions<'a, 'b> { job: &'b buildjob::BuildJob, line_counter: u64, attempt_id: String, + log_exchange: String, + log_routing_key: String, } impl<'a, 'b> JobActions<'a, 'b> { fn new(system: &str, identity: &str, job: &'b buildjob::BuildJob, receiver: &'a mut notifyworker::NotificationReceiver) -> JobActions<'a, 'b> { + let (log_exchange, log_routing_key) = job.logs.clone().unwrap_or((String::from("logs"), String::from("build.log"))); + return JobActions { system: system.to_owned(), identity: identity.to_owned(), @@ -59,6 +63,8 @@ impl<'a, 'b> JobActions<'a, 'b> { job: job, line_counter: 0, attempt_id: format!("{}", Uuid::new_v4()), + log_exchange: log_exchange, + log_routing_key: log_routing_key, }; } @@ -97,9 +103,12 @@ impl<'a, 'b> JobActions<'a, 'b> { attempt_id: self.attempt_id.clone(), }; + let log_exchange = Some(self.log_exchange.clone()); + let log_routing_key = Some(self.log_routing_key.clone()); + self.tell(worker::publish_serde_action( - Some("logs".to_owned()), - Some("build.log".to_owned()), + log_exchange, + log_routing_key, &msg )); } @@ -115,9 +124,12 @@ impl<'a, 'b> JobActions<'a, 'b> { output: line.to_owned(), }; + let log_exchange = Some(self.log_exchange.clone()); + let log_routing_key = Some(self.log_routing_key.clone()); + self.tell(worker::publish_serde_action( - Some("logs".to_owned()), - Some("build.log".to_owned()), + log_exchange, + log_routing_key, &msg )); } diff --git a/ofborg/src/tasks/githubcommentfilter.rs b/ofborg/src/tasks/githubcommentfilter.rs index ce2835d..f5e36b0 100644 --- a/ofborg/src/tasks/githubcommentfilter.rs +++ b/ofborg/src/tasks/githubcommentfilter.rs @@ -105,6 +105,7 @@ impl worker::SimpleWorker for GitHubCommentWorker { pr: pr_msg.clone(), subset: Some(subset), attrs: attrs, + logs: Some(("logs".to_owned(), "build.log".to_owned())) }; response.push(worker::publish_serde_action(