Skip to main content

gitlab/api/projects/merge_requests/pipelines/
create.rs

1// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
2// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
3// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
4// option. This file may not be copied, modified, or distributed
5// except according to those terms.
6
7use derive_builder::Builder;
8
9use crate::api::common::NameOrId;
10use crate::api::endpoint_prelude::*;
11
12/// List all pipelines attached to a merge request.
13#[derive(Debug, Builder, Clone)]
14pub struct CreateMergeRequestPipelines<'a> {
15    /// The project with the merge request.
16    #[builder(setter(into))]
17    project: NameOrId<'a>,
18    /// The ID of the merge request.
19    merge_request: u64,
20}
21
22impl<'a> CreateMergeRequestPipelines<'a> {
23    /// Create a builder for the endpoint.
24    pub fn builder() -> CreateMergeRequestPipelinesBuilder<'a> {
25        CreateMergeRequestPipelinesBuilder::default()
26    }
27}
28
29impl Endpoint for CreateMergeRequestPipelines<'_> {
30    fn method(&self) -> Method {
31        Method::POST
32    }
33
34    fn endpoint(&self) -> Cow<'static, str> {
35        format!(
36            "projects/{}/merge_requests/{}/pipelines",
37            self.project, self.merge_request,
38        )
39        .into()
40    }
41}
42
43#[cfg(test)]
44mod tests {
45    use http::Method;
46
47    use crate::api::projects::merge_requests::pipelines::{
48        CreateMergeRequestPipelines, CreateMergeRequestPipelinesBuilderError,
49    };
50    use crate::api::{self, Query};
51    use crate::test::client::{ExpectedUrl, SingleTestClient};
52
53    #[test]
54    fn project_and_merge_request_are_needed() {
55        let err = CreateMergeRequestPipelines::builder().build().unwrap_err();
56        crate::test::assert_missing_field!(err, CreateMergeRequestPipelinesBuilderError, "project");
57    }
58
59    #[test]
60    fn project_is_needed() {
61        let err = CreateMergeRequestPipelines::builder()
62            .merge_request(1)
63            .build()
64            .unwrap_err();
65        crate::test::assert_missing_field!(err, CreateMergeRequestPipelinesBuilderError, "project");
66    }
67
68    #[test]
69    fn merge_request_is_needed() {
70        let err = CreateMergeRequestPipelines::builder()
71            .project(1)
72            .build()
73            .unwrap_err();
74        crate::test::assert_missing_field!(
75            err,
76            CreateMergeRequestPipelinesBuilderError,
77            "merge_request",
78        );
79    }
80
81    #[test]
82    fn project_and_merge_request_are_sufficient() {
83        CreateMergeRequestPipelines::builder()
84            .project(1)
85            .merge_request(1)
86            .build()
87            .unwrap();
88    }
89
90    #[test]
91    fn endpoint() {
92        let endpoint = ExpectedUrl::builder()
93            .method(Method::POST)
94            .endpoint("projects/simple%2Fproject/merge_requests/1/pipelines")
95            .build()
96            .unwrap();
97        let client = SingleTestClient::new_raw(endpoint, "");
98
99        let endpoint = CreateMergeRequestPipelines::builder()
100            .project("simple/project")
101            .merge_request(1)
102            .build()
103            .unwrap();
104        api::ignore(endpoint).query(&client).unwrap();
105    }
106}