mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-25 18:34:14 +00:00 
			
		
		
		
	LibWeb: Wait until child navigable's SHE is ready before navigating
This change fixes a bug that can be reproduced with the following steps:
```js
const iframe = document.createElement("iframe");
document.body.appendChild(iframe);
iframe.contentWindow.location.href = ("http://localhost:8080/demo.html");
```
These steps are executed in the following order:
1. Create iframe and schedule session history traversal task that adds
   session history entry for the iframe.
2. Generate navigation id for scheduled navigation to
   `http://localhost:8080/demo.html`.
3. Execute the scheduled session history traversal task, which adds
   session history entry for the iframe.
4. Ooops, navigation to `http://localhost:8080/demo.html` is aborted
   because addings SHE for the iframe resets the navigation id.
This change fixes this by delaying all navigations until SHE for a
navigable is created.
			
			
This commit is contained in:
		
							parent
							
								
									718e874cc7
								
							
						
					
					
						commit
						b8af3fccf6
					
				
				
				Notes:
				
					github-actions[bot]
				
				2025-02-27 13:32:33 +00:00 
				
			
			Author: https://github.com/kalenikaliaksandr
Commit: b8af3fccf6
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/3711
			
					 12 changed files with 155 additions and 57 deletions
				
			
		|  | @ -446,7 +446,7 @@ void HTMLObjectElement::run_object_representation_handler_steps(Fetch::Infrastru | |||
|         // If the object element's content navigable is null, then create a new child navigable for the element.
 | ||||
|         if (!m_content_navigable && in_a_document_tree()) { | ||||
|             MUST(create_new_child_navigable()); | ||||
|             set_content_navigable_initialized(); | ||||
|             set_content_navigable_has_session_history_entry_and_ready_for_navigation(); | ||||
|         } | ||||
| 
 | ||||
|         // NOTE: Creating a new nested browsing context can fail if the document is not attached to a browsing context
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Aliaksandr Kalenik
						Aliaksandr Kalenik