Welcome! Log In Create A New Profile

Advanced

[njs] Fixed njs_run expect tests.

Dmitry Volyntsev
June 14, 2019 02:22PM
details: https://hg.nginx.org/njs/rev/c3a70f0f6cdc
branches:
changeset: 1006:c3a70f0f6cdc
user: Dmitry Volyntsev <xeioex@nginx.com>
date: Fri Jun 14 21:20:25 2019 +0300
description:
Fixed njs_run expect tests.

Using exec instead of spawn to get the njs output
synchronously.

diffstat:

njs/njs_shell.c | 2 +-
njs/test/njs_expect_test.exp | 35 +++++++++++++++++++----------------
2 files changed, 20 insertions(+), 17 deletions(-)

diffs (97 lines):

diff -r fb9621798309 -r c3a70f0f6cdc njs/njs_shell.c
--- a/njs/njs_shell.c Fri Jun 14 21:19:52 2019 +0300
+++ b/njs/njs_shell.c Fri Jun 14 21:20:25 2019 +0300
@@ -327,7 +327,7 @@ njs_get_options(njs_opts_t *opts, int ar
switch (*p) {
case '?':
case 'h':
- (void) write(STDIN_FILENO, help, nxt_length(help));
+ (void) write(STDOUT_FILENO, help, nxt_length(help));
return ret;

case 'c':
diff -r fb9621798309 -r c3a70f0f6cdc njs/test/njs_expect_test.exp
--- a/njs/test/njs_expect_test.exp Fri Jun 14 21:19:52 2019 +0300
+++ b/njs/test/njs_expect_test.exp Fri Jun 14 21:20:25 2019 +0300
@@ -42,9 +42,11 @@ type console.help() for more information
expect eof
}

-proc njs_run {opts output} {
- eval spawn -nottycopy njs $opts
- expect -re $output
+proc njs_run {opts expected_re} {
+ catch {exec njs {*}$opts} out
+ if {[regexp $expected_re $out match] == 0} {
+ return -code error "njs_run: unexpected output '$out' vs '$expected_re'"
+ }
}

njs_test {
@@ -625,35 +627,36 @@ njs_test {

# Modules

-njs_run "-p njs/test/module/libs ./njs/test/module/normal.js" \
+njs_run {"-p" "njs/test/module/libs" "./njs/test/module/normal.js"} \
"passed!"

-njs_run "-p njs/test/module/libs/ ./njs/test/module/normal.js" \
+njs_run {"-p" "njs/test/module/libs/" "./njs/test/module/normal.js"} \
"passed!"

-njs_run "-p njs/test/module -p njs/test/module/libs ./njs/test/module/normal.js" \
+njs_run {"-p" "njs/test/module" "-p" "njs/test/module/libs" "./njs/test/module/normal.js"} \
"passed!"

-njs_run "./njs/test/module/normal.js" \
+njs_run {"./njs/test/module/normal.js"} \
"SyntaxError: Cannot find module \"hash.js\" in sub2.js:5"

-njs_run "-p njs/test/module/libs ./njs/test/module/exception.js" \
- "at error \\(sub1.js:5\\)\r\n at exception \\(lib3.js:5\\)"
+njs_run {"-p" "njs/test/module/libs" "./njs/test/module/exception.js"} \
+ "at error \\(sub1.js:5\\)"

-njs_run "-p njs/test/module ./njs/test/module/recursive.js" \
+njs_run {"-p" "njs/test/module" "./njs/test/module/recursive.js"} \
"SyntaxError: Cannot import itself \"./recursive.js\" in recursive.js:3"

# CLI OPTIONS

# help

-njs_run "-h" "Interactive njs shell.\r\n\r\nOptions:"
+njs_run {"-h"} "Options"

# command

-njs_run "-c 'console.log(\"a b c\")'" "a b c"
+njs_run {"-c" "console.log(\"a b c\")"} "a b c"

-njs_run "-c 'console.log('" "SyntaxError: Unexpected token \"\" in string:1"
+njs_run {"-c" "console.log("} "SyntaxError: Unexpected end of input in string:1"
+

# disassemble

@@ -720,10 +723,10 @@ njs_test {
"12\r\n"}
} "-p njs/test/module/"

-njs_run "-q ./njs/test/module/normal.js" \
+njs_run {"-q" "./njs/test/module/normal.js"} \
"SyntaxError: Cannot find module \"hash.js\" in 5"

-njs_run "-p njs/test/module/libs/ -d ./njs/test/module/normal.js" \
+njs_run {"-p" "njs/test/module/libs/" "-d" "./njs/test/module/normal.js"} \
"passed!"

# sandboxing
@@ -756,5 +759,5 @@ njs_test {

# version

-njs_run "-v" "\\d+\.\\d+\.\\d+"
+njs_run {"-v"} "\\d+\.\\d+\.\\d+"

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

[njs] Fixed njs_run expect tests.

Dmitry Volyntsev 314 June 14, 2019 02:22PM



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

Online Users

Guests: 245
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