File: 102-req-start-time.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 (115 lines) | stat: -rw-r--r-- 2,006 bytes parent folder | download | duplicates (3)
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
107
108
109
110
111
112
113
114
115
# -*- mode: conf -*-
# vim:set ft= ts=4 sw=4 et fdm=marker:

use Test::Nginx::Socket::Lua;

#worker_connections(1014);
#master_process_enabled(1);
log_level('warn');

repeat_each(2);

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

#no_diff();
no_long_string();
run_tests();

__DATA__

=== TEST 1: start time
--- config
    location = /start {
        content_by_lua 'ngx.say(ngx.req.start_time())';
    }
--- request
GET /start
--- response_body_like: ^\d{10,}(\.\d+)?$
--- no_error_log
[error]



=== TEST 2: start time in set_by_lua
--- config
    location = /start {
        set_by_lua $a 'return ngx.req.start_time()';
        echo $a;
    }
--- request
GET /start
--- response_body_like: ^\d{10,}(\.\d+)?$
--- no_error_log
[error]



=== TEST 3: request time
--- config
    location = /req_time {
        content_by_lua '
            ngx.sleep(0.1)

            local req_time = ngx.now() - ngx.req.start_time()

            ngx.say(req_time)
            ngx.say(ngx.req.start_time() < ngx.now())
        ';
    }
--- request
GET /req_time
--- response_body_like chop
^(?:0\.[12]|0\.099)\d*
true$
--- no_error_log
[error]



=== TEST 4: request time update
--- config
    location = /req_time {
            content_by_lua '
               ngx.sleep(0.1)

               local req_time = ngx.now() - ngx.req.start_time()

               ngx.sleep(0.1)

               ngx.update_time()

               local req_time_updated = ngx.now() - ngx.req.start_time()

               ngx.say(req_time)
               ngx.say(req_time_updated)
               ngx.say(req_time_updated > req_time)
            ';
    }
--- request
GET /req_time
--- response_body_like chomp
^(?:0\.[12]|0\.099)\d*
0\.\d+
true$
--- no_error_log
[error]



=== TEST 5: init_by_lua
--- http_config
    init_by_lua '
        time = ngx.req.start_time()
    ';
--- config
    location = /t {
        content_by_lua '
            ngx.say(time)
        ';
    }
--- request
    GET /t
--- response_body
--- no_error_log
[error]
--- SKIP