commitstatus: return an error if we fail to set a status

This commit is contained in:
Graham Christensen 2020-03-31 17:23:20 -04:00
parent 3e5132596b
commit 0ae112f976
No known key found for this signature in database
GPG key ID: FE918C3A98C1030F

View file

@ -36,18 +36,25 @@ impl<'a> CommitStatus<'a> {
self.url = url.unwrap_or_else(|| String::from("")) self.url = url.unwrap_or_else(|| String::from(""))
} }
pub fn set_with_description(&mut self, description: &str, state: hubcaps::statuses::State) { pub fn set_with_description(
&mut self,
description: &str,
state: hubcaps::statuses::State,
) -> Result<(), CommitStatusError> {
self.set_description(description.to_owned()); self.set_description(description.to_owned());
self.set(state); self.set(state)
} }
pub fn set_description(&mut self, description: String) { pub fn set_description(&mut self, description: String) {
self.description = description; self.description = description;
} }
pub fn set(&self, state: hubcaps::statuses::State) { pub fn set(&self, state: hubcaps::statuses::State) -> Result<(), CommitStatusError> {
let desc = if self.description.len() >= 140 { let desc = if self.description.len() >= 140 {
eprintln!("Warning: description is over 140 char; truncating: {:?}", &self.description); eprintln!(
"Warning: description is over 140 char; truncating: {:?}",
&self.description
);
self.description.chars().take(140).collect() self.description.chars().take(140).collect()
} else { } else {
self.description.clone() self.description.clone()
@ -62,6 +69,11 @@ impl<'a> CommitStatus<'a> {
.target_url(self.url.clone()) .target_url(self.url.clone())
.build(), .build(),
) )
.expect("Failed to mark final status on commit"); .map(|_| ())
.map_err(|e| CommitStatusError::HubcapsError(e))
} }
} }
pub enum CommitStatusError {
HubcapsError(hubcaps::Error),
}