Merge pull request #993 from p12tic/compose-file-links

Don't resolve links to compose file
This commit is contained in:
Povilas Kanapickas 2024-07-06 19:35:18 +03:00 committed by GitHub
commit 3296c8d34f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
7 changed files with 58 additions and 1 deletions

View File

@ -0,0 +1 @@
Fix compatibility with docker-compose in how symlinks to docker-compose.yml are handled.

View File

@ -1785,7 +1785,6 @@ class PodmanCompose:
sys.exit(1)
# make absolute
relative_files = files
files = list(map(os.path.realpath, files))
filename = files[0]
project_name = args.project_name
# no_ansi = args.no_ansi

View File

@ -0,0 +1 @@
../compose_symlink_dest/docker-compose.yml

View File

@ -0,0 +1 @@
data_compose_symlink

View File

@ -0,0 +1,7 @@
version: "3"
services:
container1:
image: nopush/podman-compose-test
command: ["/bin/busybox", "cat", "/file"]
volumes:
- "./file:/file"

View File

@ -0,0 +1 @@
data_compose_symlink_dest

View File

@ -0,0 +1,47 @@
# 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
class TestFilesystem(unittest.TestCase, RunSubprocessMixin):
def test_compose_symlink(self):
"""The context of podman-compose.yml should come from the same directory as the file even
if it is a symlink
"""
compose_path = os.path.join(test_path(), "filesystem/compose_symlink/docker-compose.yml")
try:
self.run_subprocess_assert_returncode([
podman_compose_path(),
"-f",
compose_path,
"up",
"-d",
"container1",
])
out, _ = self.run_subprocess_assert_returncode([
podman_compose_path(),
"-f",
compose_path,
"logs",
"container1",
])
# BUG: figure out why cat is called twice
self.assertEqual(out, b'data_compose_symlink\ndata_compose_symlink\n')
finally:
out, _ = self.run_subprocess_assert_returncode([
podman_compose_path(),
"-f",
compose_path,
"down",
])