| // META: timeout=long |
| // META: variant=?globalScope=window |
| // META: variant=?globalScope=dedicated_worker |
| // META: script=/resources/testdriver.js |
| // META: script=/resources/testdriver-vendor.js |
| // META: script=/common/utils.js |
| // META: script=/common/dispatcher/dispatcher.js |
| // META: script=./resources/common.js |
| |
| 'use strict'; |
| |
| pressure_test(async (t) => { |
| const observer = new PressureObserver(() => { |
| assert_unreached('The observer callback should not be called'); |
| }); |
| |
| await create_virtual_pressure_source('cpu', {supported: false}); |
| t.add_cleanup(async () => { |
| await remove_virtual_pressure_source('cpu'); |
| }); |
| return promise_rejects_dom(t, 'NotSupportedError', observer.observe('cpu')); |
| }, 'Return NotSupportedError when calling observer()'); |
| |
| pressure_test(async (t) => { |
| await create_virtual_pressure_source('cpu'); |
| t.add_cleanup(async () => { |
| await remove_virtual_pressure_source('cpu'); |
| }); |
| |
| const changes = await new Promise((resolve, reject) => { |
| const observer = new PressureObserver(resolve); |
| t.add_cleanup(() => observer.disconnect()); |
| observer.observe('cpu').catch(reject); |
| update_virtual_pressure_source('cpu', 'critical', 0.5).catch(reject); |
| }); |
| assert_equals(1, changes.length); |
| assert_equals(changes[0].state, 'critical'); |
| assert_equals(changes[0].source, 'cpu'); |
| assert_equals(typeof changes[0].time, 'number'); |
| assert_equals(typeof changes[0].ownContributionEstimate, 'number'); |
| assert_equals(changes[0].ownContributionEstimate, 0.5); |
| }, 'Basic functionality test'); |
| |
| pressure_test(async (t) => { |
| await create_virtual_pressure_source('cpu'); |
| t.add_cleanup(async () => { |
| await remove_virtual_pressure_source('cpu'); |
| }); |
| |
| const changes = await new Promise((resolve, reject) => { |
| const observer = new PressureObserver(resolve); |
| t.add_cleanup(() => observer.disconnect()); |
| observer.observe('cpu').catch(reject); |
| update_virtual_pressure_source('cpu', 'critical').catch(reject); |
| }); |
| assert_equals(1, changes.length); |
| assert_equals(changes[0].state, 'critical'); |
| assert_equals(changes[0].source, 'cpu'); |
| assert_equals(typeof changes[0].time, 'number'); |
| assert_equals(changes[0].ownContributionEstimate, null); |
| }, 'Basic functionality test with no ownContributionEstimate'); |
| |
| pressure_test(async (t) => { |
| await create_virtual_pressure_source('cpu'); |
| t.add_cleanup(async () => { |
| await remove_virtual_pressure_source('cpu'); |
| }); |
| |
| const observer = new PressureObserver(() => { |
| assert_unreached('The observer callback should not be called'); |
| }); |
| |
| await update_virtual_pressure_source('cpu', 'critical'); |
| const promise = observer.observe('cpu'); |
| observer.unobserve('cpu'); |
| |
| return promise_rejects_dom(t, 'AbortError', promise); |
| }, 'Removing observer before observe() resolves works'); |
| |
| pressure_test(async (t) => { |
| await create_virtual_pressure_source('cpu'); |
| t.add_cleanup(async () => { |
| await remove_virtual_pressure_source('cpu'); |
| }); |
| |
| const callbackPromises = []; |
| const observePromises = []; |
| |
| for (let i = 0; i < 2; i++) { |
| callbackPromises.push(new Promise(resolve => { |
| const observer = new PressureObserver(resolve); |
| t.add_cleanup(() => observer.disconnect()); |
| observePromises.push(observer.observe('cpu')); |
| })); |
| } |
| |
| await Promise.all(observePromises); |
| await update_virtual_pressure_source('cpu', 'critical'); |
| return Promise.all(callbackPromises); |
| }, 'Calling observe() multiple times works'); |
| |
| pressure_test(async (t) => { |
| await create_virtual_pressure_source('cpu'); |
| t.add_cleanup(async () => { |
| await remove_virtual_pressure_source('cpu'); |
| }); |
| |
| const observer1_promise = new Promise((resolve, reject) => { |
| const observer = new PressureObserver(resolve); |
| t.add_cleanup(() => observer.disconnect()); |
| observer.observe('cpu').catch(reject); |
| }); |
| await update_virtual_pressure_source('cpu', 'critical'); |
| const observer1_changes = await observer1_promise; |
| assert_equals(1, observer1_changes.length); |
| assert_equals(observer1_changes[0].source, 'cpu'); |
| assert_equals(observer1_changes[0].state, 'critical'); |
| |
| const observer2_changes = await new Promise((resolve, reject) => { |
| const observer = new PressureObserver(resolve); |
| t.add_cleanup(() => observer.disconnect()); |
| observer.observe('cpu').catch(reject); |
| }); |
| assert_equals(1, observer2_changes.length); |
| assert_equals(observer2_changes[0].source, 'cpu'); |
| assert_equals(observer2_changes[0].state, 'critical'); |
| }, 'Starting a new observer after an observer has started works'); |
| |
| mark_as_done(); |