use derive_builder::Builder;
use crate::api::common::NameOrId;
use crate::api::endpoint_prelude::*;
#[derive(Debug, Builder, Clone)]
pub struct DeleteHook<'a> {
#[builder(setter(into))]
group: NameOrId<'a>,
hook_id: u64,
}
impl<'a> DeleteHook<'a> {
pub fn builder() -> DeleteHookBuilder<'a> {
DeleteHookBuilder::default()
}
}
impl<'a> Endpoint for DeleteHook<'a> {
fn method(&self) -> Method {
Method::DELETE
}
fn endpoint(&self) -> Cow<'static, str> {
format!("groups/{}/hooks/{}", self.group, self.hook_id).into()
}
}
#[cfg(test)]
mod tests {
use http::Method;
use crate::api::groups::hooks::{DeleteHook, DeleteHookBuilderError};
use crate::api::{self, Query};
use crate::test::client::{ExpectedUrl, SingleTestClient};
#[test]
fn group_and_hook_id_are_necessary() {
let err = DeleteHook::builder().build().unwrap_err();
crate::test::assert_missing_field!(err, DeleteHookBuilderError, "group");
}
#[test]
fn group_is_necessary() {
let err = DeleteHook::builder().hook_id(1).build().unwrap_err();
crate::test::assert_missing_field!(err, DeleteHookBuilderError, "group");
}
#[test]
fn hook_id_is_necessary() {
let err = DeleteHook::builder().group("group").build().unwrap_err();
crate::test::assert_missing_field!(err, DeleteHookBuilderError, "hook_id");
}
#[test]
fn group_and_hook_id_are_sufficient() {
DeleteHook::builder()
.group("group")
.hook_id(1)
.build()
.unwrap();
}
#[test]
fn endpoint() {
let endpoint = ExpectedUrl::builder()
.method(Method::DELETE)
.endpoint("groups/simple%2Fgroup/hooks/1")
.build()
.unwrap();
let client = SingleTestClient::new_raw(endpoint, "");
let endpoint = DeleteHook::builder()
.group("simple/group")
.hook_id(1)
.build()
.unwrap();
api::ignore(endpoint).query(&client).unwrap();
}
}