1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
use crate::{
methods::Method,
request::Request,
types::{Integer, PassportElementError},
};
use serde::Serialize;
#[derive(Clone, Debug, Serialize)]
pub struct SetPassportDataErrors {
user_id: Integer,
errors: Vec<PassportElementError>,
}
impl SetPassportDataErrors {
pub fn new(user_id: Integer, errors: Vec<PassportElementError>) -> Self {
SetPassportDataErrors { user_id, errors }
}
}
impl Method for SetPassportDataErrors {
type Response = bool;
fn into_request(self) -> Request {
Request::json("setPassportDataErrors", self)
}
}
#[cfg(test)]
mod tests {
use super::*;
use crate::request::{RequestBody, RequestMethod};
use serde_json::Value;
#[test]
fn set_passport_data_errors() {
let request = SetPassportDataErrors::new(1, vec![]).into_request();
assert_eq!(request.get_method(), RequestMethod::Post);
assert_eq!(
request.build_url("base-url", "token"),
"base-url/bottoken/setPassportDataErrors"
);
if let RequestBody::Json(data) = request.into_body() {
let data: Value = serde_json::from_str(&data.unwrap()).unwrap();
assert_eq!(data["user_id"], 1);
assert!(data["errors"].as_array().unwrap().is_empty());
} else {
panic!("Unexpected request body");
}
}
}