Download
Download objects are dispatched by page via the page.on('download') event.
All the downloaded files belonging to the browser context are deleted when the browser context is closed.
Download event is emitted once the download starts. Download path becomes available once download completes:
const [ download ] = await Promise.all([ page.waitForEvent('download'), // wait for download to start page.click('a')]);// wait for download to completeconst path = await download.path();
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, download events are emitted, but the actual download is not performed and user has no access to the downloaded files.
- download.cancel()
- download.createReadStream()
- download.delete()
- download.failure()
- download.page()
- download.path()
- download.saveAs(path)
- download.suggestedFilename()
- download.url()
#
download.cancel()Cancels a download. Will not fail if the download is already finished or canceled. Upon successful cancellations, download.failure()
would resolve to 'canceled'
.
#
download.createReadStream()Returns readable stream for current download or null
if download failed.
#
download.delete()Deletes the downloaded file. Will wait for the download to finish if necessary.
#
download.failure()Returns download error if any. Will wait for the download to finish if necessary.
#
download.page()Get the page that the download belongs to.
#
download.path()Returns path to the downloaded file in case of successful download. The method will wait for the download to finish if necessary. The method throws when connected remotely.
Note that the download's file name is a random GUID, use download.suggestedFilename() to get suggested file name.
#
download.saveAs(path)Copy the download to a user-specified path. It is safe to call this method while the download is still in progress. Will wait for the download to finish if necessary.
#
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.