annotate js_async.t @ 1738:9e0347f4df11

Tests: added js tests for async functions.
author Dmitry Volyntsev <xeioex@nginx.com>
date Mon, 11 Oct 2021 14:34:54 +0000
parents 9d8b100a6ce3
children 18ac4d9e5a2a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
1 #!/usr/bin/perl
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
2
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
3 # (C) Dmitry Volyntsev
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
4 # (C) Nginx, Inc.
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
5
1375
f168fc46c7a4 Tests: renamed JavaScript to njs.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1304
diff changeset
6 # Async tests for http njs module.
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
7
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
8 ###############################################################################
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
9
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
10 use warnings;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
11 use strict;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
12
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
13 use Test::More;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
14
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
15 BEGIN { use FindBin; chdir($FindBin::Bin); }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
16
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
17 use lib 'lib';
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
18 use Test::Nginx;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
19
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
20 ###############################################################################
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
21
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
22 select STDERR; $| = 1;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
23 select STDOUT; $| = 1;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
24
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
25 my $t = Test::Nginx->new()->has(qw/http rewrite/)
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
26 ->write_file_expand('nginx.conf', <<'EOF');
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
27
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
28 %%TEST_GLOBALS%%
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
29
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
30 daemon off;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
31
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
32 events {
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
33 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
34
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
35 http {
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
36 %%TEST_GLOBALS_HTTP%%
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
37
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
38 js_set $test_async set_timeout;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
39 js_set $context_var context_var;
1738
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
40 js_set $test_set_rv_var set_rv_var;
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
41
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
42 js_include test.js;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
43
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
44 server {
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
45 listen 127.0.0.1:8080;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
46 server_name localhost;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
47
1738
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
48 location /njs {
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
49 js_content test_njs;
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
50 }
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
51
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
52 location /async_var {
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
53 return 200 $test_async;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
54 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
55
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
56 location /shared_ctx {
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
57 add_header H $context_var;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
58 js_content shared_ctx;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
59 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
60
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
61 location /set_timeout {
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
62 js_content set_timeout;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
63 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
64
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
65 location /set_timeout_many {
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
66 js_content set_timeout_many;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
67 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
68
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
69 location /set_timeout_data {
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
70 postpone_output 0;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
71 js_content set_timeout_data;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
72 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
73
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
74 location /limit_rate {
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
75 postpone_output 0;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
76 sendfile_max_chunk 5;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
77 js_content limit_rate;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
78 }
1738
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
79
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
80 location /async_content {
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
81 js_content async_content;
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
82 }
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
83
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
84 location /set_rv_var {
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
85 return 200 $test_set_rv_var;
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
86 }
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
87 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
88 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
89
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
90 EOF
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
91
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
92 $t->write_file('test.js', <<EOF);
1738
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
93 function test_njs(r) {
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
94 r.return(200, njs.version);
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
95 }
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
96
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
97 function set_timeout(r) {
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
98 var timerId = setTimeout(timeout_cb_r, 5, r, 0);
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
99 clearTimeout(timerId);
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
100 setTimeout(timeout_cb_r, 5, r, 0)
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
101 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
102
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
103 function set_timeout_data(r) {
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
104 setTimeout(timeout_cb_data, 5, r, 0);
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
105 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
106
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
107 function set_timeout_many(r) {
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
108 for (var i = 0; i < 5; i++) {
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
109 setTimeout(timeout_cb_empty, 5, r, i);
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
110 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
111
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
112 setTimeout(timeout_cb_reply, 10, r);
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
113 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
114
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
115 function timeout_cb_r(r, cnt) {
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
116 if (cnt == 10) {
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
117 r.status = 200;
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
118 r.headersOut['Content-Type'] = 'foo';
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
119 r.sendHeader();
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
120 r.finish();
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
121
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
122 } else {
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
123 setTimeout(timeout_cb_r, 5, r, ++cnt);
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
124 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
125 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
126
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
127 function timeout_cb_empty(r, arg) {
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
128 r.log("timeout_cb_empty" + arg);
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
129 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
130
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
131 function timeout_cb_reply(r) {
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
132 r.status = 200;
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
133 r.headersOut['Content-Type'] = 'reply';
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
134 r.sendHeader();
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
135 r.finish();
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
136 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
137
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
138 function timeout_cb_data(r, counter) {
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
139 if (counter == 0) {
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
140 r.log("timeout_cb_data: init");
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
141 r.status = 200;
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
142 r.sendHeader();
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
143 setTimeout(timeout_cb_data, 5, r, ++counter);
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
144
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
145 } else if (counter == 10) {
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
146 r.log("timeout_cb_data: finish");
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
147 r.finish();
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
148
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
149 } else {
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
150 r.send("" + counter);
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
151 setTimeout(timeout_cb_data, 5, r, ++counter);
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
152 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
153 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
154
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
155 var js_;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
156 function context_var() {
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
157 return js_;
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
158 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
159
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
160 function shared_ctx(r) {
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
161 js_ = r.variables.arg_a;
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
162
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
163 r.status = 200;
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
164 r.sendHeader();
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
165 r.finish();
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
166 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
167
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
168 function limit_rate_cb(r) {
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
169 r.finish();
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
170 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
171
1436
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
172 function limit_rate(r) {
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
173 r.status = 200;
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
174 r.sendHeader();
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
175 r.send("AAAAA".repeat(10))
9d8b100a6ce3 Tests: get rid of deprecated njs API in 0.2.2.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1375
diff changeset
176 setTimeout(limit_rate_cb, 1000, r);
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
177 }
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
178
1738
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
179 function pr(x) {
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
180 return new Promise(resolve => {resolve(x)}).then(v => v).then(v => v);
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
181 }
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
182
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
183 async function async_content(r) {
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
184 const a1 = await pr('A');
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
185 const a2 = await pr('B');
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
186
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
187 r.return(200, `retval: \${a1 + a2}`);
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
188 }
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
189
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
190 async function set_rv_var(r) {
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
191 const a1 = await pr(10);
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
192 const a2 = await pr(20);
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
193
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
194 r.setReturnValue(`retval: \${a1 + a2}`);
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
195 }
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
196
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
197 EOF
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
198
1738
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
199 $t->try_run('no njs available')->plan(9);
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
200
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
201 ###############################################################################
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
202
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
203 like(http_get('/set_timeout'), qr/Content-Type: foo/, 'setTimeout');
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
204 like(http_get('/set_timeout_many'), qr/Content-Type: reply/, 'setTimeout many');
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
205 like(http_get('/set_timeout_data'), qr/123456789/, 'setTimeout data');
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
206 like(http_get('/shared_ctx?a=xxx'), qr/H: xxx/, 'shared context');
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
207 like(http_get('/limit_rate'), qr/A{50}/, 'limit_rate');
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
208
1738
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
209 TODO: {
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
210 local $TODO = 'not yet'
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
211 unless http_get('/njs') =~ /^([.0-9]+)$/m && $1 ge '0.7.0';
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
212
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
213 like(http_get('/async_content'), qr/retval: AB/, 'async content');
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
214 like(http_get('/set_rv_var'), qr/retval: 30/, 'set return value variable');
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
215
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
216 }
9e0347f4df11 Tests: added js tests for async functions.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 1436
diff changeset
217
1304
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
218 http_get('/async_var');
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
219
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
220 $t->stop();
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
221
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
222 ok(index($t->read_file('error.log'), 'pending events') > 0,
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
223 'pending js events');
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
224 ok(index($t->read_file('error.log'), 'async operation inside') > 0,
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
225 'async op in var handler');
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
226
25de201c8a0d Tests: added njs async tests.
Dmitry Volyntsev <xeioex@nginx.com>
parents:
diff changeset
227 ###############################################################################