openstack_sdk/api/load_balancer/v2/loadbalancer/
status.rs1use derive_builder::Builder;
39use http::{HeaderMap, HeaderName, HeaderValue};
40
41use crate::api::rest_endpoint_prelude::*;
42
43use std::borrow::Cow;
44
45#[derive(Builder, Debug, Clone)]
46#[builder(setter(strip_option))]
47pub struct Request<'a> {
48 #[builder(default, setter(into))]
51 id: Cow<'a, str>,
52
53 #[builder(setter(name = "_headers"), default, private)]
54 _headers: Option<HeaderMap>,
55}
56impl<'a> Request<'a> {
57 pub fn builder() -> RequestBuilder<'a> {
59 RequestBuilder::default()
60 }
61}
62
63impl RequestBuilder<'_> {
64 pub fn header(&mut self, header_name: &'static str, header_value: &'static str) -> &mut Self
66where {
67 self._headers
68 .get_or_insert(None)
69 .get_or_insert_with(HeaderMap::new)
70 .insert(header_name, HeaderValue::from_static(header_value));
71 self
72 }
73
74 pub fn headers<I, T>(&mut self, iter: I) -> &mut Self
76 where
77 I: Iterator<Item = T>,
78 T: Into<(Option<HeaderName>, HeaderValue)>,
79 {
80 self._headers
81 .get_or_insert(None)
82 .get_or_insert_with(HeaderMap::new)
83 .extend(iter.map(Into::into));
84 self
85 }
86}
87
88impl RestEndpoint for Request<'_> {
89 fn method(&self) -> http::Method {
90 http::Method::GET
91 }
92
93 fn endpoint(&self) -> Cow<'static, str> {
94 format!("lbaas/loadbalancers/{id}/status", id = self.id.as_ref(),).into()
95 }
96
97 fn parameters(&self) -> QueryParams {
98 QueryParams::default()
99 }
100
101 fn service_type(&self) -> ServiceType {
102 ServiceType::LoadBalancer
103 }
104
105 fn response_key(&self) -> Option<Cow<'static, str>> {
106 Some("statuses".into())
107 }
108
109 fn request_headers(&self) -> Option<&HeaderMap> {
111 self._headers.as_ref()
112 }
113
114 fn api_version(&self) -> Option<ApiVersion> {
116 Some(ApiVersion::new(2, 0))
117 }
118}
119
120#[cfg(test)]
121mod tests {
122 use super::*;
123 #[cfg(feature = "sync")]
124 use crate::api::Query;
125 use crate::test::client::FakeOpenStackClient;
126 use crate::types::ServiceType;
127 use http::{HeaderName, HeaderValue};
128 use httpmock::MockServer;
129 use serde_json::json;
130
131 #[test]
132 fn test_service_type() {
133 assert_eq!(
134 Request::builder().build().unwrap().service_type(),
135 ServiceType::LoadBalancer
136 );
137 }
138
139 #[test]
140 fn test_response_key() {
141 assert_eq!(
142 Request::builder().build().unwrap().response_key().unwrap(),
143 "statuses"
144 );
145 }
146
147 #[cfg(feature = "sync")]
148 #[test]
149 fn endpoint() {
150 let server = MockServer::start();
151 let client = FakeOpenStackClient::new(server.base_url());
152 let mock = server.mock(|when, then| {
153 when.method(httpmock::Method::GET)
154 .path(format!("/lbaas/loadbalancers/{id}/status", id = "id",));
155
156 then.status(200)
157 .header("content-type", "application/json")
158 .json_body(json!({ "statuses": {} }));
159 });
160
161 let endpoint = Request::builder().id("id").build().unwrap();
162 let _: serde_json::Value = endpoint.query(&client).unwrap();
163 mock.assert();
164 }
165
166 #[cfg(feature = "sync")]
167 #[test]
168 fn endpoint_headers() {
169 let server = MockServer::start();
170 let client = FakeOpenStackClient::new(server.base_url());
171 let mock = server.mock(|when, then| {
172 when.method(httpmock::Method::GET)
173 .path(format!("/lbaas/loadbalancers/{id}/status", id = "id",))
174 .header("foo", "bar")
175 .header("not_foo", "not_bar");
176 then.status(200)
177 .header("content-type", "application/json")
178 .json_body(json!({ "statuses": {} }));
179 });
180
181 let endpoint = Request::builder()
182 .id("id")
183 .headers(
184 [(
185 Some(HeaderName::from_static("foo")),
186 HeaderValue::from_static("bar"),
187 )]
188 .into_iter(),
189 )
190 .header("not_foo", "not_bar")
191 .build()
192 .unwrap();
193 let _: serde_json::Value = endpoint.query(&client).unwrap();
194 mock.assert();
195 }
196}