| <!DOCTYPE html> |
| <script src="/resources/testharness.js"></script> |
| <script src="/resources/testharnessreport.js"></script> |
| <script src="/common/utils.js"></script> |
| <script src="/common/get-host-info.sub.js"></script> |
| <script src="resources/utils.js"></script> |
| <title>Test installing a config with empty url to a navigated fenced frame |
| unloads the original document</title> |
| |
| <body> |
| |
| <script> |
| promise_test(async () => { |
| const fenced_frame_loaded_key = token(); |
| |
| // Create a fenced frame and install a config constructed with an empty url. |
| const fenced_frame = document.createElement('fencedframe'); |
| document.body.append(fenced_frame); |
| |
| // Specify the fenced frame's src attribute to an url. |
| const url = generateURL('resources/fenced-frame-loaded.html', |
| [fenced_frame_loaded_key]); |
| fenced_frame.config = new FencedFrameConfig(url); |
| |
| // The fenced frame should navigate to the src url. |
| const load_expected = "fenced frame loaded"; |
| const load_actual = await nextValueFromServer(fenced_frame_loaded_key); |
| assert_equals(load_actual, load_expected, |
| "Fenced frame successfully loaded by specifying its src attribute."); |
| |
| // Create a config with an empty url. |
| const empty_url_config = new FencedFrameConfig(''); |
| fenced_frame.config = empty_url_config; |
| |
| // Installing a config with an empty url to the fenced frame should unload the |
| // original document. |
| const server_value = await readValueFromServer(fenced_frame_loaded_key); |
| assert_false(server_value.status); |
| |
| }, 'Installing a config with empty url to a navigated fenced unloads ', |
| 'the original document.'); |
| </script> |
| |
| </body> |