2020-08-07 16:55:02 +02:00
|
|
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
|
|
|
|
2020-09-17 19:13:20 +02:00
|
|
|
use deno_core::error::uri_error;
|
|
|
|
use deno_core::error::AnyError;
|
2020-09-01 16:32:07 -04:00
|
|
|
use deno_core::js_check;
|
2020-09-17 19:13:20 +02:00
|
|
|
use deno_core::serde_json;
|
|
|
|
use deno_core::serde_json::json;
|
|
|
|
use deno_core::serde_json::Value;
|
2020-09-06 21:44:29 +02:00
|
|
|
use deno_core::JsRuntime;
|
2020-09-17 19:13:20 +02:00
|
|
|
use deno_core::ZeroCopyBuf;
|
|
|
|
use idna::domain_to_ascii;
|
|
|
|
use idna::domain_to_ascii_strict;
|
|
|
|
use serde::Deserialize;
|
2020-09-09 13:23:57 +01:00
|
|
|
use std::path::{Path, PathBuf};
|
2020-08-07 16:55:02 +02:00
|
|
|
|
2020-09-17 19:13:20 +02:00
|
|
|
pub fn op_domain_to_ascii(
|
|
|
|
_state: &mut deno_core::OpState,
|
|
|
|
args: Value,
|
|
|
|
_zero_copy: &mut [ZeroCopyBuf],
|
|
|
|
) -> Result<Value, AnyError> {
|
|
|
|
#[derive(Deserialize)]
|
|
|
|
#[serde(rename_all = "camelCase")]
|
|
|
|
struct DomainToAscii {
|
|
|
|
domain: String,
|
|
|
|
be_strict: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
let args: DomainToAscii = serde_json::from_value(args)?;
|
|
|
|
if args.be_strict {
|
|
|
|
domain_to_ascii_strict(args.domain.as_str())
|
|
|
|
} else {
|
|
|
|
domain_to_ascii(args.domain.as_str())
|
|
|
|
}
|
|
|
|
.map_err(|err| {
|
|
|
|
let message = format!("Invalid IDNA encoded domain name: {:?}", err);
|
|
|
|
uri_error(message)
|
|
|
|
})
|
|
|
|
.map(|domain| json!(domain))
|
|
|
|
}
|
|
|
|
|
2020-09-06 21:44:29 +02:00
|
|
|
pub fn init(isolate: &mut JsRuntime) {
|
2020-09-09 13:23:57 +01:00
|
|
|
let manifest_dir = Path::new(env!("CARGO_MANIFEST_DIR"));
|
2020-09-01 16:32:07 -04:00
|
|
|
let files = vec![
|
2020-09-09 13:23:57 +01:00
|
|
|
manifest_dir.join("00_dom_exception.js"),
|
|
|
|
manifest_dir.join("01_event.js"),
|
|
|
|
manifest_dir.join("02_abort_signal.js"),
|
|
|
|
manifest_dir.join("08_text_encoding.js"),
|
2020-09-17 19:13:20 +02:00
|
|
|
manifest_dir.join("11_url.js"),
|
2020-09-01 16:32:07 -04:00
|
|
|
];
|
2020-09-09 13:23:57 +01:00
|
|
|
// TODO(nayeemrmn): https://github.com/rust-lang/cargo/issues/3946 to get the
|
|
|
|
// workspace root.
|
|
|
|
let display_root = manifest_dir.parent().unwrap().parent().unwrap();
|
2020-09-01 16:32:07 -04:00
|
|
|
for file in files {
|
|
|
|
println!("cargo:rerun-if-changed={}", file.display());
|
2020-09-09 13:23:57 +01:00
|
|
|
let display_path = file.strip_prefix(display_root).unwrap();
|
|
|
|
let display_path_str = display_path.display().to_string();
|
2020-09-01 16:32:07 -04:00
|
|
|
js_check(isolate.execute(
|
2020-09-09 13:23:57 +01:00
|
|
|
&("deno:".to_string() + &display_path_str.replace('\\', "/")),
|
2020-09-01 16:32:07 -04:00
|
|
|
&std::fs::read_to_string(&file).unwrap(),
|
|
|
|
));
|
|
|
|
}
|
2020-08-07 16:55:02 +02:00
|
|
|
}
|
|
|
|
|
2020-09-01 16:32:07 -04:00
|
|
|
pub fn get_declaration() -> PathBuf {
|
2020-09-09 13:23:57 +01:00
|
|
|
PathBuf::from(env!("CARGO_MANIFEST_DIR")).join("lib.deno_web.d.ts")
|
2020-08-07 16:55:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use deno_core::js_check;
|
2020-09-06 21:44:29 +02:00
|
|
|
use deno_core::JsRuntime;
|
2020-08-07 16:55:02 +02:00
|
|
|
use futures::future::lazy;
|
|
|
|
use futures::future::FutureExt;
|
|
|
|
use futures::task::Context;
|
|
|
|
use futures::task::Poll;
|
|
|
|
|
|
|
|
fn run_in_task<F>(f: F)
|
|
|
|
where
|
|
|
|
F: FnOnce(&mut Context) + Send + 'static,
|
|
|
|
{
|
|
|
|
futures::executor::block_on(lazy(move |cx| f(cx)));
|
|
|
|
}
|
|
|
|
|
2020-09-06 21:44:29 +02:00
|
|
|
fn setup() -> JsRuntime {
|
2020-09-11 15:18:49 +02:00
|
|
|
let mut isolate = JsRuntime::new(Default::default());
|
2020-09-01 16:32:07 -04:00
|
|
|
crate::init(&mut isolate);
|
2020-08-07 16:55:02 +02:00
|
|
|
isolate
|
|
|
|
}
|
|
|
|
|
2020-08-19 14:43:20 +02:00
|
|
|
#[test]
|
|
|
|
fn test_abort_controller() {
|
|
|
|
run_in_task(|mut cx| {
|
|
|
|
let mut isolate = setup();
|
|
|
|
js_check(isolate.execute(
|
|
|
|
"abort_controller_test.js",
|
|
|
|
include_str!("abort_controller_test.js"),
|
|
|
|
));
|
|
|
|
if let Poll::Ready(Err(_)) = isolate.poll_unpin(&mut cx) {
|
|
|
|
unreachable!();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-08-07 16:55:02 +02:00
|
|
|
#[test]
|
|
|
|
fn test_event() {
|
|
|
|
run_in_task(|mut cx| {
|
|
|
|
let mut isolate = setup();
|
|
|
|
js_check(isolate.execute("event_test.js", include_str!("event_test.js")));
|
|
|
|
if let Poll::Ready(Err(_)) = isolate.poll_unpin(&mut cx) {
|
|
|
|
unreachable!();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-09-09 13:23:57 +01:00
|
|
|
#[test]
|
|
|
|
fn test_event_error() {
|
|
|
|
run_in_task(|mut cx| {
|
|
|
|
let mut isolate = setup();
|
|
|
|
let result = isolate.execute("foo.js", "new Event()");
|
|
|
|
if let Err(error) = result {
|
|
|
|
let error_string = error.to_string();
|
|
|
|
// Test that the script specifier is a URL: `deno:<repo-relative path>`.
|
|
|
|
assert!(error_string.starts_with("deno:op_crates/web/01_event.js"));
|
|
|
|
assert!(error_string.contains("Uncaught TypeError"));
|
|
|
|
} else {
|
|
|
|
unreachable!();
|
|
|
|
}
|
|
|
|
if let Poll::Ready(Err(_)) = isolate.poll_unpin(&mut cx) {
|
|
|
|
unreachable!();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-08-07 16:55:02 +02:00
|
|
|
#[test]
|
|
|
|
fn test_event_target() {
|
|
|
|
run_in_task(|mut cx| {
|
|
|
|
let mut isolate = setup();
|
|
|
|
js_check(
|
|
|
|
isolate.execute(
|
|
|
|
"event_target_test.js",
|
|
|
|
include_str!("event_target_test.js"),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
if let Poll::Ready(Err(_)) = isolate.poll_unpin(&mut cx) {
|
|
|
|
unreachable!();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_text_encoding() {
|
|
|
|
run_in_task(|mut cx| {
|
|
|
|
let mut isolate = setup();
|
|
|
|
js_check(isolate.execute(
|
|
|
|
"text_encoding_test.js",
|
|
|
|
include_str!("text_encoding_test.js"),
|
|
|
|
));
|
|
|
|
if let Poll::Ready(Err(_)) = isolate.poll_unpin(&mut cx) {
|
|
|
|
unreachable!();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|