question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

"openedRequest.abort is not a function" in Window.close()

See original GitHub issue

Basic 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:closed
  • Created 4 years ago
  • Reactions:4
  • Comments:6 (2 by maintainers)

github_iconTop GitHub Comments

4reactions
gagerncommented, Nov 14, 2019

I get the same error when writing my own ResourceLoader.fetch method:

"use strict";
const jsdom = require("jsdom");

const data = {
  "http://www.example.com/foo.css": Buffer.from([]),
  "http://www.example.com/foo.js": Buffer.from("window.close()", "utf8"),
};

class MyResourceLoader extends jsdom.ResourceLoader {
  fetch(url, options) {
    const promise = Promise.resolve(data[url]);
    // Enabling the following line fixes the problem:
    // if (typeof promise.abort === "undefined") promise.abort = function(){};
    return promise;
  }
}

new jsdom.JSDOM(`<html><head>
<script type="text/javascript" src="foo.js"></script>
<link rel="stylesheet" href="foo.css">
</head><body>Content</body></html>`, {
  url: "http://www.example.com/foo.html",
  runScripts: "dangerously",
  resources: new MyResourceLoader(),
});

I believe the problem here is that RequestManager.close assumes existence of an abort method even though the README.md only requires that

It must return a promise for a Node.js Buffer object, or return null

abort doesn’t seem to be part of the Promise API. So perhaps that call should be guarded behind a check if (typeof openedRequest.abort === "function") or some such.

Since the handler for the data protocol in ResourceLoader.fetch does use Promise.resolve as well, the original issue is essentially the same. But fixing this inside the ResourceLoader implementation, as the current draft of #2678 does, will not fix things for custom implementations like the one above.

3reactions
somewhatabstractcommented, Nov 25, 2019

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 calling abort() on each one. However, since that’s not necessarily a call on every promise (it is on fetch requests made via superagent), 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

Read more comments on GitHub >

github_iconTop 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 >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found