gitlab/api/projects/deployments/
delete.rsuse derive_builder::Builder;
use crate::api::common::NameOrId;
use crate::api::endpoint_prelude::*;
#[derive(Debug, Builder, Clone)]
pub struct DeleteDeployment<'a> {
#[builder(setter(into))]
project: NameOrId<'a>,
deployment_id: u64,
}
impl<'a> DeleteDeployment<'a> {
pub fn builder() -> DeleteDeploymentBuilder<'a> {
DeleteDeploymentBuilder::default()
}
}
impl Endpoint for DeleteDeployment<'_> {
fn method(&self) -> Method {
Method::DELETE
}
fn endpoint(&self) -> Cow<'static, str> {
format!(
"projects/{}/deployments/{}",
self.project, self.deployment_id,
)
.into()
}
}
#[cfg(test)]
mod tests {
use http::Method;
use crate::api::projects::deployments::{DeleteDeployment, DeleteDeploymentBuilderError};
use crate::api::{self, Query};
use crate::test::client::{ExpectedUrl, SingleTestClient};
#[test]
fn project_and_deployment_id_are_necessary() {
let err = DeleteDeployment::builder().build().unwrap_err();
crate::test::assert_missing_field!(err, DeleteDeploymentBuilderError, "project");
}
#[test]
fn project_is_necessary() {
let err = DeleteDeployment::builder()
.deployment_id(1)
.build()
.unwrap_err();
crate::test::assert_missing_field!(err, DeleteDeploymentBuilderError, "project");
}
#[test]
fn deployment_id_is_necessary() {
let err = DeleteDeployment::builder()
.project("project")
.build()
.unwrap_err();
crate::test::assert_missing_field!(err, DeleteDeploymentBuilderError, "deployment_id");
}
#[test]
fn project_and_deployment_id_are_sufficient() {
DeleteDeployment::builder()
.project("project")
.deployment_id(1)
.build()
.unwrap();
}
#[test]
fn endpoint() {
let endpoint = ExpectedUrl::builder()
.method(Method::DELETE)
.endpoint("projects/simple%2Fproject/deployments/1")
.build()
.unwrap();
let client = SingleTestClient::new_raw(endpoint, "");
let endpoint = DeleteDeployment::builder()
.project("simple/project")
.deployment_id(1)
.build()
.unwrap();
api::ignore(endpoint).query(&client).unwrap();
}
}