make actions per worker

This commit is contained in:
Graham Christensen 2017-11-07 15:03:28 -05:00
parent 0133c66887
commit 3de397f4be
No known key found for this signature in database
GPG key ID: ACA1C1D120C83D5C
3 changed files with 16 additions and 17 deletions

View file

@ -17,7 +17,6 @@ use ofborg::config;
use ofborg::checkout; use ofborg::checkout;
use ofborg::worker; use ofborg::worker;
use ofborg::message::buildjob; use ofborg::message::buildjob;
use ofborg::worker::Actions;
fn main() { fn main() {
let cfg = config::load(env::args().nth(1).unwrap().as_ref()); let cfg = config::load(env::args().nth(1).unwrap().as_ref());
@ -62,6 +61,7 @@ struct BuildWorker {
impl worker::SimpleWorker for BuildWorker { impl worker::SimpleWorker for BuildWorker {
type J = buildjob::BuildJob; type J = buildjob::BuildJob;
type A = buildjob::Actions;
fn msg_to_job(&self, method: &Deliver, headers: &BasicProperties, fn msg_to_job(&self, method: &Deliver, headers: &BasicProperties,
body: &Vec<u8>) -> Result<Self::J, String> { body: &Vec<u8>) -> Result<Self::J, String> {
@ -75,7 +75,12 @@ impl worker::SimpleWorker for BuildWorker {
} }
} }
fn consumer(&self, job: buildjob::BuildJob, resp: Actions) -> Result<(), Error> { fn job_to_actions(&self, channel: &mut amqp::Channel, job: &buildjob::BuildJob) -> buildjob::Actions {
return buildjob::Actions{};
}
fn consumer(&self, job: buildjob::BuildJob, resp: buildjob::Actions) -> Result<(), Error> {
let project = self.cloner.project(job.repo.full_name, job.repo.clone_url); let project = self.cloner.project(job.repo.full_name, job.repo.clone_url);
let co = project.clone_for("builder".to_string(), let co = project.clone_for("builder".to_string(),
job.pr.number.to_string())?; job.pr.number.to_string())?;

View file

@ -10,3 +10,5 @@ pub struct BuildJob {
pub fn from(data: &Vec<u8>) -> Result<BuildJob, serde_json::error::Error> { pub fn from(data: &Vec<u8>) -> Result<BuildJob, serde_json::error::Error> {
return serde_json::from_slice(&data); return serde_json::from_slice(&data);
} }
pub struct Actions{}

View file

@ -13,10 +13,13 @@ pub struct Actions {
pub trait SimpleWorker { pub trait SimpleWorker {
type J; type J;
fn consumer(&self, job: Self::J, resp: Actions) -> Result<(), Error>; type A;
fn consumer(&self, job: Self::J, resp: Self::A) -> Result<(), Error>;
fn msg_to_job(&self, method: &Deliver, headers: &BasicProperties, fn msg_to_job(&self, method: &Deliver, headers: &BasicProperties,
body: &Vec<u8>) -> Result<Self::J, String>; body: &Vec<u8>) -> Result<Self::J, String>;
fn job_to_actions(&self, channel: &mut Channel, job: &Self::J) -> Self::A;
} }
pub fn new<T: SimpleWorker>(worker: T) -> Worker<T> { pub fn new<T: SimpleWorker>(worker: T) -> Worker<T> {
@ -34,19 +37,8 @@ impl <T: SimpleWorker + Send> Consumer for Worker<T> {
headers: BasicProperties, headers: BasicProperties,
body: Vec<u8>) { body: Vec<u8>) {
match self.internal.msg_to_job(&method, &headers, &body) { let job = self.internal.msg_to_job(&method, &headers, &body).unwrap();
Ok(job) => { let actions = self.internal.job_to_actions(channel, &job);
let actions = Actions{}; self.internal.consumer(job, actions).unwrap();
match self.internal.consumer(job, actions) {
Ok(_) => { /* :) */ }
Err(_) => {
panic!("failed to run job!");
}
}
}
Err(e) => {
panic!(e);
}
}
} }
} }