mirror of
https://github.com/servo/servo.git
synced 2025-06-12 02:14:41 +00:00
In rust-url 1.0 the `Url` struct is going to have private fields, and there is no way to to create an aribitrary one without going through the parser. The plugin never had a clear demonstrated performance benefit, it was made mostly because it was possible and relatively easy at the time.
106 lines
3.3 KiB
Rust
106 lines
3.3 KiB
Rust
/* 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 script::origin::Origin;
|
|
use url::Url;
|
|
|
|
#[test]
|
|
fn same_origin() {
|
|
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
let b = Origin::new(&Url::parse("http://example.com/b.html").unwrap());
|
|
assert!(a.same_origin(&b));
|
|
assert_eq!(a.is_scheme_host_port_tuple(), true);
|
|
}
|
|
|
|
#[test]
|
|
fn identical_origin() {
|
|
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
assert!(a.same_origin(&a));
|
|
}
|
|
|
|
#[test]
|
|
fn cross_origin() {
|
|
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
let b = Origin::new(&Url::parse("http://example.org/b.html").unwrap());
|
|
assert!(!a.same_origin(&b));
|
|
}
|
|
|
|
#[test]
|
|
fn alias_same_origin() {
|
|
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
let b = Origin::new(&Url::parse("http://example.com/b.html").unwrap());
|
|
let c = b.alias();
|
|
assert!(a.same_origin(&c));
|
|
assert!(b.same_origin(&b));
|
|
assert!(c.same_origin(&b));
|
|
assert_eq!(c.is_scheme_host_port_tuple(), true);
|
|
}
|
|
|
|
#[test]
|
|
fn alias_cross_origin() {
|
|
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
let b = Origin::new(&Url::parse("http://example.org/b.html").unwrap());
|
|
let c = b.alias();
|
|
assert!(!a.same_origin(&c));
|
|
assert!(b.same_origin(&c));
|
|
assert!(c.same_origin(&c));
|
|
}
|
|
|
|
#[test]
|
|
fn alias_update_same_origin() {
|
|
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
let b = Origin::new(&Url::parse("http://example.org/b.html").unwrap());
|
|
let c = b.alias();
|
|
b.set(Url::parse("http://example.com/c.html").unwrap().origin());
|
|
assert!(a.same_origin(&c));
|
|
assert!(b.same_origin(&c));
|
|
assert!(c.same_origin(&c));
|
|
}
|
|
|
|
#[test]
|
|
fn alias_update_cross_origin() {
|
|
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
let b = Origin::new(&Url::parse("http://example.com/b.html").unwrap());
|
|
let c = b.alias();
|
|
b.set(Url::parse("http://example.org/c.html").unwrap().origin());
|
|
assert!(!a.same_origin(&c));
|
|
assert!(b.same_origin(&c));
|
|
assert!(c.same_origin(&c));
|
|
}
|
|
|
|
#[test]
|
|
fn alias_chain() {
|
|
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
let b = Origin::new(&Url::parse("http://example.com/b.html").unwrap());
|
|
let c = b.copy();
|
|
let d = c.alias();
|
|
let e = d.alias();
|
|
assert!(a.same_origin(&e));
|
|
assert!(b.same_origin(&e));
|
|
assert!(c.same_origin(&e));
|
|
assert!(d.same_origin(&e));
|
|
assert!(e.same_origin(&e));
|
|
c.set(Url::parse("http://example.org/c.html").unwrap().origin());
|
|
assert!(a.same_origin(&b));
|
|
assert!(!b.same_origin(&c));
|
|
assert!(c.same_origin(&d));
|
|
assert!(d.same_origin(&e));
|
|
assert!(!e.same_origin(&a));
|
|
}
|
|
|
|
#[test]
|
|
fn opaque() {
|
|
let a = Origin::opaque_identifier();
|
|
let b = Origin::opaque_identifier();
|
|
assert!(!a.same_origin(&b));
|
|
assert_eq!(a.is_scheme_host_port_tuple(), false);
|
|
}
|
|
|
|
#[test]
|
|
fn opaque_clone() {
|
|
let a = Origin::opaque_identifier();
|
|
let b = a.alias();
|
|
assert!(a.same_origin(&b));
|
|
assert_eq!(a.is_scheme_host_port_tuple(), false);
|
|
}
|