Merge pull request #1094 from p12tic/build-args-test

Add unit tests for image building
This commit is contained in:
Povilas Kanapickas 2024-12-30 01:04:16 +02:00 committed by GitHub
commit 62789a2358
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 148 additions and 14 deletions

View File

@ -2429,18 +2429,7 @@ async def compose_push(compose, args):
await compose.podman.run([], "push", [cnt["image"]])
async def build_one(compose, args, cnt):
if "build" not in cnt:
return None
if getattr(args, "if_not_exists", None):
try:
img_id = await compose.podman.output(
[], "inspect", ["-t", "image", "-f", "{{.Id}}", cnt["image"]]
)
except subprocess.CalledProcessError:
img_id = None
if img_id:
return None
def container_to_build_args(compose, cnt, args, path_exists):
build_desc = cnt["build"]
if not hasattr(build_desc, "items"):
build_desc = {"context": build_desc}
@ -2459,9 +2448,9 @@ async def build_one(compose, args, cnt):
]
for dockerfile in dockerfile_alts:
dockerfile = os.path.join(ctx, dockerfile)
if os.path.exists(dockerfile):
if path_exists(dockerfile):
break
if not os.path.exists(dockerfile):
if not path_exists(dockerfile):
raise OSError("Dockerfile not found in " + ctx)
build_args = ["-f", dockerfile, "-t", cnt["image"]]
if "platform" in cnt:
@ -2495,6 +2484,23 @@ async def build_one(compose, args, cnt):
build_arg,
))
build_args.append(ctx)
return build_args
async def build_one(compose, args, cnt):
if "build" not in cnt:
return None
if getattr(args, "if_not_exists", None):
try:
img_id = await compose.podman.output(
[], "inspect", ["-t", "image", "-f", "{{.Id}}", cnt["image"]]
)
except subprocess.CalledProcessError:
img_id = None
if img_id:
return None
build_args = container_to_build_args(compose, cnt, args, os.path.exists)
status = await compose.podman.run([], "build", build_args)
return status

View File

@ -0,0 +1,128 @@
# SPDX-License-Identifier: GPL-2.0
import unittest
from unittest import mock
from podman_compose import container_to_build_args
def create_compose_mock(project_name='test_project_name'):
compose = mock.Mock()
compose.project_name = project_name
compose.dirname = 'test_dirname'
compose.container_names_by_service.get = mock.Mock(return_value=None)
compose.prefer_volume_over_mount = False
compose.default_net = None
compose.networks = {}
compose.x_podman = {}
return compose
def get_minimal_container():
return {
'name': 'project_name_service_name1',
'service_name': 'service_name',
'image': 'new-image',
'build': {},
}
def get_minimal_args():
args = mock.Mock()
args.build_arg = []
return args
class TestContainerToBuildArgs(unittest.TestCase):
def test_minimal(self):
c = create_compose_mock()
cnt = get_minimal_container()
args = get_minimal_args()
args = container_to_build_args(c, cnt, args, lambda path: True)
self.assertEqual(
args,
[
'-f',
'./Containerfile',
'-t',
'new-image',
'--no-cache',
'--pull-always',
'.',
],
)
def test_platform(self):
c = create_compose_mock()
cnt = get_minimal_container()
cnt['platform'] = 'linux/amd64'
args = get_minimal_args()
args = container_to_build_args(c, cnt, args, lambda path: True)
self.assertEqual(
args,
[
'-f',
'./Containerfile',
'-t',
'new-image',
'--platform',
'linux/amd64',
'--no-cache',
'--pull-always',
'.',
],
)
def test_tags(self):
c = create_compose_mock()
cnt = get_minimal_container()
cnt['build']['tags'] = ['some-tag1', 'some-tag2:2']
args = get_minimal_args()
args = container_to_build_args(c, cnt, args, lambda path: True)
self.assertEqual(
args,
[
'-f',
'./Containerfile',
'-t',
'new-image',
'-t',
'some-tag1',
'-t',
'some-tag2:2',
'--no-cache',
'--pull-always',
'.',
],
)
def test_labels(self):
c = create_compose_mock()
cnt = get_minimal_container()
cnt['build']['labels'] = ['some-label1', 'some-label2.2']
args = get_minimal_args()
args = container_to_build_args(c, cnt, args, lambda path: True)
self.assertEqual(
args,
[
'-f',
'./Containerfile',
'-t',
'new-image',
'--label',
'some-label1',
'--label',
'some-label2.2',
'--no-cache',
'--pull-always',
'.',
],
)