mirror of
https://github.com/rustwasm/wasm-bindgen.git
synced 2024-12-15 04:23:12 +03:00
Use textContent instead of innerHTML for extracting logs from headless browser tests
Easier to maintain fidelity and less likely to be sabotaged by XSS and `<script>` tags. Fixes #1232
This commit is contained in:
parent
9d27bc2e8b
commit
11eeeb8fc8
@ -13,7 +13,7 @@
|
||||
const orig = id => (...args) => {
|
||||
const logs = document.getElementById(id);
|
||||
for (let msg of args) {
|
||||
logs.innerHTML += `${msg}\n`;
|
||||
logs.textContent += `${msg}\n`;
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -30,7 +30,7 @@ pub fn spawn(
|
||||
// Now that we've gotten to the point where JS is executing, update our
|
||||
// status text as at this point we should be asynchronously fetching the
|
||||
// wasm module.
|
||||
document.getElementById('output').innerHTML = "Loading wasm module...";
|
||||
document.getElementById('output').textContent = "Loading wasm module...";
|
||||
|
||||
async function main(test) {{
|
||||
// this is a facet of using wasm2es6js, a hack until browsers have
|
||||
|
@ -22,10 +22,10 @@ extern "C" {
|
||||
fn getElementById(this: &HTMLDocument, id: &str) -> Element;
|
||||
|
||||
type Element;
|
||||
#[wasm_bindgen(method, getter = innerHTML, structural)]
|
||||
fn inner_html(this: &Element) -> String;
|
||||
#[wasm_bindgen(method, setter = innerHTML, structural)]
|
||||
fn set_inner_html(this: &Element, html: &str);
|
||||
#[wasm_bindgen(method, getter = textContent, structural)]
|
||||
fn text_content(this: &Element) -> String;
|
||||
#[wasm_bindgen(method, setter = textContent, structural)]
|
||||
fn set_text_content(this: &Element, text: &str);
|
||||
|
||||
type BrowserError;
|
||||
#[wasm_bindgen(method, getter, structural)]
|
||||
@ -37,24 +37,16 @@ impl Browser {
|
||||
/// (requires `Node::new()` to have return `None` first).
|
||||
pub fn new() -> Browser {
|
||||
let pre = document.getElementById("output");
|
||||
pre.set_inner_html("");
|
||||
pre.set_text_content("");
|
||||
Browser { pre }
|
||||
}
|
||||
}
|
||||
|
||||
impl super::Formatter for Browser {
|
||||
fn writeln(&self, line: &str) {
|
||||
let mut html = self.pre.inner_html();
|
||||
for c in line.chars() {
|
||||
match c {
|
||||
'<' => html.push_str("<"),
|
||||
'>' => html.push_str(">"),
|
||||
'&' => html.push_str("&"),
|
||||
c => html.push(c),
|
||||
}
|
||||
}
|
||||
html.push_str("\n");
|
||||
self.pre.set_inner_html(&html);
|
||||
let mut html = self.pre.text_content();
|
||||
html.extend(line.chars().chain(Some('\n')));
|
||||
self.pre.set_text_content(&html);
|
||||
}
|
||||
|
||||
fn log_test(&self, name: &str, result: &Result<(), JsValue>) {
|
||||
|
11
tests/headless.rs
Normal file → Executable file
11
tests/headless.rs
Normal file → Executable file
@ -26,3 +26,14 @@ impl ConsumeRetString {
|
||||
fn works() {
|
||||
ConsumeRetString.consume();
|
||||
}
|
||||
|
||||
#[wasm_bindgen]
|
||||
extern {
|
||||
#[wasm_bindgen(js_namespace = console)]
|
||||
pub fn log(s: &str);
|
||||
}
|
||||
|
||||
#[wasm_bindgen_test]
|
||||
fn can_log_html_strings() {
|
||||
log("<script>alert('lol')</script>");
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user