1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
<!doctype html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<iframe id="i" src="/common/blank.html"></iframe>
<script>
async_test(t => {
window.onload = t.step_func(() => {
const navState1 = { key: "value" };
const navState2 = { key2: "value2" };
const navInfo = { infoKey: "infoValue" };
i.contentWindow.navigation.navigate("#1", { state: navState1 }).committed.then(t.step_func(() => {
// Make sure that state setting worked
assert_equals(i.contentWindow.navigation.currentEntry.getState().key, "value", "initial state setup");
assert_not_equals(i.contentWindow.navigation.currentEntry.getState(), navState1);
let start_url = i.contentWindow.location.href;
let start_key = i.contentWindow.navigation.currentEntry.key;
let start_id = i.contentWindow.navigation.currentEntry.id;
let onnavigate_called = false;
let promise_settled = false;
i.contentWindow.navigation.onnavigate = t.step_func(e => {
e.intercept();
onnavigate_called = true;
assert_equals(e.info, navInfo);
assert_equals(e.navigationType, "reload");
assert_equals(e.destination.getState().key2, "value2", "navigate event for the reload()");
assert_not_equals(e.destination.getState(), navState2);
});
i.contentWindow.navigation.reload({ info: navInfo, state: navState2 }).committed.then(t.step_func_done(() => {
assert_true(onnavigate_called);
assert_equals(i.contentWindow.location.href, start_url);
assert_equals(i.contentWindow.navigation.currentEntry.key, start_key);
assert_equals(i.contentWindow.navigation.currentEntry.id, start_id);
assert_equals(i.contentWindow.navigation.currentEntry.getState().key2, "value2", "currentEntry.getState() after the reload");
assert_not_equals(i.contentWindow.navigation.currentEntry.getState(), navState2);
}));
}));
});
}, "reload() variant with info and new state");
</script>
|