mirror of
https://github.com/rustwasm/wasm-bindgen.git
synced 2024-12-18 23:41:45 +03:00
efa4a2b8fa
* Reorganize Travis configuration * Add a `JOB` env var descriptor to all matrix entries. Not used anywhere but is useful when viewing the whole build on Travis's web interface. * Reorganize where builds are located, moving slow builds first and fast ones last. * Change checking the CLI builds from `cargo build` to `cargo check` * Use YAML references to reduce some duplication * Print some more timing statistics for each test * Extract `Project` helper in tests to a module This'll help make it a bit more extensible over time. At the same time the methods are also slightly reorganized to read more clearly from top to bottom. * Migrate all tests away from Webpack Wepback can take a significant amount of time to execute and when it's multiplied by hundreds of tests that adds up really quickly! After investigating Node's `--experimental-modules` option it looks like it's suitable for our use so this switches all tests to using JS files (moving away from TypeScript as well) with `--experimental-modules` with Node. Tests will be selectively re-enabled with webpack and node.js specific output (that doesn't require `--experimental-modules`), coming in later commits. * Restore the node test for node.js output Ensures it's workable as-is * Only generate typescript with webpack * Only read wasm files for webpack * Skip package.json/node_modules for now * Only generate webpack config if needed * Start a dedicated test module for typescript Will hopefully verify the generated Typescript compiles OK. * Remove unneeded `node` method * Fixup some rebase conflicts * Don't run asmjs example on travis * Fixup generator tests * Attempt to fix windows * Comment windows fix * More test fixes * More exclusions * More test fixes * Relax eslint regex Catch mjs modules as well * Fix eslint * Speed up travis on examples slightly
209 lines
5.2 KiB
Rust
209 lines
5.2 KiB
Rust
#![allow(non_snake_case)]
|
|
|
|
use project;
|
|
|
|
#[test]
|
|
fn apply() {
|
|
project()
|
|
.file(
|
|
"src/lib.rs",
|
|
r#"
|
|
#![feature(proc_macro, wasm_custom_section)]
|
|
|
|
extern crate wasm_bindgen;
|
|
use wasm_bindgen::prelude::*;
|
|
use wasm_bindgen::js;
|
|
|
|
#[wasm_bindgen]
|
|
pub fn apply(this: &js::Function, context: &JsValue, args: &js::Array) -> js::Function {
|
|
this.apply(context, args)
|
|
}
|
|
"#,
|
|
)
|
|
.file(
|
|
"test.js",
|
|
r#"
|
|
import * as assert from "assert";
|
|
import * as wasm from "./out";
|
|
|
|
export function test() {
|
|
assert.equal(wasm.apply(Math.max, {}, [1, 2, 3]), 3);
|
|
|
|
const arr = [1, 2];
|
|
wasm.apply(Array.prototype.push, arr, [3]);
|
|
assert.equal(arr[2], 3);
|
|
}
|
|
"#,
|
|
)
|
|
.test()
|
|
}
|
|
|
|
#[test]
|
|
fn bind() {
|
|
project()
|
|
.file(
|
|
"src/lib.rs",
|
|
r#"
|
|
#![feature(proc_macro, wasm_custom_section)]
|
|
|
|
extern crate wasm_bindgen;
|
|
use wasm_bindgen::prelude::*;
|
|
use wasm_bindgen::js;
|
|
|
|
#[wasm_bindgen]
|
|
pub fn bind(this: &js::Function, context: &JsValue) -> js::Function {
|
|
this.bind(context)
|
|
}
|
|
"#,
|
|
)
|
|
.file(
|
|
"test.js",
|
|
r#"
|
|
import * as assert from "assert";
|
|
import * as wasm from "./out";
|
|
|
|
export function test() {
|
|
const obj = {
|
|
a: 0,
|
|
fn: function () {
|
|
return this.a + 1;
|
|
}
|
|
}
|
|
|
|
const boundFn = wasm.bind(obj.fn, { a: 41 });
|
|
assert.equal(boundFn(), 42);
|
|
}
|
|
"#,
|
|
)
|
|
.test()
|
|
}
|
|
|
|
#[test]
|
|
fn length() {
|
|
project()
|
|
.file(
|
|
"src/lib.rs",
|
|
r#"
|
|
#![feature(proc_macro, wasm_custom_section)]
|
|
|
|
extern crate wasm_bindgen;
|
|
use wasm_bindgen::prelude::*;
|
|
use wasm_bindgen::js;
|
|
|
|
#[wasm_bindgen]
|
|
pub fn fn_length(this: &js::Function) -> u32 {
|
|
this.length()
|
|
}
|
|
"#,
|
|
)
|
|
.file(
|
|
"test.js",
|
|
r#"
|
|
import * as assert from "assert";
|
|
import * as wasm from "./out";
|
|
|
|
export function test() {
|
|
assert.equal(wasm.fn_length(() => {}), 0);
|
|
assert.equal(wasm.fn_length(a => console.log(a)), 1);
|
|
assert.equal(wasm.fn_length((a, b) => console.log({ a, b })), 2);
|
|
|
|
function fn0() {}
|
|
function fn1(a) {
|
|
console.log(a);
|
|
}
|
|
function fn2(a, b) {
|
|
console.log({ a, b });
|
|
}
|
|
|
|
assert.equal(wasm.fn_length(fn0), 0);
|
|
assert.equal(wasm.fn_length(fn1), 1);
|
|
assert.equal(wasm.fn_length(fn2), 2);
|
|
}
|
|
"#,
|
|
)
|
|
.test()
|
|
}
|
|
|
|
#[test]
|
|
fn name() {
|
|
project()
|
|
.file(
|
|
"src/lib.rs",
|
|
r#"
|
|
#![feature(proc_macro, wasm_custom_section)]
|
|
|
|
extern crate wasm_bindgen;
|
|
use wasm_bindgen::prelude::*;
|
|
use wasm_bindgen::js;
|
|
|
|
#[wasm_bindgen]
|
|
pub fn fn_name(this: &js::Function) -> js::JsString {
|
|
this.name()
|
|
}
|
|
"#,
|
|
)
|
|
.file(
|
|
"test.js",
|
|
r#"
|
|
import * as assert from "assert";
|
|
import * as wasm from "./out";
|
|
|
|
export function test() {
|
|
function namedFn() {}
|
|
assert.equal(wasm.fn_name(namedFn), 'namedFn');
|
|
|
|
assert.equal(wasm.fn_name(namedFn.bind({})), 'bound namedFn');
|
|
|
|
const obj = {
|
|
method: () => {}
|
|
}
|
|
assert.equal(wasm.fn_name(obj.method), 'method');
|
|
|
|
assert.equal(wasm.fn_name(new Function()), 'anonymous');
|
|
|
|
assert.equal(wasm.fn_name(() => {}), '');
|
|
|
|
const closure = () => {};
|
|
assert.equal(wasm.fn_name(closure), 'closure');
|
|
}
|
|
"#,
|
|
)
|
|
.test()
|
|
}
|
|
|
|
#[test]
|
|
fn to_string() {
|
|
project()
|
|
.file(
|
|
"src/lib.rs",
|
|
r#"
|
|
#![feature(proc_macro, wasm_custom_section)]
|
|
|
|
extern crate wasm_bindgen;
|
|
use wasm_bindgen::prelude::*;
|
|
use wasm_bindgen::js;
|
|
|
|
#[wasm_bindgen]
|
|
pub fn get_source_code(this: &js::Function) -> js::JsString {
|
|
this.to_string()
|
|
}
|
|
"#,
|
|
)
|
|
.file(
|
|
"test.js",
|
|
r#"
|
|
import * as assert from "assert";
|
|
import * as wasm from "./out";
|
|
|
|
export function test() {
|
|
function fn1(a, b) { return a + b; }
|
|
const fn2 = a => console.log(a);
|
|
|
|
assert.equal(wasm.get_source_code(fn1), 'function fn1(a, b) { return a + b; }');
|
|
assert.equal(wasm.get_source_code(fn2), 'a => console.log(a)');
|
|
}
|
|
"#,
|
|
)
|
|
.test()
|
|
}
|