Signed-off-by: kjuulh <contact@kjuulh.io>
This commit is contained in:
@@ -4,9 +4,9 @@ use async_trait::async_trait;
|
||||
use tokio::sync::Mutex;
|
||||
|
||||
pub struct CuddleCI {
|
||||
pr_action: Arc<Mutex<dyn PullRequestAction + Send + Sync>>,
|
||||
main_action: Arc<Mutex<dyn MainAction + Send + Sync>>,
|
||||
release_action: Arc<Mutex<dyn ReleaseAction + Send + Sync>>,
|
||||
pr_action: Vec<Arc<Mutex<dyn PullRequestAction + Send + Sync>>>,
|
||||
main_action: Vec<Arc<Mutex<dyn MainAction + Send + Sync>>>,
|
||||
release_action: Vec<Arc<Mutex<dyn ReleaseAction + Send + Sync>>>,
|
||||
}
|
||||
|
||||
impl CuddleCI {
|
||||
@@ -16,9 +16,9 @@ impl CuddleCI {
|
||||
release: Arc<Mutex<dyn ReleaseAction + Send + Sync>>,
|
||||
) -> Self {
|
||||
Self {
|
||||
pr_action: pr,
|
||||
main_action: main,
|
||||
release_action: release,
|
||||
pr_action: vec![pr],
|
||||
main_action: vec![main],
|
||||
release_action: vec![release],
|
||||
}
|
||||
}
|
||||
|
||||
@@ -26,13 +26,13 @@ impl CuddleCI {
|
||||
&mut self,
|
||||
pr: Arc<Mutex<dyn PullRequestAction + Send + Sync>>,
|
||||
) -> &mut Self {
|
||||
self.pr_action = pr;
|
||||
self.pr_action.push(pr);
|
||||
|
||||
self
|
||||
}
|
||||
|
||||
pub fn with_main(&mut self, main: Arc<Mutex<dyn MainAction + Send + Sync>>) -> &mut Self {
|
||||
self.main_action = main;
|
||||
self.main_action.push(main);
|
||||
|
||||
self
|
||||
}
|
||||
@@ -41,7 +41,7 @@ impl CuddleCI {
|
||||
&mut self,
|
||||
release: Arc<Mutex<dyn ReleaseAction + Send + Sync>>,
|
||||
) -> &mut Self {
|
||||
self.release_action = release;
|
||||
self.release_action.push(release);
|
||||
|
||||
self
|
||||
}
|
||||
@@ -62,17 +62,23 @@ impl CuddleCI {
|
||||
Some((name, args)) => match (name, args) {
|
||||
("pr", _args) => {
|
||||
eprintln!("starting pr validate");
|
||||
self.pr_action.lock().await.execute_pull_request().await?;
|
||||
for pr_action in self.pr_action.iter() {
|
||||
pr_action.lock().await.execute_pull_request().await?;
|
||||
}
|
||||
eprintln!("finished pr validate");
|
||||
}
|
||||
("main", _args) => {
|
||||
eprintln!("starting main validate");
|
||||
self.main_action.lock().await.execute_main().await?;
|
||||
for main_action in self.main_action.iter() {
|
||||
main_action.lock().await.execute_main().await?;
|
||||
}
|
||||
eprintln!("finished main validate");
|
||||
}
|
||||
("release", _args) => {
|
||||
eprintln!("starting release validate");
|
||||
self.release_action.lock().await.execute_release().await?;
|
||||
for release_action in self.release_action.iter() {
|
||||
release_action.lock().await.execute_release().await?;
|
||||
}
|
||||
eprintln!("finished release validate");
|
||||
}
|
||||
(command_name, _) => {
|
||||
@@ -110,15 +116,16 @@ impl PullRequestAction for DefaultPullRequestAction {}
|
||||
|
||||
#[async_trait]
|
||||
pub trait MainAction {
|
||||
async fn execute_main(&self) -> eyre::Result<()> {
|
||||
eprintln!("validate main: noop");
|
||||
Ok(())
|
||||
}
|
||||
async fn execute_main(&self) -> eyre::Result<()>;
|
||||
}
|
||||
|
||||
pub struct DefaultMainAction {}
|
||||
#[async_trait]
|
||||
impl MainAction for DefaultMainAction {}
|
||||
impl MainAction for DefaultMainAction {
|
||||
async fn execute_main(&self) -> eyre::Result<()> {
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
#[async_trait]
|
||||
pub trait ReleaseAction {
|
||||
|
Reference in New Issue
Block a user