Merge pull request #997 from mokibit/automate-build-tests

Automate manual `build` tests
This commit is contained in:
Povilas Kanapickas 2024-07-08 22:42:00 +03:00 committed by GitHub
commit daab93b762
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 96 additions and 45 deletions

View File

@ -29,5 +29,6 @@ pluggy==1.4.0
pyproject-api==1.6.1
python-dotenv==1.0.1
PyYAML==6.0.1
requests
tomlkit==0.12.4
virtualenv==20.25.1

View File

@ -1,23 +0,0 @@
# Test podman-compose with build
```
podman-compose build
podman-compose up -d
curl http://localhost:8080/index.txt
curl http://localhost:8000/index.txt
podman inspect my-busybox-httpd2
podman-compose down
```
expected output would be something like
```
2019-09-03T15:16:38+0000
ALT buildno=2 port 8000 2019-09-03T15:16:38+0000
{
...
}
```
as you can see we were able to override buildno to be 2 instead of 1,
and httpd_port to 8000.

View File

@ -1,22 +0,0 @@
# Test podman-compose with build (fail scenario)
```shell
podman-compose build || echo $?
```
expected output would be something like
```
STEP 1/3: FROM busybox
STEP 2/3: RUN this_command_does_not_exist
/bin/sh: this_command_does_not_exist: not found
Error: building at STEP "RUN this_command_does_not_exist": while running runtime: exit status 127
exit code: 127
```
Expected `podman-compose` exit code:
```shell
echo $?
127
```

View File

@ -0,0 +1,65 @@
# SPDX-License-Identifier: GPL-2.0
import os
import unittest
import requests
from tests.integration.test_podman_compose import podman_compose_path
from tests.integration.test_podman_compose import test_path
from tests.integration.test_utils import RunSubprocessMixin
def compose_yaml_path():
""" "Returns the path to the compose file used for this test module"""
base_path = os.path.join(test_path(), "build")
return os.path.join(base_path, "docker-compose.yml")
class TestComposeBuild(unittest.TestCase, RunSubprocessMixin):
def test_build(self):
try:
self.run_subprocess_assert_returncode([
podman_compose_path(),
"-f",
compose_yaml_path(),
"build",
"--no-cache",
])
self.run_subprocess_assert_returncode([
podman_compose_path(),
"-f",
compose_yaml_path(),
"up",
"-d",
])
request = requests.get('http://localhost:8080/index.txt')
self.assertEqual(request.status_code, 200)
alt_request_success = False
try:
# FIXME: suspicious behaviour, too often ends up in error
alt_request = requests.get('http://localhost:8000/index.txt')
self.assertEqual(alt_request.status_code, 200)
self.assertIn("ALT buildno=2 port=8000 ", alt_request.text)
alt_request_success = True
except requests.exceptions.ConnectionError:
pass
if alt_request_success:
output, _ = self.run_subprocess_assert_returncode([
"podman",
"inspect",
"my-busybox-httpd2",
])
self.assertIn("httpd_port=8000", str(output))
self.assertIn("buildno=2", str(output))
finally:
self.run_subprocess_assert_returncode([
podman_compose_path(),
"-f",
compose_yaml_path(),
"down",
])

View File

@ -0,0 +1,30 @@
# SPDX-License-Identifier: GPL-2.0
import os
import unittest
from tests.integration.test_podman_compose import podman_compose_path
from tests.integration.test_podman_compose import test_path
from tests.integration.test_utils import RunSubprocessMixin
def compose_yaml_path():
""" "Returns the path to the compose file used for this test module"""
base_path = os.path.join(test_path(), "build_fail")
return os.path.join(base_path, "docker-compose.yml")
class TestComposeBuildFail(unittest.TestCase, RunSubprocessMixin):
def test_build_fail(self):
output, error = self.run_subprocess_assert_returncode(
[
podman_compose_path(),
"-f",
compose_yaml_path(),
"build",
],
expected_returncode=127,
)
self.assertIn("RUN this_command_does_not_exist", str(output))
self.assertIn("this_command_does_not_exist: not found", str(error))
self.assertIn("while running runtime: exit status 127", str(error))