xmpp-rs: Test that client builds correctly

Maxime “pep” Buquet created

Signed-off-by: Maxime “pep” Buquet <pep@bouah.net>

Change summary

xmpp-rs/src/lib.rs | 52 ++++++++++++++++++++++++++++++++++++++++++-----
1 file changed, 46 insertions(+), 6 deletions(-)

Detailed changes

xmpp-rs/src/lib.rs 🔗

@@ -167,21 +167,23 @@ impl ClientBuilder<'_> {
         self,
     ) -> Result<(Agent, impl Stream<Item = Event, Error = tokio_xmpp::Error>), JidParseError> {
         let client = TokioXmppClient::new(self.jid, self.password)?;
-        Ok(self.build_impl(client))
+        let (sender_tx, sender_rx) = mpsc::unbounded();
+        Ok(self.build_impl(client, sender_tx, sender_rx)?)
     }
 
     // This function is meant to be used for testing build
     pub(crate) fn build_impl<S>(
         self,
         stream: S,
-    ) -> (Agent, impl Stream<Item = Event, Error = tokio_xmpp::Error>)
+        sender_tx: mpsc::UnboundedSender<Packet>,
+        sender_rx: mpsc::UnboundedReceiver<Packet>,
+    ) -> Result<(Agent, impl Stream<Item = Event, Error = tokio_xmpp::Error>), JidParseError>
     where
         S: Stream<Item = tokio_xmpp::Event, Error = tokio_xmpp::Error>
-            + Sink<SinkItem = tokio_xmpp::Packet, SinkError = tokio_xmpp::Error>,
+        + Sink<SinkItem = tokio_xmpp::Packet, SinkError = tokio_xmpp::Error>,
     {
         let disco = self.make_disco();
         let node = self.website;
-        let (sender_tx, sender_rx) = mpsc::unbounded();
 
         let client = stream;
         let (sink, stream) = client.split();
@@ -322,11 +324,11 @@ impl ClientBuilder<'_> {
             default_nick: Rc::new(RefCell::new(self.default_nick)),
         };
 
-        (agent, future)
+        Ok((agent, future))
     }
 }
 
-#[derive(Clone)]
+#[derive(Clone, Debug)]
 pub struct Agent {
     sender_tx: mpsc::UnboundedSender<Packet>,
     default_nick: Rc<RefCell<String>>,
@@ -360,3 +362,41 @@ impl Agent {
             .unwrap();
     }
 }
+
+#[cfg(test)]
+mod tests {
+    use futures::prelude::*;
+    use tokio_xmpp::Client as TokioXmppClient;
+    use tokio::runtime::current_thread::Runtime;
+    use super::{Agent, ClientBuilder, ClientType, ClientFeature, Event};
+    use futures::sync::mpsc;
+
+    #[test]
+    fn test_simple() {
+        // tokio_core context
+        let mut rt = Runtime::new().unwrap();
+        let client = TokioXmppClient::new("foo@bar", "meh").unwrap();
+        let (sender_tx, sender_rx) = mpsc::unbounded();
+
+        // Client instance
+        let client_builder = ClientBuilder::new("foo@bar", "meh")
+            .set_client(ClientType::Bot, "xmpp-rs")
+            .set_website("https://gitlab.com/xmpp-rs/xmpp-rs")
+            .set_default_nick("bot")
+            .enable_feature(ClientFeature::Avatars)
+            .enable_feature(ClientFeature::ContactList);
+
+        let (_agent, stream): (Agent, _) =
+            client_builder
+            .build_impl(client, sender_tx.clone(), sender_rx)
+            .unwrap();
+
+        let handler = stream.map_err(Some).for_each(|_evt: Event| {
+            return Err(None);
+        });
+
+        rt.block_on(handler).unwrap_or_else(|e| match e {
+            _ => (),
+        });
+    }
+}