"openedRequest.abort is not a function" in Window.close()
See original GitHub issueBasic info:
- Node.js version: 11.12.0
- jsdom version: 15.1.1
Minimal reproduction case
const { JSDOM } = require("jsdom")
const content = `
<html>
<head>
...
</head>
<body>
<img src="" alt="data-uri image">
</body>
`
const { window } = new JSDOM(content, {
runScripts: 'dangerously',
})
window.close()
When calling window.close()
on a page that contains data uri’s, I get the error message TypeError: openedRequest.abort is not a function at RequestManager.close
(thrown at request-manager.js#L23-L28)
Issue Analytics
- State:
- Created 4 years ago
- Reactions:4
- Comments:6 (2 by maintainers)
Top Results From Across the Web
Developers - "openedRequest.abort is not a function" in Window ...
... window.close(). When calling window.close() on a page that contains data uri's, I get the error message TypeError: openedRequest.abort is not a function...
Read more >window.close() is not a function in electron What I am doing ...
mainWindow is a function, so you need to call it and inside the function also return the window:
Read more >Contributing to JSDOM - Charper Bonaroo
.abort is not a function. Is openedRequest our fetch result? lib/jsdom/browser/resources/request-manager.js.
Read more >JavaScript Window close method - Javatpoint
JavaScript provides an in-built function named close() to close the browser window that is opened by using window.open() method. Unlike the window.open() method...
Read more >Oracle9i Database Error Messages - Oracle Help Center
conventions for writing code require that closing braces should appear on an ... If the problem is not resolved soon, the database will...
Read more >
Top Related Medium Post
No results found
Top Related StackOverflow Question
No results found
Troubleshoot Live Code
Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free
Top Related Reddit Thread
No results found
Top Related Hackernoon Post
No results found
Top Related Tweet
No results found
Top Related Dev.to Post
No results found
Top Related Hashnode Post
No results found
I get the same error when writing my own
ResourceLoader.fetch
method:I believe the problem here is that
RequestManager.close
assumes existence of anabort
method even though the README.md only requires thatabort
doesn’t seem to be part of thePromise
API. So perhaps that call should be guarded behind a checkif (typeof openedRequest.abort === "function")
or some such.Since the handler for the data protocol in
ResourceLoader.fetch
does usePromise.resolve
as well, the original issue is essentially the same. But fixing this inside theResourceLoader
implementation, as the current draft of #2678 does, will not fix things for custom implementations like the one above.I spotted that this is down to pending resource load promises still being around when JSDOM’s
close()
method is called. At that point, the resource loader API tries to abort any open requests by callingabort()
on each one. However, since that’s not necessarily a call on every promise (it is on fetch requests made viasuperagent
), it can result in this error.I think adding a check for the
abort
method here will suffice, as per @gagern above.https://github.com/jsdom/jsdom/blob/master/lib/jsdom/browser/resources/request-manager.js#L25