Welcome! Log In Create A New Profile

Advanced

[njs] Tests: adapting fs tests introduced in 685adce92af1 for various OS.

Dmitry Volyntsev
November 10, 2021 09:54AM
details: https://hg.nginx.org/njs/rev/dedadba0ee87
branches:
changeset: 1742:dedadba0ee87
user: Dmitry Volyntsev <xeioex@nginx.com>
date: Wed Nov 10 14:50:16 2021 +0000
description:
Tests: adapting fs tests introduced in 685adce92af1 for various OS.

diffstat:

test/fs/methods.js | 68 +++++++++++++++++++++++++++++++++++++++++++----------
1 files changed, 55 insertions(+), 13 deletions(-)

diffs (113 lines):

diff -r 2b07f8810d31 -r dedadba0ee87 test/fs/methods.js
--- a/test/fs/methods.js Tue Nov 09 17:59:58 2021 +0000
+++ b/test/fs/methods.js Wed Nov 10 14:50:16 2021 +0000
@@ -188,7 +188,7 @@ async function write_test(params) {

try { fs.unlinkSync(fname); } catch (e) {}

- let data = await method("writeFile", params);
+ let data = await method("writeFile", params).catch(e => ({error:e}));

if (!data) {
data = fs.readFileSync(fname);
@@ -196,8 +196,18 @@ async function write_test(params) {

try { fs.unlinkSync(fname); } catch (e) {}

- if (data.compare(params.expected) != 0) {
- throw Error(`writeFile unexpected data`);
+ if (params.check) {
+ if (!params.check(data, params)) {
+ throw Error(`writeFile failed check`);
+ }
+
+ } else if (params.exception) {
+ throw data.error;
+
+ } else {
+ if (data.compare(params.expected) != 0) {
+ throw Error(`writeFile unexpected data`);
+ }
}

return 'SUCCESS';
@@ -219,9 +229,20 @@ let write_tests = [
{ args: ["@", "eHl6", {encoding: "base64url"}], expected: Buffer.from("xyz"),
optional: true },
{ args: ["@", Symbol("XYZ")], exception: "TypeError: Cannot convert a Symbol value to a string"},
- { args: ["/invalid_path", "XYZ"], stringify: true,
- expected: Buffer.from('{"errno":13,"code":"EACCES","path":"/invalid_path","syscall":"open"}'),
- exception: "Error: No such file or directory" },
+ { args: ["/invalid_path", "XYZ"],
+ check: (err, params) => {
+ let e = err.error;
+
+ if (e.syscall != 'open') {
+ throw Error(`${e.syscall} unexpected syscall`);
+ }
+
+ if (e.code != "EACCES" && e.code != "EROFS") {
+ throw Error(`${e.code} unexpected code`);
+ }
+
+ return true;
+ } },
];

let writeFile_tsuite = {
@@ -253,8 +274,8 @@ async function append_test(params) {

try { fs.unlinkSync(fname); } catch (e) {}

- let data = await method("appendFile", params);
- data = await method("appendFile", params);
+ let data = await method("appendFile", params).catch(e => ({error:e}));
+ data = await method("appendFile", params).catch(e => ({error:e}));

if (!data) {
data = fs.readFileSync(fname);
@@ -262,8 +283,18 @@ async function append_test(params) {

try { fs.unlinkSync(fname); } catch (e) {}

- if (data.compare(params.expected) != 0) {
- throw Error(`appendFile unexpected data`);
+ if (params.check) {
+ if (!params.check(data, params)) {
+ throw Error(`appendFile failed check`);
+ }
+
+ } else if (params.exception) {
+ throw data.error;
+
+ } else {
+ if (data.compare(params.expected) != 0) {
+ throw Error(`appendFile unexpected data`);
+ }
}

return 'SUCCESS';
@@ -285,9 +316,20 @@ let append_tests = [
{ args: ["@", "eHl6", {encoding: "base64url"}], expected: Buffer.from("xyzxyz"),
optional: true },
{ args: ["@", Symbol("XYZ")], exception: "TypeError: Cannot convert a Symbol value to a string"},
- { args: ["/invalid_path", "XYZ"], stringify: true,
- expected: Buffer.from('{"errno":13,"code":"EACCES","path":"/invalid_path","syscall":"open"}'),
- exception: "Error: No such file or directory" },
+ { args: ["/invalid_path", "XYZ"],
+ check: (err, params) => {
+ let e = err.error;
+
+ if (e.syscall != 'open') {
+ throw Error(`${e.syscall} unexpected syscall`);
+ }
+
+ if (e.code != "EACCES" && e.code != "EROFS") {
+ throw Error(`${e.code} unexpected code`);
+ }
+
+ return true;
+ } },
];

let appendFile_tsuite = {
_______________________________________________
nginx-devel mailing list
nginx-devel@nginx.org
http://mailman.nginx.org/mailman/listinfo/nginx-devel
Subject Author Views Posted

[njs] Tests: adapting fs tests introduced in 685adce92af1 for various OS.

Dmitry Volyntsev 392 November 10, 2021 09:54AM



Sorry, you do not have permission to post/reply in this forum.

Online Users

Guests: 276
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready