class: Download

Download objects are dispatched by page via the ‘download’ event.

All the downloaded files belonging to the browser context are deleted when the browser context is closed. All downloaded files are deleted when the browser closes.

Download event is emitted once the download starts. Download path becomes available once download completes:

  1. const [ download ] = await Promise.all([
  2. page.waitForEvent('download'), // wait for download to start
  3. page.click('a')
  4. ]);
  5. // wait for download to complete
  6. const path = await download.path();
  7. ...

NOTE Browser context must be created with the acceptDownloads set to true when user needs access to the downloaded content. If acceptDownloads is not set or set to false, download events are emitted, but the actual download is not performed and user has no access to the downloaded files.

download.createReadStream()

Returns readable stream for current download or null if download failed.

download.delete()

Deletes the downloaded file.

download.failure()

Returns download error if any.

download.path()

Returns path to the downloaded file in case of successful download.

download.suggestedFilename()

Returns suggested filename for this download. It is typically computed by the browser from the Content-Disposition response header or the download attribute. See the spec on whatwg. Different browsers can use different logic for computing it.

download.url()

Returns downloaded url.