aboutsummaryrefslogtreecommitdiffstats
path: root/components/net/data_loader.rs
diff options
context:
space:
mode:
authorSimon Sapin <simon.sapin@exyr.org>2015-04-07 17:32:39 +0200
committerSimon Sapin <simon.sapin@exyr.org>2015-04-08 01:07:50 +0200
commitd88770e09f76e89e51f69dd6a6b541600405b7bf (patch)
tree2b23a566d2a740753de1882d73b771fa1bdef18e /components/net/data_loader.rs
parent691222696ede82ab7bed219e1c4203200ad2a752 (diff)
downloadservo-d88770e09f76e89e51f69dd6a6b541600405b7bf.tar.gz
servo-d88770e09f76e89e51f69dd6a6b541600405b7bf.zip
Move net::{data_loader,image_cache_task} unit tests into the unit_tests crate.
Diffstat (limited to 'components/net/data_loader.rs')
-rw-r--r--components/net/data_loader.rs70
1 files changed, 1 insertions, 69 deletions
diff --git a/components/net/data_loader.rs b/components/net/data_loader.rs
index dc1b4356390..03ec60be3a8 100644
--- a/components/net/data_loader.rs
+++ b/components/net/data_loader.rs
@@ -21,7 +21,7 @@ pub fn factory(load_data: LoadData, _classifier: Arc<MIMEClassifier>) {
load(load_data)
}
-fn load(load_data: LoadData) {
+pub fn load(load_data: LoadData) {
let start_chan = load_data.consumer;
let url = load_data.url;
assert!(&*url.scheme == "data");
@@ -81,71 +81,3 @@ fn load(load_data: LoadData) {
progress_chan.send(Done(Ok(()))).unwrap();
}
}
-
-#[cfg(test)]
-fn assert_parse(url: &'static str,
- content_type: Option<(String, String)>,
- charset: Option<String>,
- data: Option<Vec<u8>>) {
- use std::sync::mpsc::channel;
- use url::Url;
-
- let (start_chan, start_port) = channel();
- load(LoadData::new(Url::parse(url).unwrap(), start_chan));
-
- let response = start_port.recv().unwrap();
- assert_eq!(&response.metadata.content_type, &content_type);
- assert_eq!(&response.metadata.charset, &charset);
-
- let progress = response.progress_port.recv().unwrap();
-
- match data {
- None => {
- assert_eq!(progress, Done(Err("invalid data uri".to_string())));
- }
- Some(dat) => {
- assert_eq!(progress, Payload(dat));
- assert_eq!(response.progress_port.recv().unwrap(), Done(Ok(())));
- }
- }
-}
-
-#[test]
-fn empty_invalid() {
- assert_parse("data:", None, None, None);
-}
-
-#[test]
-fn plain() {
- assert_parse("data:,hello%20world", None, None, Some(b"hello world".iter().map(|&x| x).collect()));
-}
-
-#[test]
-fn plain_ct() {
- assert_parse("data:text/plain,hello",
- Some(("text".to_string(), "plain".to_string())), None, Some(b"hello".iter().map(|&x| x).collect()));
-}
-
-#[test]
-fn plain_charset() {
- assert_parse("data:text/plain;charset=latin1,hello",
- Some(("text".to_string(), "plain".to_string())), Some("latin1".to_string()), Some(b"hello".iter().map(|&x| x).collect()));
-}
-
-#[test]
-fn base64() {
- assert_parse("data:;base64,C62+7w==", None, None, Some(vec!(0x0B, 0xAD, 0xBE, 0xEF)));
-}
-
-#[test]
-fn base64_ct() {
- assert_parse("data:application/octet-stream;base64,C62+7w==",
- Some(("application".to_string(), "octet-stream".to_string())), None, Some(vec!(0x0B, 0xAD, 0xBE, 0xEF)));
-}
-
-#[test]
-fn base64_charset() {
- assert_parse("data:text/plain;charset=koi8-r;base64,8PLl9+XkIO3l5Pfl5A==",
- Some(("text".to_string(), "plain".to_string())), Some("koi8-r".to_string()),
- Some(vec!(0xF0, 0xF2, 0xE5, 0xF7, 0xE5, 0xE4, 0x20, 0xED, 0xE5, 0xE4, 0xF7, 0xE5, 0xE4)));
-}