From 44936c14961ac7bdc033ece1a0ee11d293446cc1 Mon Sep 17 00:00:00 2001 From: Aditya R Date: Thu, 24 Mar 2022 11:27:44 +0530 Subject: [PATCH] test: add a test to verify race free concurrent/parallel builds Invoking parallel/concurrent builds from podman race against each other following behviour was fixed in containers/storage#1153 and containers/image#1480 Test verifies if following bug is fixed in new race-free API or not. Read more about this issue, see bz 2055487 for more details. Test manually backported from: containers@63f92d0 Signed-off-by: Aditya R --- test/system/070-build.bats | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/test/system/070-build.bats b/test/system/070-build.bats index c963d8325f83..94256b21594e 100644 --- a/test/system/070-build.bats +++ b/test/system/070-build.bats @@ -210,6 +210,32 @@ EOF run_podman rmi -f build_test } +@test "podman parallel build should not race" { + skip_if_remote "following test is not supported for remote clients" + + # Run thirty parallel builds using the same Containerfile + cat >$PODMAN_TMPDIR/Containerfile </dev/null & + done + + # Wait for all background builds to complete. Note that this succeeds + # even if some of the individual builds fail! Our actual test is below. + wait + + # Now delete all built images. If any image wasn't built, rmi will fail + # and test will fail. + for i in $(seq --format 'i%02g' 1 $count); do + run_podman rmi $i + done +} + @test "podman build - URLs" { tmpdir=$PODMAN_TMPDIR/build-test mkdir -p $tmpdir