xmpp-rs-mirror/src/stanza_id.rs

125 lines
3.7 KiB
Rust
Raw Normal View History

2017-04-29 21:14:34 +00:00
// Copyright (c) 2017 Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
use crate::message::MessagePayload;
2017-04-29 02:23:50 +00:00
use jid::Jid;
2018-07-31 22:16:59 +00:00
generate_element!(
/// Gives the identifier a service has stamped on this stanza, often in
/// order to identify it inside of [an archive](../mam/index.html).
StanzaId, "stanza-id", SID,
attributes: [
/// The id associated to this stanza by another entity.
id: String = "id" => required,
/// The entity who stamped this stanza-id.
by: Jid = "by" => required,
]
);
impl MessagePayload for StanzaId {}
2018-07-31 22:16:59 +00:00
generate_element!(
/// A hack for MUC before version 1.31 to track a message which may have
/// its 'id' attribute changed.
OriginId, "origin-id", SID,
attributes: [
/// The id this client set for this stanza.
id: String = "id" => required,
]
);
2017-04-29 02:23:50 +00:00
impl MessagePayload for OriginId {}
2017-04-29 02:23:50 +00:00
#[cfg(test)]
mod tests {
2017-05-06 19:10:35 +00:00
use super::*;
use crate::error::Error;
2018-12-18 14:32:05 +00:00
use minidom::Element;
2017-04-29 02:23:50 +00:00
use std::str::FromStr;
2018-12-18 14:32:05 +00:00
use try_from::TryFrom;
2017-04-29 02:23:50 +00:00
2018-10-28 12:10:48 +00:00
#[cfg(target_pointer_width = "32")]
#[test]
fn test_size() {
assert_size!(StanzaId, 48);
assert_size!(OriginId, 12);
}
#[cfg(target_pointer_width = "64")]
#[test]
fn test_size() {
assert_size!(StanzaId, 96);
assert_size!(OriginId, 24);
}
2017-04-29 02:23:50 +00:00
#[test]
fn test_simple() {
2018-12-18 14:32:05 +00:00
let elem: Element = "<stanza-id xmlns='urn:xmpp:sid:0' id='coucou' by='coucou@coucou'/>"
.parse()
.unwrap();
let stanza_id = StanzaId::try_from(elem).unwrap();
assert_eq!(stanza_id.id, String::from("coucou"));
assert_eq!(stanza_id.by, Jid::from_str("coucou@coucou").unwrap());
2017-04-29 02:23:50 +00:00
2018-12-18 14:32:05 +00:00
let elem: Element = "<origin-id xmlns='urn:xmpp:sid:0' id='coucou'/>"
.parse()
.unwrap();
let origin_id = OriginId::try_from(elem).unwrap();
assert_eq!(origin_id.id, String::from("coucou"));
2017-04-29 02:23:50 +00:00
}
#[test]
fn test_invalid_child() {
2018-12-18 14:32:05 +00:00
let elem: Element = "<stanza-id xmlns='urn:xmpp:sid:0'><coucou/></stanza-id>"
.parse()
.unwrap();
let error = StanzaId::try_from(elem).unwrap_err();
2017-04-29 02:23:50 +00:00
let message = match error {
Error::ParseError(string) => string,
_ => panic!(),
};
assert_eq!(message, "Unknown child in stanza-id element.");
2017-04-29 02:23:50 +00:00
}
#[test]
fn test_invalid_id() {
let elem: Element = "<stanza-id xmlns='urn:xmpp:sid:0'/>".parse().unwrap();
let error = StanzaId::try_from(elem).unwrap_err();
2017-04-29 02:23:50 +00:00
let message = match error {
Error::ParseError(string) => string,
_ => panic!(),
};
assert_eq!(message, "Required attribute 'id' missing.");
2017-04-29 02:23:50 +00:00
}
#[test]
fn test_invalid_by() {
2018-12-18 14:32:05 +00:00
let elem: Element = "<stanza-id xmlns='urn:xmpp:sid:0' id='coucou'/>"
.parse()
.unwrap();
let error = StanzaId::try_from(elem).unwrap_err();
2017-04-29 02:23:50 +00:00
let message = match error {
Error::ParseError(string) => string,
_ => panic!(),
};
assert_eq!(message, "Required attribute 'by' missing.");
2017-04-29 02:23:50 +00:00
}
#[test]
fn test_serialise() {
2018-12-18 14:32:05 +00:00
let elem: Element = "<stanza-id xmlns='urn:xmpp:sid:0' id='coucou' by='coucou@coucou'/>"
.parse()
.unwrap();
let stanza_id = StanzaId {
id: String::from("coucou"),
by: Jid::from_str("coucou@coucou").unwrap(),
};
let elem2 = stanza_id.into();
2017-04-29 02:23:50 +00:00
assert_eq!(elem, elem2);
}
}