annotate post_action.t @ 540:481d705b8610

Tests: SSL support in mail backends. Socket is now embedded into every mail module. Socket methods are wrapped where appropriate. The new "SSL" extra flag specifies to accept connection over SSL.
author Sergey Kandaurov <pluknet@nginx.com>
date Fri, 03 Apr 2015 00:11:38 +0300
parents 34280f6b0bc6
children 56c3a8310076
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
453
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
1 #!/usr/bin/perl
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
2
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
3 # (C) Maxim Dounin
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
4 # (C) Nginx, Inc.
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
5
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
6 # Tests for nginx post_action directive.
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
7
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
8 ###############################################################################
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
9
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
10 use warnings;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
11 use strict;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
12
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
13 use Test::More;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
14
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
15 BEGIN { use FindBin; chdir($FindBin::Bin); }
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
16
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
17 use lib 'lib';
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
18 use Test::Nginx;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
19
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
20 ###############################################################################
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
21
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
22 select STDERR; $| = 1;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
23 select STDOUT; $| = 1;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
24
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
25 my $t = Test::Nginx->new()->has(qw/http proxy/)->plan(6);
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
26
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
27 $t->write_file_expand('nginx.conf', <<'EOF');
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
28
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
29 %%TEST_GLOBALS%%
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
30
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
31 daemon off;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
32
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
33 events {
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
34 }
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
35
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
36 http {
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
37 %%TEST_GLOBALS_HTTP%%
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
38
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
39 server {
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
40 listen 127.0.0.1:8080;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
41 server_name localhost;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
42
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
43 location / {
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
44 post_action /post.html;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
45 }
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
46
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
47 location /post.html {
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
48 # static
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
49 }
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
50
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
51 location /remote {
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
52 post_action /post.remote;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
53 }
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
54
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
55 location /post.remote {
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
56 proxy_pass http://127.0.0.1:8080/post.html;
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
57 }
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
58 }
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
59 }
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
60
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
61 EOF
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
62
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
63 $t->write_file('index.html', 'SEE-THIS');
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
64 $t->write_file('post.html', 'HIDDEN');
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
65 $t->write_file('remote', 'SEE-THIS');
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
66
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
67 $t->run();
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
68
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
69 ###############################################################################
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
70
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
71 like(http_get('/'), qr/SEE-THIS/m, 'post action');
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
72 unlike(http_get('/'), qr/HIDDEN/m, 'no additional body');
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
73
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
74 like(http_get('/remote'), qr/SEE-THIS/m, 'post action proxy');
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
75 unlike(http_get('/remote'), qr/HIDDEN/m, 'no additional body proxy');
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
76
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
77 $t->stop();
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
78
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
79 like(`cat ${\($t->testdir())}/access.log`, qr/post/, 'post action in logs');
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
80
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
81 TODO: {
506
5baf4b01cae4 Tests: adjusted TODOs.
Maxim Dounin <mdounin@mdounin.ru>
parents: 453
diff changeset
82 local $TODO = 'broken in 1.5.4' unless $t->has_version('1.7.8');
453
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
83
507
34280f6b0bc6 Tests: trailing spaces.
Maxim Dounin <mdounin@mdounin.ru>
parents: 506
diff changeset
84 # the r->header_sent check in 1.5.4+ results in
453
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
85 # "header already sent" alerts
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
86
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
87 like(`grep -F '[alert]' ${\($t->testdir())}/error.log`, qr/^$/s, 'no alerts');
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
88
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
89 }
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
90
baae3ed4ad09 Tests: post_action tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
91 ###############################################################################