Detailed changes
@@ -170,11 +170,14 @@ mod tests {
//assert_eq!(bind.resource.unwrap(), "HelloTM");
assert_eq!(bind.resource.unwrap(), "Helloβ’");
- let elem: Element = "<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'><jid>coucou@linkmauve.fr/HelloTM</jid></bind>"
+ let elem: Element = "<bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'><jid>coucou@linkmauve.fr/Helloβ’</jid></bind>"
.parse()
.unwrap();
let bind = BindResponse::try_from(elem).unwrap();
- assert_eq!(bind.jid, FullJid::new("coucou", "linkmauve.fr", "HelloTM"));
+ assert_eq!(
+ bind.jid,
+ FullJid::new("coucou@linkmauve.fr/HelloTM").unwrap()
+ );
}
#[cfg(not(feature = "disable-validation"))]
@@ -98,7 +98,6 @@ generate_empty_element!(
#[cfg(test)]
mod tests {
use super::*;
- use jid::BareJid;
#[cfg(target_pointer_width = "32")]
#[test]
@@ -141,14 +140,8 @@ mod tests {
fn test_items() {
let elem: Element = "<blocklist xmlns='urn:xmpp:blocking'><item jid='coucou@coucou'/><item jid='domain'/></blocklist>".parse().unwrap();
let two_items = vec![
- Jid::Bare(BareJid {
- node: Some(String::from("coucou")),
- domain: String::from("coucou"),
- }),
- Jid::Bare(BareJid {
- node: None,
- domain: String::from("domain"),
- }),
+ Jid::new("coucou@coucou").unwrap(),
+ Jid::new("domain").unwrap(),
];
let result_elem = elem.clone();
@@ -112,7 +112,7 @@ mod tests {
assert_eq!(storage.conferences[0].autojoin, Autojoin::True);
assert_eq!(
storage.conferences[0].jid,
- BareJid::new("test-muc", "muc.localhost")
+ BareJid::new("test-muc@muc.localhost").unwrap()
);
assert_eq!(storage.conferences[0].clone().name.unwrap(), "Test MUC");
assert_eq!(storage.conferences[0].clone().nick.unwrap(), "Coucou");
@@ -57,7 +57,7 @@ mod tests {
.parse()
.unwrap();
let delay = Delay::try_from(elem).unwrap();
- assert_eq!(delay.from.unwrap(), BareJid::domain("capulet.com"));
+ assert_eq!(delay.from.unwrap(), BareJid::new("capulet.com").unwrap());
assert_eq!(
delay.stamp,
DateTime::from_str("2002-09-10T23:08:25Z").unwrap()
@@ -109,7 +109,7 @@ mod tests {
fn test_serialise_data() {
let elem: Element = "<delay xmlns='urn:xmpp:delay' from='juliet@example.org' stamp='2002-09-10T23:08:25+00:00'>Reason</delay>".parse().unwrap();
let delay = Delay {
- from: Some(Jid::Bare(BareJid::new("juliet", "example.org"))),
+ from: Some(Jid::new("juliet@example.org").unwrap()),
stamp: DateTime::from_str("2002-09-10T23:08:25Z").unwrap(),
data: Some(String::from("Reason")),
};
@@ -445,10 +445,10 @@ mod tests {
let elem2 = Element::from(query);
let query = DiscoItemsResult::try_from(elem2).unwrap();
assert_eq!(query.items.len(), 2);
- assert_eq!(query.items[0].jid, BareJid::domain("component"));
+ assert_eq!(query.items[0].jid, BareJid::new("component").unwrap());
assert_eq!(query.items[0].node, None);
assert_eq!(query.items[0].name, None);
- assert_eq!(query.items[1].jid, BareJid::domain("component2"));
+ assert_eq!(query.items[1].jid, BareJid::new("component2").unwrap());
assert_eq!(query.items[1].node, Some(String::from("test")));
assert_eq!(query.items[1].name, Some(String::from("A component")));
}
@@ -75,7 +75,7 @@ mod tests {
let response = JidPrepResponse::try_from(elem).unwrap();
assert_eq!(
response.jid,
- FullJid::new("romeo", "montague.lit", "orchard")
+ FullJid::new("romeo@montague.lit/orchard").unwrap()
);
}
}
@@ -276,7 +276,6 @@ impl From<Transport> for Element {
#[cfg(test)]
mod tests {
use super::*;
- use jid::BareJid;
use std::str::FromStr;
#[cfg(target_pointer_width = "32")]
@@ -344,7 +343,7 @@ mod tests {
payload: TransportPayload::Candidates(vec![Candidate {
cid: CandidateId(String::from("coucou")),
host: IpAddr::from_str("127.0.0.1").unwrap(),
- jid: Jid::Bare(BareJid::new("coucou", "coucou")),
+ jid: Jid::new("coucou@coucou").unwrap(),
port: None,
priority: 0u32,
type_: Type::Direct,
@@ -24,7 +24,7 @@
#![warn(missing_docs)]
pub use crate::util::error::Error;
-pub use jid::{BareJid, FullJid, Jid, JidParseError};
+pub use jid::{BareJid, Error as JidParseError, FullJid, Jid};
pub use minidom::Element;
/// XML namespace definitions used through XMPP.
@@ -88,7 +88,7 @@ fn serialise_jid_list(name: &str, jids: Vec<Jid>) -> ::std::option::IntoIter<Nod
Element::builder(name, ns::MAM)
.append_all(
jids.into_iter()
- .map(|jid| Element::builder("jid", ns::MAM).append(String::from(jid))),
+ .map(|jid| Element::builder("jid", ns::MAM).append(jid)),
)
.into(),
)
@@ -160,8 +160,11 @@ mod tests {
.parse()
.unwrap();
let prefs = Prefs::try_from(elem).unwrap();
- assert_eq!(prefs.always, [BareJid::new("romeo", "montague.lit")]);
- assert_eq!(prefs.never, [BareJid::new("montague", "montague.lit")]);
+ assert_eq!(prefs.always, [BareJid::new("romeo@montague.lit").unwrap()]);
+ assert_eq!(
+ prefs.never,
+ [BareJid::new("montague@montague.lit").unwrap()]
+ );
let elem2 = Element::from(prefs.clone());
println!("{:?}", elem2);
@@ -299,7 +299,6 @@ impl From<Message> for Element {
#[cfg(test)]
mod tests {
use super::*;
- use jid::BareJid;
use std::str::FromStr;
#[cfg(target_pointer_width = "32")]
@@ -378,7 +377,7 @@ mod tests {
let elem: Element = "<message xmlns='jabber:client' to='coucou@example.org' type='chat'><body>Hello world!</body></message>".parse().unwrap();
#[cfg(feature = "component")]
let elem: Element = "<message xmlns='jabber:component:accept' to='coucou@example.org' type='chat'><body>Hello world!</body></message>".parse().unwrap();
- let mut message = Message::new(Jid::Bare(BareJid::new("coucou", "example.org")));
+ let mut message = Message::new(Jid::new("coucou@example.org").unwrap());
message
.bodies
.insert(String::from(""), Body::from_str("Hello world!").unwrap());
@@ -301,7 +301,7 @@ mod tests {
use super::*;
use crate::message::Message;
use crate::presence::{Presence, Type as PresenceType};
- use crate::{BareJid, Jid};
+ use crate::Jid;
#[test]
fn test_simple() {
@@ -743,7 +743,7 @@ mod tests {
#[test]
fn message_payload() {
- let jid: Jid = Jid::Bare(BareJid::new("louise", "example.com"));
+ let jid: Jid = Jid::new("louise@example.com").unwrap();
let elem: Element = "<x xmlns='http://jabber.org/protocol/muc#user'/>"
.parse()
.unwrap();
@@ -672,24 +672,21 @@ mod tests {
let elem: Element = presence.into();
assert_eq!(elem.attr("to"), None);
- let presence = Presence::new(Type::None).with_to(Jid::Bare(BareJid::domain("localhost")));
+ let presence = Presence::new(Type::None).with_to(Jid::new("localhost").unwrap());
let elem: Element = presence.into();
assert_eq!(elem.attr("to"), Some("localhost"));
- let presence = Presence::new(Type::None).with_to(BareJid::domain("localhost"));
+ let presence = Presence::new(Type::None).with_to(BareJid::new("localhost").unwrap());
let elem: Element = presence.into();
assert_eq!(elem.attr("to"), Some("localhost"));
- let presence = Presence::new(Type::None).with_to(Jid::Full(FullJid::new(
- "test",
- "localhost",
- "coucou",
- )));
+ let presence =
+ Presence::new(Type::None).with_to(Jid::new("test@localhost/coucou").unwrap());
let elem: Element = presence.into();
assert_eq!(elem.attr("to"), Some("test@localhost/coucou"));
let presence =
- Presence::new(Type::None).with_to(FullJid::new("test", "localhost", "coucou"));
+ Presence::new(Type::None).with_to(FullJid::new("test@localhost/coucou").unwrap());
let elem: Element = presence.into();
assert_eq!(elem.attr("to"), Some("test@localhost/coucou"));
}
@@ -273,7 +273,7 @@ mod tests {
assert_eq!(items[0].id, Some(ItemId(String::from("test"))));
assert_eq!(
items[0].publisher.clone().unwrap(),
- BareJid::new("test", "coucou")
+ BareJid::new("test@coucou").unwrap()
);
assert_eq!(items[0].payload, None);
}
@@ -404,7 +404,7 @@ mod tests {
)))
);
assert_eq!(subscription, Some(Subscription::Subscribed));
- assert_eq!(jid.unwrap(), BareJid::new("francisco", "denmark.lit"));
+ assert_eq!(jid.unwrap(), BareJid::new("francisco@denmark.lit").unwrap());
assert_eq!(expiry, Some("2006-02-28T23:59:59Z".parse().unwrap()));
}
_ => panic!(),
@@ -546,7 +546,6 @@ impl From<PubSub> for Element {
mod tests {
use super::*;
use crate::data_forms::{DataForm, DataFormType, Field, FieldType};
- use jid::FullJid;
#[test]
fn create() {
@@ -746,7 +745,7 @@ mod tests {
let form = DataForm::try_from(elem).unwrap();
let options = Options {
- jid: Jid::Full(FullJid::new("juliet", "capulet.lit", "balcony")),
+ jid: Jid::new("juliet@capulet.lit/balcony").unwrap(),
node: None,
subid: None,
form: Some(form),
@@ -167,7 +167,10 @@ mod tests {
let roster = Roster::try_from(elem).unwrap();
assert_eq!(roster.ver, Some(String::from("ver11")));
assert_eq!(roster.items.len(), 4);
- assert_eq!(roster.items[0].jid, BareJid::new("romeo", "example.net"));
+ assert_eq!(
+ roster.items[0].jid,
+ BareJid::new("romeo@example.net").unwrap()
+ );
assert_eq!(roster.items[0].name, Some(String::from("Romeo")));
assert_eq!(roster.items[0].subscription, Subscription::Both);
assert_eq!(roster.items[0].ask, Ask::None);
@@ -176,7 +179,10 @@ mod tests {
vec!(Group::from_str("Friends").unwrap())
);
- assert_eq!(roster.items[3].jid, BareJid::new("contact", "example.org"));
+ assert_eq!(
+ roster.items[3].jid,
+ BareJid::new("contact@example.org").unwrap()
+ );
assert_eq!(roster.items[3].name, Some(String::from("MyContact")));
assert_eq!(roster.items[3].subscription, Subscription::None);
assert_eq!(roster.items[3].ask, Ask::Subscribe);
@@ -195,7 +201,10 @@ mod tests {
let roster = Roster::try_from(elem).unwrap();
assert!(roster.ver.is_none());
assert_eq!(roster.items.len(), 1);
- assert_eq!(roster.items[0].jid, BareJid::new("test", "example.org"));
+ assert_eq!(
+ roster.items[0].jid,
+ BareJid::new("test@example.org").unwrap()
+ );
assert_eq!(roster.items[0].name, None);
assert_eq!(roster.items[0].groups.len(), 2);
assert_eq!(roster.items[0].groups[0], Group::from_str("A").unwrap());
@@ -225,7 +234,10 @@ mod tests {
let roster = Roster::try_from(elem).unwrap();
assert!(roster.ver.is_none());
assert_eq!(roster.items.len(), 1);
- assert_eq!(roster.items[0].jid, BareJid::new("nurse", "example.com"));
+ assert_eq!(
+ roster.items[0].jid,
+ BareJid::new("nurse@example.com").unwrap()
+ );
assert_eq!(roster.items[0].name, Some(String::from("Nurse")));
assert_eq!(roster.items[0].groups.len(), 1);
assert_eq!(
@@ -242,7 +254,10 @@ mod tests {
let roster = Roster::try_from(elem).unwrap();
assert!(roster.ver.is_none());
assert_eq!(roster.items.len(), 1);
- assert_eq!(roster.items[0].jid, BareJid::new("nurse", "example.com"));
+ assert_eq!(
+ roster.items[0].jid,
+ BareJid::new("nurse@example.com").unwrap()
+ );
assert!(roster.items[0].name.is_none());
assert!(roster.items[0].groups.is_empty());
assert_eq!(roster.items[0].subscription, Subscription::Remove);
@@ -66,7 +66,7 @@ mod tests {
.unwrap();
let stanza_id = StanzaId::try_from(elem).unwrap();
assert_eq!(stanza_id.id, String::from("coucou"));
- assert_eq!(stanza_id.by, BareJid::new("coucou", "coucou"));
+ assert_eq!(stanza_id.by, BareJid::new("coucou@coucou").unwrap());
let elem: Element = "<origin-id xmlns='urn:xmpp:sid:0' id='coucou'/>"
.parse()
@@ -119,7 +119,7 @@ mod tests {
.unwrap();
let stanza_id = StanzaId {
id: String::from("coucou"),
- by: Jid::Bare(BareJid::new("coucou", "coucou")),
+ by: Jid::new("coucou@coucou").unwrap(),
};
let elem2 = stanza_id.into();
assert_eq!(elem, elem2);
@@ -92,7 +92,10 @@ mod tests {
fn test_simple() {
let elem: Element = "<stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' xml:lang='en' version='1.0' id='abc' from='some-server.example'/>".parse().unwrap();
let stream = Stream::try_from(elem).unwrap();
- assert_eq!(stream.from, Some(BareJid::domain("some-server.example")));
+ assert_eq!(
+ stream.from,
+ Some(BareJid::new("some-server.example").unwrap())
+ );
assert_eq!(stream.to, None);
assert_eq!(stream.id, Some(String::from("abc")));
assert_eq!(stream.version, Some(String::from("1.0")));
@@ -33,7 +33,7 @@ pub enum Error {
/// Generated when text which should be a [JID](../../jid/struct.Jid.html)
/// fails to parse.
- JidParseError(jid::JidParseError),
+ JidParseError(jid::Error),
/// Generated when text which should be a
/// [DateTime](../date/struct.DateTime.html) fails to parse.
@@ -92,8 +92,8 @@ impl From<std::net::AddrParseError> for Error {
}
}
-impl From<jid::JidParseError> for Error {
- fn from(err: jid::JidParseError) -> Error {
+impl From<jid::Error> for Error {
+ fn from(err: jid::Error) -> Error {
Error::JidParseError(err)
}
}