|
|
|
@ -9,8 +9,8 @@ use crate::context::Context; |
|
|
|
use crate::control::Request as ControlRequest;
|
|
|
|
use crate::executor::Job;
|
|
|
|
use crate::handlers::{
|
|
|
|
RoomListRequestHandler, RoomMessageRequestHandler, SetPrivilegedUsersHandler,
|
|
|
|
SetRoomListHandler,
|
|
|
|
RoomJoinRequestHandler, RoomJoinResponseHandler, RoomListRequestHandler,
|
|
|
|
RoomMessageRequestHandler, SetPrivilegedUsersHandler, SetRoomListHandler,
|
|
|
|
};
|
|
|
|
use crate::message_handler::MessageHandler;
|
|
|
|
|
|
|
|
@ -75,6 +75,12 @@ impl Dispatcher { |
|
|
|
message: response,
|
|
|
|
handler: SetPrivilegedUsersHandler::default(),
|
|
|
|
})),
|
|
|
|
Message::ServerResponse(ServerResponse::RoomJoinResponse(response)) => {
|
|
|
|
Some(Box::new(DispatchedMessage {
|
|
|
|
message: response,
|
|
|
|
handler: RoomJoinResponseHandler::default(),
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
Message::ServerResponse(ServerResponse::RoomListResponse(response)) => {
|
|
|
|
Some(Box::new(DispatchedMessage {
|
|
|
|
message: response,
|
|
|
|
@ -97,6 +103,12 @@ impl Dispatcher { |
|
|
|
handler: RoomMessageRequestHandler::default(),
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
Message::ControlRequest(ControlRequest::RoomJoinRequest(room_name)) => {
|
|
|
|
Some(Box::new(DispatchedMessage {
|
|
|
|
message: room_name,
|
|
|
|
handler: RoomJoinRequestHandler::default(),
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
Message::ControlRequest(request) => {
|
|
|
|
warn!("Unhandled control request: {:?}", request);
|
|
|
|
None
|
|
|
|
@ -110,7 +122,7 @@ mod tests { |
|
|
|
use crate::control;
|
|
|
|
use crate::dispatcher::Message;
|
|
|
|
|
|
|
|
use solstice_proto::server::{self, ServerResponse};
|
|
|
|
use solstice_proto::server;
|
|
|
|
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
@ -138,6 +150,21 @@ mod tests { |
|
|
|
.is_some());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn dispatches_room_join_response() {
|
|
|
|
assert!(Dispatcher::new()
|
|
|
|
.dispatch(Message::ServerResponse(
|
|
|
|
server::RoomJoinResponse {
|
|
|
|
room_name: "bleep".to_string(),
|
|
|
|
owner: None,
|
|
|
|
operators: Vec::new(),
|
|
|
|
users: Vec::new(),
|
|
|
|
}
|
|
|
|
.into()
|
|
|
|
))
|
|
|
|
.is_some());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn dispatches_room_list_response() {
|
|
|
|
assert!(Dispatcher::new()
|
|
|
|
@ -153,6 +180,15 @@ mod tests { |
|
|
|
.is_some());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn dispatches_room_join_request() {
|
|
|
|
assert!(Dispatcher::new()
|
|
|
|
.dispatch(Message::ControlRequest(
|
|
|
|
control::Request::RoomJoinRequest("bleep".to_string()).into()
|
|
|
|
))
|
|
|
|
.is_some());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn dispatches_room_message_request() {
|
|
|
|
assert!(Dispatcher::new()
|
|
|
|
|