diff --git a/test/driver.js b/test/driver.js index c79c30601380e..8ba30b0bfd3ce 100644 --- a/test/driver.js +++ b/test/driver.js @@ -782,7 +782,7 @@ class Driver { } } - if (task.skipPages && task.skipPages.includes(task.pageNum)) { + if (task.skipPages?.includes(task.pageNum)) { this._log( " Skipping page " + task.pageNum + "/" + task.pdfDoc.numPages + "...\n" ); diff --git a/test/test.mjs b/test/test.mjs index c6d3ccf44308e..4d16c8ea1e656 100644 --- a/test/test.mjs +++ b/test/test.mjs @@ -161,7 +161,7 @@ function parseOptions() { ); }) .check(argv => { - if (argv.testfilter && argv.testfilter.length > 0 && argv.xfaOnly) { + if (argv.testfilter?.length > 0 && argv.xfaOnly) { throw new Error("--testfilter and --xfaOnly cannot be used together."); } return true; diff --git a/test/unit/test_utils.js b/test/unit/test_utils.js index bc1d839d5eadd..507fc15649f48 100644 --- a/test/unit/test_utils.js +++ b/test/unit/test_utils.js @@ -45,15 +45,8 @@ class DOMFileReaderFactory { class NodeFileReaderFactory { static async fetch(params) { - return new Promise((resolve, reject) => { - fs.readFile(params.path, (error, data) => { - if (error || !data) { - reject(error || new Error(`Empty file for: ${params.path}`)); - return; - } - resolve(new Uint8Array(data)); - }); - }); + const data = await fs.promises.readFile(params.path); + return new Uint8Array(data); } } @@ -152,33 +145,34 @@ function createTemporaryNodeServer() { const server = http .createServer((request, response) => { const filePath = process.cwd() + "/test/pdfs" + request.url; - fs.lstat(filePath, (error, stat) => { - if (error) { + fs.promises.lstat(filePath).then( + stat => { + if (!request.headers.range) { + const contentLength = stat.size; + const stream = fs.createReadStream(filePath); + response.writeHead(200, { + "Content-Type": "application/pdf", + "Content-Length": contentLength, + "Accept-Ranges": "bytes", + }); + stream.pipe(response); + } else { + const [start, end] = request.headers.range + .split("=")[1] + .split("-") + .map(x => Number(x)); + const stream = fs.createReadStream(filePath, { start, end }); + response.writeHead(206, { + "Content-Type": "application/pdf", + }); + stream.pipe(response); + } + }, + error => { response.writeHead(404); response.end(`File ${request.url} not found!`); - return; - } - if (!request.headers.range) { - const contentLength = stat.size; - const stream = fs.createReadStream(filePath); - response.writeHead(200, { - "Content-Type": "application/pdf", - "Content-Length": contentLength, - "Accept-Ranges": "bytes", - }); - stream.pipe(response); - } else { - const [start, end] = request.headers.range - .split("=")[1] - .split("-") - .map(x => Number(x)); - const stream = fs.createReadStream(filePath, { start, end }); - response.writeHead(206, { - "Content-Type": "application/pdf", - }); - stream.pipe(response); } - }); + ); }) .listen(0); /* Listen on a random free port */