mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-24 17:09:43 +00:00 
			
		
		
		
	It does fetching and uses parseFromString() DOMParser API in the fetch
callback. Following steps end up hanging before reverting
664611bae4:
1. Do fetching initiated by fetch() js call.
2. Invoke fetch callback on networking task source
3. Fetch callback does parseFromString()
4. parseFromString() invokes HTMLParser
5. HTMLLinkElement inserted into new document initiates fetching
6. Fetching callback cannot run because networking source was blocked on
   step 2.
7. HTMLParser::the_end() spins waiting for HTMLLinkElement to unblock
   load event, which will never happen because fetching callback cannot
   proceed.
		
	
			
		
			
				
	
	
		
			20 lines
		
	
	
	
		
			596 B
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			20 lines
		
	
	
	
		
			596 B
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | |
| <head>
 | |
|     <script src="include.js"></script>
 | |
|     <link href="file://does-not-exists.css" rel="stylesheet" />
 | |
| </head>
 | |
| <script>
 | |
|     asyncTest(done => {
 | |
|         fetch("parse-document-from-string-in-fetch-callback.html")
 | |
|             .then(response => {
 | |
|                 return response.text()
 | |
|             })
 | |
|             .then(text => {
 | |
|                 const parser = new DOMParser();
 | |
|                 const newDoc = parser.parseFromString(text, 'text/html');
 | |
|                 println(newDoc.body.innerHTML);
 | |
|                 done();
 | |
|             });
 | |
|     });
 | |
| </script>
 | |
| <body>hello!</body>
 |