[njs] Tests: added TypedArray test for js_filter in stream.
noreply at nginx.com
noreply at nginx.com
Wed Aug 27 01:59:41 UTC 2025
details: https://github.com/nginx/njs/commit/b6fd8ebc8b5bdc36ba1147cfd51bfedc72fc6a3b
branches: master
commit: b6fd8ebc8b5bdc36ba1147cfd51bfedc72fc6a3b
user: Dmitry Volyntsev <xeioex at nginx.com>
date: Tue, 19 Aug 2025 17:16:22 -0700
description:
Tests: added TypedArray test for js_filter in stream.
---
nginx/t/stream_js_buffer.t | 77 ++++++++++++++++++++++++++++++++++++++++++++--
1 file changed, 75 insertions(+), 2 deletions(-)
diff --git a/nginx/t/stream_js_buffer.t b/nginx/t/stream_js_buffer.t
index cc960136..be6569f2 100644
--- a/nginx/t/stream_js_buffer.t
+++ b/nginx/t/stream_js_buffer.t
@@ -91,6 +91,12 @@ stream {
js_filter test.header_inject;
proxy_pass 127.0.0.1:8080;
}
+
+ server {
+ listen 127.0.0.1:8086;
+ js_filter test.typed_array_send;
+ proxy_pass 127.0.0.1:8090;
+ }
}
EOF
@@ -150,12 +156,26 @@ $t->write_file('test.js', <<EOF);
});
}
+ function typed_array_send(s) {
+ s.on('upstream', function (data, flags) {
+ var buf = new Uint8Array([72, 101, 108, 108, 111]);
+ var view1 = buf.subarray(1, 4);
+ var view2 = buf.subarray(2);
+
+ s.sendUpstream(view1);
+ s.sendUpstream(view2);
+ s.off('upstream');
+ });
+ }
+
export default {njs: test_njs, type, binary_var, cb_mismatch, cb_mismatch2,
- header_inject};
+ header_inject, typed_array_send};
EOF
-$t->try_run('no njs ngx')->plan(5);
+$t->run_daemon(\&stream_daemon, port(8090));
+$t->try_run('no njs ngx')->plan(6);
+$t->waitforsocket('127.0.0.1:' . port(8090));
###############################################################################
@@ -167,6 +187,9 @@ stream('127.0.0.1:' . port(8084))->io('x');
like(http_get('/p/return'), qr/RETURN:foo/, 'injected header');
+is(stream('127.0.0.1:' . port(8086))->io('x', length => 6), 'ellllo',
+ 'typed array send');
+
$t->stop();
ok(index($t->read_file('error.log'), 'cb_mismatch:mixing string and buffer')
@@ -175,3 +198,53 @@ ok(index($t->read_file('error.log'), 'cb_mismatch2:mixing string and buffer')
> 0, 'cb mismatch');
###############################################################################
+
+sub stream_daemon {
+ my $server = IO::Socket::INET->new(
+ Proto => 'tcp',
+ LocalAddr => '127.0.0.1:' . port(8090),
+ Listen => 5,
+ Reuse => 1
+ )
+ or die "Can't create listening socket: $!\n";
+
+ local $SIG{PIPE} = 'IGNORE';
+
+ while (my $client = $server->accept()) {
+ $client->autoflush(1);
+
+ log2c("(new connection $client)");
+
+ while (1) {
+ my $bytes_read = $client->sysread(my $buffer, 65536);
+
+ if (!defined $bytes_read) {
+ log2c("Read error from $client: $!");
+ last;
+
+ } elsif ($bytes_read == 0) {
+ log2c("Client $client disconnected");
+ last;
+ }
+
+ log2i("$client $buffer");
+
+ my $bytes_written = $client->syswrite($buffer);
+
+ if (!defined $bytes_written || $bytes_written != length($buffer)) {
+ log2c("Write error to $client: $!");
+ last;
+ }
+
+ log2o("$client $buffer");
+ }
+
+ close $client;
+ }
+}
+
+sub log2i { Test::Nginx::log_core('|| <<', @_); }
+sub log2o { Test::Nginx::log_core('|| >>', @_); }
+sub log2c { Test::Nginx::log_core('||', @_); }
+
+###############################################################################
More information about the nginx-devel
mailing list