mirror of
https://github.com/containers/podman-compose.git
synced 2025-01-24 06:48:45 +01:00
Merge pull request #997 from mokibit/automate-build-tests
Automate manual `build` tests
This commit is contained in:
commit
daab93b762
@ -29,5 +29,6 @@ pluggy==1.4.0
|
|||||||
pyproject-api==1.6.1
|
pyproject-api==1.6.1
|
||||||
python-dotenv==1.0.1
|
python-dotenv==1.0.1
|
||||||
PyYAML==6.0.1
|
PyYAML==6.0.1
|
||||||
|
requests
|
||||||
tomlkit==0.12.4
|
tomlkit==0.12.4
|
||||||
virtualenv==20.25.1
|
virtualenv==20.25.1
|
||||||
|
@ -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.
|
|
@ -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
|
|
||||||
```
|
|
65
tests/integration/test_podman_compose_build.py
Normal file
65
tests/integration/test_podman_compose_build.py
Normal 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",
|
||||||
|
])
|
30
tests/integration/test_podman_compose_build_fail.py
Normal file
30
tests/integration/test_podman_compose_build_fail.py
Normal 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))
|
Loading…
Reference in New Issue
Block a user