mirror of
https://github.com/sile/hls_m3u8.git
synced 2025-01-11 04:35:24 +00:00
improve documentation and tests of ExtXSessionData
This commit is contained in:
parent
8948f9914b
commit
a8c788f4d2
1 changed files with 142 additions and 170 deletions
|
@ -9,29 +9,26 @@ use crate::types::ProtocolVersion;
|
||||||
use crate::utils::{quote, tag, unquote};
|
use crate::utils::{quote, tag, unquote};
|
||||||
use crate::{Error, RequiredVersion};
|
use crate::{Error, RequiredVersion};
|
||||||
|
|
||||||
/// The data of an [`ExtXSessionData`] tag.
|
/// The data of [`ExtXSessionData`].
|
||||||
#[derive(Hash, Eq, Ord, Debug, PartialEq, Clone, PartialOrd)]
|
#[derive(Hash, Eq, Ord, Debug, PartialEq, Clone, PartialOrd)]
|
||||||
pub enum SessionData {
|
pub enum SessionData {
|
||||||
/// A String, that contains the data identified by
|
/// This variant contains the data identified by the
|
||||||
/// [`data_id`](ExtXSessionData::data_id).
|
/// [`ExtXSessionData::data_id`].
|
||||||
/// If a [`language`] is specified, the value
|
///
|
||||||
/// should contain a human-readable string written in the specified
|
/// If a [`language`] is specified, this variant should contain a
|
||||||
/// language.
|
/// human-readable string written in the specified language.
|
||||||
///
|
///
|
||||||
/// [`data_id`]: ExtXSessionData::data_id
|
/// [`data_id`]: ExtXSessionData::data_id
|
||||||
/// [`language`]: ExtXSessionData::language
|
/// [`language`]: ExtXSessionData::language
|
||||||
Value(String),
|
Value(String),
|
||||||
/// An [`uri`], which points to a [`json`].
|
/// An [`URI`], which points to a [`json`] file.
|
||||||
///
|
///
|
||||||
/// [`json`]: https://tools.ietf.org/html/rfc8259
|
/// [`json`]: https://tools.ietf.org/html/rfc8259
|
||||||
/// [`uri`]: https://tools.ietf.org/html/rfc3986
|
/// [`URI`]: https://tools.ietf.org/html/rfc3986
|
||||||
Uri(String),
|
Uri(String),
|
||||||
}
|
}
|
||||||
|
|
||||||
/// # [4.3.4.4. EXT-X-SESSION-DATA]
|
/// Allows arbitrary session data to be carried in a [`MasterPlaylist`].
|
||||||
///
|
|
||||||
/// The [`ExtXSessionData`] tag allows arbitrary session data to be
|
|
||||||
/// carried in a [`MasterPlaylist`].
|
|
||||||
///
|
///
|
||||||
/// [`MasterPlaylist`]: crate::MasterPlaylist
|
/// [`MasterPlaylist`]: crate::MasterPlaylist
|
||||||
/// [4.3.4.4. EXT-X-SESSION-DATA]: https://tools.ietf.org/html/rfc8216#section-4.3.4.4
|
/// [4.3.4.4. EXT-X-SESSION-DATA]: https://tools.ietf.org/html/rfc8216#section-4.3.4.4
|
||||||
|
@ -39,8 +36,27 @@ pub enum SessionData {
|
||||||
#[builder(setter(into))]
|
#[builder(setter(into))]
|
||||||
#[shorthand(enable(must_use, into))]
|
#[shorthand(enable(must_use, into))]
|
||||||
pub struct ExtXSessionData {
|
pub struct ExtXSessionData {
|
||||||
/// Sets the `data_id` attribute, that should conform to a [reverse DNS]
|
/// This should conform to a [reverse DNS] naming convention, such as
|
||||||
/// naming convention, such as `com.example.movie.title`.
|
/// `com.example.movie.title`.
|
||||||
|
///
|
||||||
|
/// # Example
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
/// # use hls_m3u8::tags::ExtXSessionData;
|
||||||
|
/// use hls_m3u8::tags::SessionData;
|
||||||
|
///
|
||||||
|
/// let mut session_data = ExtXSessionData::new(
|
||||||
|
/// "com.example.movie.title",
|
||||||
|
/// SessionData::Uri("https://www.example.com/".to_string()),
|
||||||
|
/// );
|
||||||
|
///
|
||||||
|
/// session_data.set_data_id("com.ironrust.movie.title");
|
||||||
|
///
|
||||||
|
/// assert_eq!(
|
||||||
|
/// session_data.data_id(),
|
||||||
|
/// &"com.ironrust.movie.title".to_string()
|
||||||
|
/// );
|
||||||
|
/// ```
|
||||||
///
|
///
|
||||||
/// # Note
|
/// # Note
|
||||||
///
|
///
|
||||||
|
@ -51,15 +67,59 @@ pub struct ExtXSessionData {
|
||||||
///
|
///
|
||||||
/// [reverse DNS]: https://en.wikipedia.org/wiki/Reverse_domain_name_notation
|
/// [reverse DNS]: https://en.wikipedia.org/wiki/Reverse_domain_name_notation
|
||||||
data_id: String,
|
data_id: String,
|
||||||
/// The data associated with the [`data_id`](ExtXSessionData::data_id).
|
/// The [`SessionData`] associated with the
|
||||||
/// For more information look [`here`](SessionData).
|
/// [`data_id`](ExtXSessionData::data_id).
|
||||||
|
///
|
||||||
|
/// # Example
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
/// # use hls_m3u8::tags::ExtXSessionData;
|
||||||
|
/// use hls_m3u8::tags::SessionData;
|
||||||
|
///
|
||||||
|
/// let mut session_data = ExtXSessionData::new(
|
||||||
|
/// "com.example.movie.title",
|
||||||
|
/// SessionData::Uri("https://www.example.com/".to_string()),
|
||||||
|
/// );
|
||||||
|
///
|
||||||
|
/// session_data.set_data(SessionData::Uri(
|
||||||
|
/// "https://www.example.com/data.json".to_string(),
|
||||||
|
/// ));
|
||||||
|
///
|
||||||
|
/// assert_eq!(
|
||||||
|
/// session_data.data(),
|
||||||
|
/// &SessionData::Uri("https://www.example.com/data.json".to_string())
|
||||||
|
/// );
|
||||||
|
/// ```
|
||||||
///
|
///
|
||||||
/// # Note
|
/// # Note
|
||||||
///
|
///
|
||||||
/// This field is required.
|
/// This field is required.
|
||||||
|
#[shorthand(disable(into))]
|
||||||
data: SessionData,
|
data: SessionData,
|
||||||
/// The `language` attribute identifies the language of the [`SessionData`].
|
/// The `language` attribute identifies the language of the [`SessionData`].
|
||||||
/// See [rfc5646](https://tools.ietf.org/html/rfc5646).
|
///
|
||||||
|
/// # Example
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
/// # use hls_m3u8::tags::ExtXSessionData;
|
||||||
|
/// use hls_m3u8::tags::SessionData;
|
||||||
|
///
|
||||||
|
/// let mut session_data = ExtXSessionData::new(
|
||||||
|
/// "com.example.movie.title",
|
||||||
|
/// SessionData::Uri("https://www.example.com/".to_string()),
|
||||||
|
/// );
|
||||||
|
///
|
||||||
|
/// session_data.set_language(Some("en"));
|
||||||
|
///
|
||||||
|
/// assert_eq!(session_data.language(), Some(&"en".to_string()));
|
||||||
|
/// ```
|
||||||
|
///
|
||||||
|
/// # Note
|
||||||
|
///
|
||||||
|
/// This field is optional and the provided value should conform to
|
||||||
|
/// [RFC5646].
|
||||||
|
///
|
||||||
|
/// [RFC5646]: https://tools.ietf.org/html/rfc5646
|
||||||
#[builder(setter(into, strip_option), default)]
|
#[builder(setter(into, strip_option), default)]
|
||||||
language: Option<String>,
|
language: Option<String>,
|
||||||
}
|
}
|
||||||
|
@ -72,7 +132,8 @@ impl ExtXSessionData {
|
||||||
/// # Example
|
/// # Example
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
/// use hls_m3u8::tags::{ExtXSessionData, SessionData};
|
/// # use hls_m3u8::tags::ExtXSessionData;
|
||||||
|
/// use hls_m3u8::tags::SessionData;
|
||||||
///
|
///
|
||||||
/// ExtXSessionData::new(
|
/// ExtXSessionData::new(
|
||||||
/// "com.example.movie.title",
|
/// "com.example.movie.title",
|
||||||
|
@ -87,28 +148,20 @@ impl ExtXSessionData {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns a new Builder for [`ExtXSessionData`].
|
/// Returns a builder for [`ExtXSessionData`].
|
||||||
///
|
///
|
||||||
/// # Example
|
/// # Example
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
/// use hls_m3u8::tags::{ExtXSessionData, SessionData};
|
/// # use hls_m3u8::tags::ExtXSessionData;
|
||||||
|
/// use hls_m3u8::tags::SessionData;
|
||||||
///
|
///
|
||||||
/// let session_data = ExtXSessionData::builder()
|
/// let session_data = ExtXSessionData::builder()
|
||||||
/// .data_id("com.example.movie.title")
|
/// .data_id("com.example.movie.title")
|
||||||
/// .data(SessionData::Value("some data".to_string()))
|
/// .data(SessionData::Value("some data".to_string()))
|
||||||
/// .language("english")
|
/// .language("en")
|
||||||
/// .build()
|
/// .build()?;
|
||||||
/// .expect("Failed to build an ExtXSessionData tag.");
|
/// # Ok::<(), Box<dyn ::std::error::Error>>(())
|
||||||
///
|
|
||||||
/// assert_eq!(
|
|
||||||
/// session_data,
|
|
||||||
/// ExtXSessionData::with_language(
|
|
||||||
/// "com.example.movie.title",
|
|
||||||
/// SessionData::Value("some data".to_string()),
|
|
||||||
/// "english"
|
|
||||||
/// )
|
|
||||||
/// );
|
|
||||||
/// ```
|
/// ```
|
||||||
pub fn builder() -> ExtXSessionDataBuilder { ExtXSessionDataBuilder::default() }
|
pub fn builder() -> ExtXSessionDataBuilder { ExtXSessionDataBuilder::default() }
|
||||||
|
|
||||||
|
@ -117,12 +170,13 @@ impl ExtXSessionData {
|
||||||
/// # Example
|
/// # Example
|
||||||
///
|
///
|
||||||
/// ```
|
/// ```
|
||||||
/// use hls_m3u8::tags::{ExtXSessionData, SessionData};
|
/// # use hls_m3u8::tags::ExtXSessionData;
|
||||||
|
/// use hls_m3u8::tags::SessionData;
|
||||||
///
|
///
|
||||||
/// let session_data = ExtXSessionData::with_language(
|
/// let session_data = ExtXSessionData::with_language(
|
||||||
/// "com.example.movie.title",
|
/// "com.example.movie.title",
|
||||||
/// SessionData::Value("some data".to_string()),
|
/// SessionData::Value("some data".to_string()),
|
||||||
/// "english",
|
/// "en",
|
||||||
/// );
|
/// );
|
||||||
/// ```
|
/// ```
|
||||||
pub fn with_language<T, K>(data_id: T, data: SessionData, language: K) -> Self
|
pub fn with_language<T, K>(data_id: T, data: SessionData, language: K) -> Self
|
||||||
|
@ -214,145 +268,20 @@ mod test {
|
||||||
use super::*;
|
use super::*;
|
||||||
use pretty_assertions::assert_eq;
|
use pretty_assertions::assert_eq;
|
||||||
|
|
||||||
|
macro_rules! generate_tests {
|
||||||
|
( $( { $struct:expr, $str:expr } ),+ $(,)* ) => {
|
||||||
#[test]
|
#[test]
|
||||||
fn test_display() {
|
fn test_display() {
|
||||||
assert_eq!(
|
$(
|
||||||
"#EXT-X-SESSION-DATA:\
|
assert_eq!($struct.to_string(), $str.to_string());
|
||||||
DATA-ID=\"com.example.lyrics\",\
|
)+
|
||||||
URI=\"lyrics.json\""
|
|
||||||
.to_string(),
|
|
||||||
ExtXSessionData::new(
|
|
||||||
"com.example.lyrics",
|
|
||||||
SessionData::Uri("lyrics.json".to_string())
|
|
||||||
)
|
|
||||||
.to_string()
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
"#EXT-X-SESSION-DATA:\
|
|
||||||
DATA-ID=\"com.example.title\",\
|
|
||||||
VALUE=\"This is an example\",\
|
|
||||||
LANGUAGE=\"en\""
|
|
||||||
.to_string(),
|
|
||||||
ExtXSessionData::with_language(
|
|
||||||
"com.example.title",
|
|
||||||
SessionData::Value("This is an example".to_string()),
|
|
||||||
"en"
|
|
||||||
)
|
|
||||||
.to_string()
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
"#EXT-X-SESSION-DATA:\
|
|
||||||
DATA-ID=\"com.example.title\",\
|
|
||||||
VALUE=\"Este es un ejemplo\",\
|
|
||||||
LANGUAGE=\"es\""
|
|
||||||
.to_string(),
|
|
||||||
ExtXSessionData::with_language(
|
|
||||||
"com.example.title",
|
|
||||||
SessionData::Value("Este es un ejemplo".to_string()),
|
|
||||||
"es"
|
|
||||||
)
|
|
||||||
.to_string()
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
"#EXT-X-SESSION-DATA:\
|
|
||||||
DATA-ID=\"foo\",\
|
|
||||||
VALUE=\"bar\""
|
|
||||||
.to_string(),
|
|
||||||
ExtXSessionData::new("foo", SessionData::Value("bar".into())).to_string()
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
"#EXT-X-SESSION-DATA:\
|
|
||||||
DATA-ID=\"foo\",\
|
|
||||||
URI=\"bar\""
|
|
||||||
.to_string(),
|
|
||||||
ExtXSessionData::new("foo", SessionData::Uri("bar".into())).to_string()
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
"#EXT-X-SESSION-DATA:\
|
|
||||||
DATA-ID=\"foo\",\
|
|
||||||
VALUE=\"bar\",\
|
|
||||||
LANGUAGE=\"baz\""
|
|
||||||
.to_string(),
|
|
||||||
ExtXSessionData::with_language("foo", SessionData::Value("bar".into()), "baz")
|
|
||||||
.to_string()
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_parser() {
|
fn test_parser() {
|
||||||
assert_eq!(
|
$(
|
||||||
"#EXT-X-SESSION-DATA:\
|
assert_eq!($struct, $str.parse().unwrap());
|
||||||
DATA-ID=\"com.example.lyrics\",\
|
)+
|
||||||
URI=\"lyrics.json\""
|
|
||||||
.parse::<ExtXSessionData>()
|
|
||||||
.unwrap(),
|
|
||||||
ExtXSessionData::new(
|
|
||||||
"com.example.lyrics",
|
|
||||||
SessionData::Uri("lyrics.json".to_string())
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
"#EXT-X-SESSION-DATA:\
|
|
||||||
DATA-ID=\"com.example.title\",\
|
|
||||||
LANGUAGE=\"en\",\
|
|
||||||
VALUE=\"This is an example\""
|
|
||||||
.parse::<ExtXSessionData>()
|
|
||||||
.unwrap(),
|
|
||||||
ExtXSessionData::with_language(
|
|
||||||
"com.example.title",
|
|
||||||
SessionData::Value("This is an example".to_string()),
|
|
||||||
"en"
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
"#EXT-X-SESSION-DATA:\
|
|
||||||
DATA-ID=\"com.example.title\",\
|
|
||||||
LANGUAGE=\"es\",\
|
|
||||||
VALUE=\"Este es un ejemplo\""
|
|
||||||
.parse::<ExtXSessionData>()
|
|
||||||
.unwrap(),
|
|
||||||
ExtXSessionData::with_language(
|
|
||||||
"com.example.title",
|
|
||||||
SessionData::Value("Este es un ejemplo".to_string()),
|
|
||||||
"es"
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
"#EXT-X-SESSION-DATA:\
|
|
||||||
DATA-ID=\"foo\",\
|
|
||||||
VALUE=\"bar\""
|
|
||||||
.parse::<ExtXSessionData>()
|
|
||||||
.unwrap(),
|
|
||||||
ExtXSessionData::new("foo", SessionData::Value("bar".into()))
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
"#EXT-X-SESSION-DATA:\
|
|
||||||
DATA-ID=\"foo\",\
|
|
||||||
URI=\"bar\""
|
|
||||||
.parse::<ExtXSessionData>()
|
|
||||||
.unwrap(),
|
|
||||||
ExtXSessionData::new("foo", SessionData::Uri("bar".into()))
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(
|
|
||||||
"#EXT-X-SESSION-DATA:\
|
|
||||||
DATA-ID=\"foo\",\
|
|
||||||
VALUE=\"bar\",\
|
|
||||||
LANGUAGE=\"baz\",\
|
|
||||||
UNKNOWN=TAG"
|
|
||||||
.parse::<ExtXSessionData>()
|
|
||||||
.unwrap(),
|
|
||||||
ExtXSessionData::with_language("foo", SessionData::Value("bar".into()), "baz")
|
|
||||||
);
|
|
||||||
|
|
||||||
assert!("#EXT-X-SESSION-DATA:\
|
assert!("#EXT-X-SESSION-DATA:\
|
||||||
DATA-ID=\"foo\",\
|
DATA-ID=\"foo\",\
|
||||||
|
@ -369,6 +298,49 @@ mod test {
|
||||||
.is_err());
|
.is_err());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
generate_tests! {
|
||||||
|
{
|
||||||
|
ExtXSessionData::new(
|
||||||
|
"com.example.lyrics",
|
||||||
|
SessionData::Uri("lyrics.json".into())
|
||||||
|
),
|
||||||
|
concat!(
|
||||||
|
"#EXT-X-SESSION-DATA:",
|
||||||
|
"DATA-ID=\"com.example.lyrics\",",
|
||||||
|
"URI=\"lyrics.json\""
|
||||||
|
)
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ExtXSessionData::with_language(
|
||||||
|
"com.example.title",
|
||||||
|
SessionData::Value("This is an example".into()),
|
||||||
|
"en"
|
||||||
|
),
|
||||||
|
concat!(
|
||||||
|
"#EXT-X-SESSION-DATA:",
|
||||||
|
"DATA-ID=\"com.example.title\",",
|
||||||
|
"VALUE=\"This is an example\",",
|
||||||
|
"LANGUAGE=\"en\""
|
||||||
|
)
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ExtXSessionData::with_language(
|
||||||
|
"com.example.title",
|
||||||
|
SessionData::Value("Este es un ejemplo".into()),
|
||||||
|
"es"
|
||||||
|
),
|
||||||
|
concat!(
|
||||||
|
"#EXT-X-SESSION-DATA:",
|
||||||
|
"DATA-ID=\"com.example.title\",",
|
||||||
|
"VALUE=\"Este es un ejemplo\",",
|
||||||
|
"LANGUAGE=\"es\""
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_required_version() {
|
fn test_required_version() {
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
|
|
Loading…
Reference in a new issue