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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
use super::RequestReactionType;
use crate::{
client::Client,
request::Request,
response::{marker::EmptyBody, ResponseFuture},
routing::Route,
};
use twilight_model::id::{ChannelId, MessageId};
#[must_use = "requests must be configured and executed"]
pub struct CreateReaction<'a> {
channel_id: ChannelId,
emoji: &'a RequestReactionType<'a>,
http: &'a Client,
message_id: MessageId,
}
impl<'a> CreateReaction<'a> {
pub(crate) const fn new(
http: &'a Client,
channel_id: ChannelId,
message_id: MessageId,
emoji: &'a RequestReactionType<'a>,
) -> Self {
Self {
channel_id,
emoji,
http,
message_id,
}
}
fn request(&self) -> Request {
Request::from_route(&Route::CreateReaction {
channel_id: self.channel_id.get(),
emoji: self.emoji,
message_id: self.message_id.get(),
})
}
pub fn exec(self) -> ResponseFuture<EmptyBody> {
self.http.request(self.request())
}
}
#[cfg(test)]
mod tests {
#![allow(clippy::non_ascii_literal)]
use super::CreateReaction;
use crate::{
request::{channel::reaction::RequestReactionType, Request},
routing::Route,
Client,
};
use twilight_model::id::{ChannelId, MessageId};
#[test]
fn test_request() {
let client = Client::new("foo".to_owned());
let emoji = RequestReactionType::Unicode { name: "🌃" };
let builder = CreateReaction::new(
&client,
ChannelId::new(123).expect("non zero"),
MessageId::new(456).expect("non zero"),
&emoji,
);
let actual = builder.request();
let expected = Request::from_route(&Route::CreateReaction {
channel_id: 123,
emoji: &RequestReactionType::Unicode { name: "🌃" },
message_id: 456,
});
assert_eq!(actual.path, expected.path);
}
}