File: xrSession_visibilityState.https.html

package info (click to toggle)
thunderbird 1%3A143.0.1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 4,703,968 kB
  • sloc: cpp: 7,770,492; javascript: 5,943,842; ansic: 3,918,754; python: 1,418,263; xml: 653,354; asm: 474,045; java: 183,079; sh: 111,238; makefile: 20,410; perl: 14,359; objc: 13,059; yacc: 4,583; pascal: 3,405; lex: 1,720; ruby: 999; exp: 762; sql: 715; awk: 580; php: 436; lisp: 430; sed: 69; csh: 10
file content (82 lines) | stat: -rw-r--r-- 2,716 bytes parent folder | download | duplicates (22)
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
<!DOCTYPE html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="resources/webxr_util.js"></script>
<script src="resources/webxr_test_constants.js"></script>

<script>
let testName = "Ensures that the XRSession's visibilityState is correctly "
  + "reported and that the associated visibilitychange event fires.";

let watcherDone = new Event("watcherdone");
let frameFired = new Event("framefired");

let fakeDeviceInitParams = TRACKED_IMMERSIVE_DEVICE;

let testFunction = function(session, fakeDeviceController, t) {
  let eventWatcher = new EventWatcher(
    t, session, ["visibilitychange", "framefired", "watcherdone"]);
  let eventPromise = eventWatcher.wait_for(
    ["visibilitychange", "visibilitychange", "framefired", "watcherdone"]);

  function onFrame(timestamp, frame) {
    t.step( () => {
      // The session should not fire any animation frames while the visibility
      // state is hidden.
      assert_not_equals(session.visibilityState, "hidden");
    });

    // Make sure the frame does fire when the visibility is changed back to "visible"
    session.dispatchEvent(frameFired);
  }

  function onSessionVisibilityChangeHidden(event) {
    t.step( () => {
      assert_equals(session.visibilityState, "hidden");
    });

    session.removeEventListener("visibilitychange", onSessionVisibilityChangeHidden, false);
    session.addEventListener("visibilitychange", onSessionVisibilityChangeVisible, false);

    session.requestAnimationFrame(onFrame)

    t.step_timeout(() => {
      fakeDeviceController.simulateVisibilityChange("visible");
    }, 300);
  }

  function onSessionVisibilityChangeVisible(event) {
    t.step( () => {
      assert_equals(session.visibilityState, "visible");
    });

    session.removeEventListener("visibilitychange", onSessionVisibilityChangeVisible, false);
    session.addEventListener("visibilitychange", onSessionVisibilityChangeInvalid, false);
    fakeDeviceController.simulateVisibilityChange("visible");

    t.step_timeout(() => {
      session.dispatchEvent(watcherDone);
    }, 300);
  }

  function onSessionVisibilityChangeInvalid(event) {
    t.step( () => {
      assert_not_reached("Should not fire visibilitychange events for the same state");
    });
  }

  t.step( () => {
    // Session visibility should start out as "visible"
    assert_equals(session.visibilityState, "visible");
  });

  session.addEventListener("visibilitychange", onSessionVisibilityChangeHidden, false);
  fakeDeviceController.simulateVisibilityChange("hidden");

  return eventPromise;
};

xr_session_promise_test(
  testName, testFunction, fakeDeviceInitParams, 'immersive-vr');

</script>