Mercurial > hg > nginx-tests
view ssi_waited.t @ 289:cbd4f6eca676
Tests: check if started process is alive while starting nginx.
This allows faster test execution in case of startup failures, e.g.
due to configuration errors. Note that just adding waitpid() to
waitforfile() causes hang on win32 in wait(). To fix this, wait()
calls were changed to waitpid() with pid specified.
author | Maxim Dounin <mdounin@mdounin.ru> |
---|---|
date | Mon, 27 May 2013 17:15:17 +0400 |
parents | 6a0d934950bc |
children | 6c0a5903d0ae |
line wrap: on
line source
#!/usr/bin/perl # (C) Maxim Dounin # Tests for nginx ssi module, waited subrequests. ############################################################################### use warnings; use strict; use Test::More; BEGIN { use FindBin; chdir($FindBin::Bin); } use lib 'lib'; use Test::Nginx; ############################################################################### select STDERR; $| = 1; select STDOUT; $| = 1; my $t = Test::Nginx->new()->has(qw/http ssi/)->plan(2); $t->write_file_expand('nginx.conf', <<'EOF'); %%TEST_GLOBALS%% daemon off; events { } http { %%TEST_GLOBALS_HTTP%% server { listen 127.0.0.1:8080; server_name localhost; location / { ssi on; } } } EOF $t->write_file('index.html', 'x<!--#include virtual="/first.html" -->' . 'x<!--#include virtual="/second.html" -->x'); $t->write_file('first.html', 'FIRST'); $t->write_file('second.html', '<!--#include virtual="/waited.html" wait="yes"-->xSECOND'); $t->write_file('waited.html', 'WAITED'); $t->run(); ############################################################################### like(http_get('/'), qr/^xFIRSTxWAITEDxSECONDx$/m, 'waited non-active'); like(`grep -F '[alert]' ${\($t->testdir())}/error.log`, qr/^$/s, 'no alerts'); ###############################################################################