mirror of
https://github.com/containers/podman.git
synced 2025-08-06 19:44:14 +08:00

Since this option will also be used for netavark we should rename it to something more generic. It is important that --cni-config-dir still works otherwise we could break existing container cleanup commands. Signed-off-by: Paul Holzinger <pholzing@redhat.com>
267 lines
15 KiB
Perl
Executable File
267 lines
15 KiB
Perl
Executable File
#!/usr/bin/perl
|
|
#
|
|
# tests for logformatter
|
|
#
|
|
(our $ME = $0) =~ s|^.*/||;
|
|
|
|
use v5.14;
|
|
use strict;
|
|
use warnings;
|
|
|
|
use FindBin;
|
|
use File::Temp qw(tempdir);
|
|
use Test::More;
|
|
|
|
#
|
|
# Read the test cases (see __END__ section below)
|
|
#
|
|
my @tests;
|
|
my $context = '';
|
|
while (my $line = <DATA>) {
|
|
chomp $line;
|
|
|
|
if ($line =~ /^==\s+(.*)/) {
|
|
push @tests, { name => $1, input => [], expect => [] };
|
|
$context = '';
|
|
}
|
|
elsif ($line =~ /^<<</) {
|
|
$context = 'input';
|
|
}
|
|
elsif ($line =~ /^>>>/) {
|
|
$context = 'expect';
|
|
}
|
|
elsif (@tests && $line) {
|
|
push @{ $tests[-1]{$context} }, $line;
|
|
}
|
|
}
|
|
|
|
plan tests => scalar(@tests);
|
|
|
|
my $tempdir = tempdir("logformatter-test.XXXXXX", TMPDIR => 1, CLEANUP => !$ENV{DEBUG});
|
|
|
|
chdir $tempdir
|
|
or die "$ME: Could not cd $tempdir: $!\n";
|
|
|
|
for my $t (@tests) {
|
|
my $name = $t->{name};
|
|
(my $fname = $name) =~ s/\s+/_/g;
|
|
|
|
open my $fh_out, '>', "$fname.txt"
|
|
or die "$ME: Cannot create $tempdir/$fname.txt: $!\n";
|
|
print { $fh_out } "$_\n" for @{$t->{input}};
|
|
close $fh_out
|
|
or die "$ME: Error writing $tempdir/$fname.txt: $!\n";
|
|
|
|
system("$FindBin::Bin/logformatter $fname <$fname.txt >/dev/null");
|
|
open my $fh_in, '<', "$fname.log.html"
|
|
or die "$ME: Fatal: $fname: logformatter did not create .log.html\n";
|
|
my @actual;
|
|
while (my $line = <$fh_in>) {
|
|
chomp $line;
|
|
push @actual, $line if $line =~ / begin processed output / .. $line =~ / end processed output /;
|
|
}
|
|
close $fh_in;
|
|
|
|
# Strip off leading and trailing "<pre>"
|
|
shift @actual; pop @actual;
|
|
|
|
# For debugging: preserve expected results
|
|
if ($ENV{DEBUG}) {
|
|
open my $fh_out, '>', "$fname.expect";
|
|
print { $fh_out } "$_\n" for @{$t->{expect}};
|
|
close $fh_out;
|
|
}
|
|
|
|
is_deeply \@actual, $t->{expect}, $name;
|
|
}
|
|
|
|
chdir '/';
|
|
|
|
|
|
|
|
__END__
|
|
|
|
== simple bats
|
|
|
|
<<<
|
|
1..4
|
|
ok 1 hi
|
|
ok 2 bye # skip no reason
|
|
not ok 3 fail
|
|
# $ /path/to/podman foo -bar
|
|
# #| FAIL: exit code is 123; expected 321
|
|
ok 4 blah
|
|
>>>
|
|
1..4
|
|
<span class='bats-passed'><a name='t--00001'>ok 1 hi</a></span>
|
|
<span class='bats-skipped'><a name='t--00002'>ok 2 bye # skip no reason</a></span>
|
|
<span class='bats-failed'><a name='t--00003'>not ok 3 fail</a></span>
|
|
<span class='bats-log'># $ <b><span title="/path/to/podman">podman</span> foo -bar</b></span>
|
|
<span class='bats-log-esm'># #| FAIL: exit code is 123; expected 321</span>
|
|
<span class='bats-passed'><a name='t--00004'>ok 4 blah</a></span>
|
|
<hr/><span class='bats-summary'>Summary: <span class='bats-passed'>2 Passed</span>, <span class='bats-failed'>1 Failed</span>, <span class='bats-skipped'>1 Skipped</span>. Total tests: 4</span>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
== simple ginkgo
|
|
|
|
<<<
|
|
$SCRIPT_BASE/integration_test.sh |& ${TIMESTAMP}
|
|
[08:26:19] START - All [+xxxx] lines that follow are relative to right now.
|
|
[+0002s] GO111MODULE=on go build -mod=vendor -gcflags 'all=-trimpath=/var/tmp/go/src/github.com/containers/podman' -asmflags 'all=-trimpath=/var/tmp/go/src/github.com/containers/podman' -ldflags '-X github.com/containers/podman/libpod/define.gitCommit=40f5d8b1becd381c4e8283ed3940d09193e4fe06 -X github.com/containers/podman/libpod/define.buildInfo=1582809981 -X github.com/containers/podman/libpod/config._installPrefix=/usr/local -X github.com/containers/podman/libpod/config._etcDir=/etc -extldflags ""' -tags " selinux systemd exclude_graphdriver_devicemapper seccomp varlink" -o bin/podman github.com/containers/podman/cmd/podman
|
|
[+0103s] •
|
|
[+0103s] ------------------------------
|
|
[+0103s] Podman pod restart
|
|
[+0103s] podman pod restart single empty pod
|
|
[+0103s] /var/tmp/go/src/github.com/containers/podman/test/e2e/pod_restart_test.go:41
|
|
[+0103s] [BeforeEach] Podman pod restart
|
|
[+0103s] /var/tmp/go/src/github.com/containers/podman/test/e2e/pod_restart_test.go:18
|
|
[+0103s] [It] podman pod restart single empty pod
|
|
[+0103s] /var/tmp/go/src/github.com/containers/podman/test/e2e/pod_restart_test.go:41
|
|
[+0103s] Running: /var/tmp/go/src/github.com/containers/podman/bin/podman --storage-opt vfs.imagestore=/tmp/podman/imagecachedir --root /tmp/podman_test553496330/crio --runroot /tmp/podman_test553496330/crio-run --runtime /usr/bin/runc --conmon /usr/bin/conmon --network-config-dir /etc/cni/net.d --cgroup-manager systemd --tmpdir /tmp/podman_test553496330 --events-backend file --storage-driver vfs pod create --infra=false --share
|
|
[+0103s] 4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89
|
|
[+0103s] output: 4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89
|
|
[+0103s] Running: /var/tmp/go/src/github.com/containers/podman/bin/podman --storage-opt vfs.imagestore=/tmp/podman/imagecachedir --root /tmp/podman_test553496330/crio --runroot /tmp/podman_test553496330/crio-run --runtime /usr/bin/runc --conmon /usr/bin/conmon --network-config-dir /etc/cni/net.d --cgroup-manager systemd --tmpdir /tmp/podman_test553496330 --events-backend file --storage-driver vfs pod restart 4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89
|
|
[+0103s] Error: no containers in pod 4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89 have no dependencies, cannot start pod: no such container
|
|
[+0103s] output:
|
|
[+0103s] [AfterEach] Podman pod restart
|
|
[+0103s] /var/tmp/go/src/github.com/containers/podman/test/e2e/pod_restart_test.go:28
|
|
[+0103s] Running: /var/tmp/go/src/github.com/containers/podman/bin/podman --storage-opt vfs.imagestore=/tmp/podman/imagecachedir --root /tmp/podman_test553496330/crio --runroot /tmp/podman_test553496330/crio-run --runtime /usr/bin/runc --conmon /usr/bin/conmon --network-config-dir /etc/cni/net.d --cgroup-manager systemd --tmpdir /tmp/podman_test553496330 --events-backend file --storage-driver vfs pod rm -fa
|
|
[+0103s] 4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89
|
|
[+0104s] Running: /var/tmp/go/src/github.com/containers/libpod/bin/podman-remote --storage-opt vfs.imagestore=/tmp/podman/imagecachedir --root /tmp/podman_test553496330/crio --runroot /tmp/podman_test553496330/crio-run --runtime /usr/bin/runc --conmon /usr/bin/conmon --network-config-dir /etc/cni/net.d --cgroup-manager systemd --tmpdir /tmp/podman_test553496330 --events-backend file --storage-driver vfs --remote --url unix:/run/user/12345/podman-xyz.sock pod rm -fa
|
|
[+0104s] 4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89 again
|
|
|
|
|
|
[+0107s] •
|
|
[+0523s] ------------------------------
|
|
[+0523s] Podman play kube with build
|
|
[+0523s] --build should override image in store
|
|
[+0523s] /var/tmp/go/src/github.com/containers/podman/test/e2e/play_build_test.go:215
|
|
|
|
|
|
[+0479s] •
|
|
[+0479s] ------------------------------
|
|
[+0479s] Podman pod rm
|
|
[+0479s] podman pod rm -a doesn't remove a running container
|
|
[+0479s] /var/tmp/go/src/github.com/containers/podman/test/e2e/pod_rm_test.go:119
|
|
|
|
|
|
[+1405s] •
|
|
[+1405s] ------------------------------
|
|
[+1405s] Podman run entrypoint
|
|
[+1405s] podman run entrypoint == [""]
|
|
[+1405s] /var/tmp/go/src/github.com/containers/podman/test/e2e/run_entrypoint_test.go:47
|
|
|
|
[+0184s] S [SKIPPING] [3.086 seconds]
|
|
[+1385s] S [SKIPPING] in Spec Setup (BeforeEach) [0.001 seconds]
|
|
|
|
[+1512s] Summarizing 6 Failures:
|
|
[+1512s]
|
|
[+1512s] [Fail] Podman play kube with build [It] --build should override image in store
|
|
[+1512s] /var/tmp/go/src/github.com/containers/podman/test/e2e/play_build_test.go:259
|
|
>>>
|
|
$SCRIPT_BASE/integration_test.sh |& ${TIMESTAMP}
|
|
[08:26:19] START - All [+xxxx] lines that follow are relative to right now.
|
|
<span class="timestamp">[+0002s] </span>GO111MODULE=on go build -mod=vendor -gcflags 'all=-trimpath=/var/tmp/go/src/github.com/containers/podman' -asmflags 'all=-trimpath=/var/tmp/go/src/github.com/containers/podman' -ldflags '-X github.com/containers/podman/libpod/define.gitCommit=40f5d8b1becd381c4e8283ed3940d09193e4fe06 -X github.com/containers/podman/libpod/define.buildInfo=1582809981 -X github.com/containers/podman/libpod/config._installPrefix=/usr/local -X github.com/containers/podman/libpod/config._etcDir=/etc -extldflags ""' -tags " selinux systemd exclude_graphdriver_devicemapper seccomp varlink" -o bin/podman github.com/containers/podman/cmd/podman
|
|
<span class="timestamp">[+0103s] </span>•
|
|
</pre>
|
|
<hr />
|
|
<pre>
|
|
<span class="timestamp">[+0103s] </span>Podman pod restart
|
|
<span class="timestamp"> </span><a name='t--podman-pod-restart-single-empty-pod--1'><h2> podman pod restart single empty pod</h2></a>
|
|
<span class="timestamp"> </span> /var/tmp/go/src/github.com<a class="codelink" href='https://github.com/containers/podman/blob/40f5d8b1becd381c4e8283ed3940d09193e4fe06/test/e2e/pod_restart_test.go#L41'>/containers/podman/test/e2e/pod_restart_test.go:41</a>
|
|
<span class="timestamp"> </span>[BeforeEach] Podman pod restart
|
|
<span class="timestamp"> </span> /var/tmp/go/src/github.com<a class="codelink" href='https://github.com/containers/podman/blob/40f5d8b1becd381c4e8283ed3940d09193e4fe06/test/e2e/pod_restart_test.go#L18'>/containers/podman/test/e2e/pod_restart_test.go:18</a>
|
|
<span class="timestamp"> </span><span class="testname">[It] podman pod restart single empty pod</span>
|
|
<span class="timestamp"> </span> /var/tmp/go/src/github.com<a class="codelink" href='https://github.com/containers/podman/blob/40f5d8b1becd381c4e8283ed3940d09193e4fe06/test/e2e/pod_restart_test.go#L41'>/containers/podman/test/e2e/pod_restart_test.go:41</a>
|
|
<span class="timestamp"> </span><span class="boring">#</span> <span title="/var/tmp/go/src/github.com/containers/podman/bin/podman"><b>podman</b></span> <span class="boring" title="--storage-opt vfs.imagestore=/tmp/podman/imagecachedir
|
|
--root /tmp/podman_test553496330/crio
|
|
--runroot /tmp/podman_test553496330/crio-run
|
|
--runtime /usr/bin/runc
|
|
--conmon /usr/bin/conmon
|
|
--network-config-dir /etc/cni/net.d
|
|
--cgroup-manager systemd
|
|
--tmpdir /tmp/podman_test553496330
|
|
--events-backend file
|
|
--storage-driver vfs">[options]</span><b> pod create --infra=false --share</b>
|
|
<span class="timestamp"> </span>4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89
|
|
<span class="timestamp"> </span><span class="boring">#</span> <span title="/var/tmp/go/src/github.com/containers/podman/bin/podman"><b>podman</b></span> <span class="boring" title="--storage-opt vfs.imagestore=/tmp/podman/imagecachedir
|
|
--root /tmp/podman_test553496330/crio
|
|
--runroot /tmp/podman_test553496330/crio-run
|
|
--runtime /usr/bin/runc
|
|
--conmon /usr/bin/conmon
|
|
--network-config-dir /etc/cni/net.d
|
|
--cgroup-manager systemd
|
|
--tmpdir /tmp/podman_test553496330
|
|
--events-backend file
|
|
--storage-driver vfs">[options]</span><b> pod restart 4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89</b>
|
|
<span class="timestamp"> </span><span class='log-warn'>Error: no containers in pod 4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89 have no dependencies, cannot start pod: no such container</span>
|
|
<span class="timestamp"> </span>output:
|
|
<span class="timestamp"> </span>[AfterEach] Podman pod restart
|
|
<span class="timestamp"> </span> /var/tmp/go/src/github.com<a class="codelink" href='https://github.com/containers/podman/blob/40f5d8b1becd381c4e8283ed3940d09193e4fe06/test/e2e/pod_restart_test.go#L28'>/containers/podman/test/e2e/pod_restart_test.go:28</a>
|
|
<span class="timestamp"> </span><span class="boring">#</span> <span title="/var/tmp/go/src/github.com/containers/podman/bin/podman"><b>podman</b></span> <span class="boring" title="--storage-opt vfs.imagestore=/tmp/podman/imagecachedir
|
|
--root /tmp/podman_test553496330/crio
|
|
--runroot /tmp/podman_test553496330/crio-run
|
|
--runtime /usr/bin/runc
|
|
--conmon /usr/bin/conmon
|
|
--network-config-dir /etc/cni/net.d
|
|
--cgroup-manager systemd
|
|
--tmpdir /tmp/podman_test553496330
|
|
--events-backend file
|
|
--storage-driver vfs">[options]</span><b> pod rm -fa</b>
|
|
<span class="timestamp"> </span>4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89
|
|
|
|
<span class="timestamp">[+0104s] </span><span class="boring">#</span> <span title="/var/tmp/go/src/github.com/containers/libpod/bin/podman-remote"><b>podman-remote</b></span> <span class="boring" title="--storage-opt vfs.imagestore=/tmp/podman/imagecachedir
|
|
--root /tmp/podman_test553496330/crio
|
|
--runroot /tmp/podman_test553496330/crio-run
|
|
--runtime /usr/bin/runc
|
|
--conmon /usr/bin/conmon
|
|
--network-config-dir /etc/cni/net.d
|
|
--cgroup-manager systemd
|
|
--tmpdir /tmp/podman_test553496330
|
|
--events-backend file
|
|
--storage-driver vfs
|
|
--url unix:/run/user/12345/podman-xyz.sock">[options]</span><b> pod rm -fa</b>
|
|
<span class="timestamp"> </span>4810be0cfbd42241e349dbe7d50fbc54405cd320a6637c65fd5323f34d64af89 again
|
|
|
|
|
|
<span class="timestamp">[+0107s] </span>•
|
|
</pre>
|
|
<hr />
|
|
<pre>
|
|
<span class="timestamp">[+0523s] </span>Podman play kube with build
|
|
<span class="timestamp"> </span><a name='t----build-should-override-image-in-store--1'><h2> --build should override image in store</h2></a>
|
|
<span class="timestamp"> </span> /var/tmp/go/src/github.com<a class="codelink" href='https://github.com/containers/podman/blob/40f5d8b1becd381c4e8283ed3940d09193e4fe06/test/e2e/play_build_test.go#L215'>/containers/podman/test/e2e/play_build_test.go:215</a>
|
|
|
|
|
|
<span class="timestamp">[+0479s] </span>•
|
|
</pre>
|
|
<hr />
|
|
<pre>
|
|
<span class="timestamp">[+0479s] </span>Podman pod rm
|
|
<span class="timestamp"> </span><a name='t--podman-pod-rm--a-doesnt-remove-a-running-container--1'><h2> podman pod rm -a doesn't remove a running container</h2></a>
|
|
<span class="timestamp"> </span> /var/tmp/go/src/github.com<a class="codelink" href='https://github.com/containers/podman/blob/40f5d8b1becd381c4e8283ed3940d09193e4fe06/test/e2e/pod_rm_test.go#L119'>/containers/podman/test/e2e/pod_rm_test.go:119</a>
|
|
|
|
|
|
<span class="timestamp">[+1405s] </span>•
|
|
</pre>
|
|
<hr />
|
|
<pre>
|
|
<span class="timestamp">[+1405s] </span>Podman run entrypoint
|
|
<span class="timestamp"> </span><a name='t--podman-run-entrypoint---1'><h2> podman run entrypoint == [""]</h2></a>
|
|
<span class="timestamp"> </span> /var/tmp/go/src/github.com<a class="codelink" href='https://github.com/containers/podman/blob/40f5d8b1becd381c4e8283ed3940d09193e4fe06/test/e2e/run_entrypoint_test.go#L47'>/containers/podman/test/e2e/run_entrypoint_test.go:47</a>
|
|
|
|
|
|
<span class="timestamp">[+0184s] </span>S <span class="log-skip">[SKIPPING] [3.086 seconds]</span>
|
|
<span class="timestamp">[+1385s] </span>S <span class="log-skip">[SKIPPING] in Spec Setup (BeforeEach) [0.001 seconds]</span>
|
|
|
|
|
|
<span class="timestamp">[+1512s] </span>Summarizing 6 Failures:
|
|
[+1512s]
|
|
<span class="timestamp"> </span><b>[Fail] Podman play kube with build [It] <a href='#t----build-should-override-image-in-store--1'>--build should override image in store</a></b>
|
|
<span class="timestamp"> </span>/var/tmp/go/src/github.com<a class="codelink" href='https://github.com/containers/podman/blob/40f5d8b1becd381c4e8283ed3940d09193e4fe06/test/e2e/play_build_test.go#L259'>/containers/podman/test/e2e/play_build_test.go:259</a>
|