Skip to content

Commit

Permalink
Merge pull request #1487 from ibaryshnikov/shared_array_buffer_tests
Browse files Browse the repository at this point in the history
Added tests for SharedArrayBuffer
  • Loading branch information
alexcrichton authored Apr 26, 2019
2 parents cd7aa71 + af22a26 commit 26f9d86
Show file tree
Hide file tree
Showing 4 changed files with 65 additions and 2 deletions.
4 changes: 2 additions & 2 deletions crates/js-sys/tests/wasm/ArrayBuffer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -22,14 +22,14 @@ fn is_view() {
assert!(ArrayBuffer::is_view(&JsValue::from(x)));
}

#[test]
#[wasm_bindgen_test]
fn slice() {
let buf = ArrayBuffer::new(4);
let slice = buf.slice(2);
assert!(JsValue::from(slice).is_object());
}

#[test]
#[wasm_bindgen_test]
fn slice_with_end() {
let buf = ArrayBuffer::new(4);
let slice = buf.slice_with_end(1, 2);
Expand Down
3 changes: 3 additions & 0 deletions crates/js-sys/tests/wasm/SharedArrayBuffer.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
exports.is_shared_array_buffer_supported = function () {
return typeof SharedArrayBuffer === 'function';
};
59 changes: 59 additions & 0 deletions crates/js-sys/tests/wasm/SharedArrayBuffer.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
use js_sys::*;
use wasm_bindgen::JsCast;
use wasm_bindgen::prelude::*;
use wasm_bindgen_test::*;

#[wasm_bindgen(module = "tests/wasm/SharedArrayBuffer.js")]
extern "C" {
fn is_shared_array_buffer_supported() -> bool;
}

#[wasm_bindgen_test]
fn new() {
if !is_shared_array_buffer_supported() {
return;
}
let x = SharedArrayBuffer::new(42);
let y: JsValue = x.into();
assert!(y.is_object());
}

#[wasm_bindgen_test]
fn byte_length() {
if !is_shared_array_buffer_supported() {
return;
}
let buf = SharedArrayBuffer::new(42);
assert_eq!(buf.byte_length(), 42);
}

#[wasm_bindgen_test]
fn slice() {
if !is_shared_array_buffer_supported() {
return;
}
let buf = SharedArrayBuffer::new(4);
let slice = buf.slice(2);
assert!(JsValue::from(slice).is_object());
}

#[wasm_bindgen_test]
fn slice_with_end() {
if !is_shared_array_buffer_supported() {
return;
}
let buf = SharedArrayBuffer::new(4);
let slice = buf.slice_with_end(1, 2);
assert!(JsValue::from(slice).is_object());
}

#[wasm_bindgen_test]
fn sharedarraybuffer_inheritance() {
if !is_shared_array_buffer_supported() {
return;
}
let buf = SharedArrayBuffer::new(4);
assert!(buf.is_instance_of::<SharedArrayBuffer>());
assert!(buf.is_instance_of::<Object>());
let _: &Object = buf.as_ref();
}
1 change: 1 addition & 0 deletions crates/js-sys/tests/wasm/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ pub mod Reflect;
pub mod RegExp;
pub mod Set;
pub mod SetIterator;
pub mod SharedArrayBuffer;
pub mod Symbol;
pub mod SyntaxError;
pub mod TypeError;
Expand Down

0 comments on commit 26f9d86

Please sign in to comment.