Mojolicious-Plugin-SetUserGroup

 view release on metacpan or  search on metacpan

xt/author/setfail_prefork.t  view on Meta::CPAN

use strict;
use warnings;
use Test::More;
use Mojo::Asset::File;
use Mojo::IOLoop;
use Mojo::Server::Prefork;
use POSIX qw(getuid getgid geteuid :sys_wait_h);
use Time::HiRes 'usleep';

plan skip_all => 'Non-root test' if geteuid() == 0;

my $uid = getuid();
my $gid = getgid();
my $user = getpwuid 0;
my $group = getgrgid 0;

plan skip_all => 'User 0 does not exist' unless defined $user;
plan skip_all => 'Group 0 does not exist' unless defined $group;

my $templog = Mojo::Asset::File->new;
$templog->handle; # setup temp file path

defined(my $pid = fork) or die "Fork failed: $!";

unless ($pid) { # child
	my $daemon = Mojo::Server::Prefork->new(listen => ['http://127.0.0.1'], silent => 1);
	$daemon->app->log->path($templog->path);
	$daemon->app->plugin(SetUserGroup => {user => $user, group => $group});
	
	Mojo::IOLoop->timer(0.5 => sub { $daemon->app->log->error("Test worker has started"); Mojo::IOLoop->stop });
	{ open my $null, '>', '/dev/null'; local *STDERR = $null; $daemon->run; }
	exit 0;
}

my $completed;
for my $i (1..10) {
	if (waitpid $pid, WNOHANG > 0) {
		$completed = 1;
		last;
	}
	usleep 100000;
}

ok $completed, 'Prefork server stopped on worker failure';

unless ($completed) {
	kill 'TERM', $pid or die "Failed to kill prefork server: $!";
	waitpid $pid, 0;
}

my $log = $templog->slurp;
unlike $log, qr/Test worker has started/, 'Workers failed to start';
like $log, qr/Can't (switch to (user|group)|set supplemental groups)/, 'right error';
cmp_ok getuid(), '==', $uid, 'User has not changed';
cmp_ok getgid(), '==', $gid, 'Group has not changed';

done_testing;



( run in 0.547 second using v1.01-cache-2.11-cpan-39bf76dae61 )