File: 064-pcall.t

package info (click to toggle)
nginx 1.18.0-6.1%2Bdeb11u3
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 19,344 kB
  • sloc: ansic: 250,653; perl: 7,548; sh: 1,408; ruby: 879; python: 358; makefile: 338; awk: 36; cpp: 18
file content (106 lines) | stat: -rw-r--r-- 2,432 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
# vim:set ft= ts=4 sw=4 et fdm=marker:
use Test::Nginx::Socket::Lua;

worker_connections(1014);
#master_on();
#workers(4);
#log_level('warn');
no_root_location();

repeat_each(2);

plan tests => repeat_each() * (blocks() * 3);

our $HtmlDir = html_dir;

#$ENV{LUA_CPATH} = "/usr/local/openresty/lualib/?.so;" . $ENV{LUA_CPATH};

no_long_string();
run_tests();

__DATA__

=== TEST 1: pcall works
--- http_config eval
    "lua_package_path '$::HtmlDir/?.lua;./?.lua';"
--- config
        location = /test {
            content_by_lua '
                function f(a, b)
                    if a == 0 and b == 0 then
                        error("zero error")
                    end

                    return 23, "hello", true
                end

                local res = {pcall(f, 0, 0)}
                ngx.say("res len: ", #res)
                ngx.say("res: ", unpack(res))

                res = {pcall(f, 0)}
                ngx.say("res len: ", #res)
                ngx.say("res: ", unpack(res))
            ';
        }
--- request
GET /test
--- response_body eval
qr/^res len: 2
res: falsecontent_by_lua\(nginx\.conf:\d+\):4: zero error
res len: 4
res: true23hellotrue
$/s
--- no_error_log
[error]



=== TEST 2: xpcall works
--- http_config eval
    "lua_package_path '$::HtmlDir/?.lua;./?.lua';"
--- config
        location = /test {
            content_by_lua '
                function f(a, b)
                    if a == 0 and b == 0 then
                        error("zero error")
                    end

                    return 23, "hello", true
                end

                function g()
                    return f(0, 0)
                end

                function h()
                    return f(0)
                end

                function err(...)
                    ngx.say("error handler called: ", ...)
                    return "this is the new err"
                end

                local res = {xpcall(g, err)}
                ngx.say("res len: ", #res)
                ngx.say("res: ", unpack(res))

                res = {xpcall(h, err)}
                ngx.say("res len: ", #res)
                ngx.say("res: ", unpack(res))
            ';
        }
--- request
GET /test
--- response_body eval
qr/^error handler called: content_by_lua\(nginx\.conf:\d+\):4: zero error
res len: 2
res: falsethis is the new err
res len: 4
res: true23hellotrue
$/

--- no_error_log
[error]