|
@@ -1,17 +1,14 @@
|
|
|
import functools
|
|
|
import os
|
|
|
-import shutil
|
|
|
-import sys
|
|
|
-import tempfile
|
|
|
-import unittest
|
|
|
|
|
|
-from ..platformflags import is_win32
|
|
|
-from ..platform import acl_get, acl_set, swidth
|
|
|
+import pytest
|
|
|
+
|
|
|
+from ..platformflags import is_darwin, is_freebsd, is_linux, is_win32
|
|
|
+from ..platform import acl_get, acl_set
|
|
|
from ..platform import get_process_id, process_alive
|
|
|
-from . import BaseTestCase, unopened_tempfile
|
|
|
+from . import unopened_tempfile
|
|
|
from .locking import free_pid # NOQA
|
|
|
|
|
|
-
|
|
|
ACCESS_ACL = """
|
|
|
user::rw-
|
|
|
user:root:rw-:0
|
|
@@ -38,8 +35,6 @@ other::r--
|
|
|
"ascii"
|
|
|
)
|
|
|
|
|
|
-# _acls_working = None
|
|
|
-
|
|
|
|
|
|
def fakeroot_detected():
|
|
|
return "FAKEROOTKEY" in os.environ
|
|
@@ -75,154 +70,13 @@ def are_acls_working():
|
|
|
return False
|
|
|
|
|
|
|
|
|
-@unittest.skipUnless(sys.platform.startswith("linux"), "linux only test")
|
|
|
-@unittest.skipIf(fakeroot_detected(), "not compatible with fakeroot")
|
|
|
-class PlatformLinuxTestCase(BaseTestCase):
|
|
|
- def setUp(self):
|
|
|
- self.tmpdir = tempfile.mkdtemp()
|
|
|
-
|
|
|
- def tearDown(self):
|
|
|
- shutil.rmtree(self.tmpdir)
|
|
|
-
|
|
|
- def get_acl(self, path, numeric_ids=False):
|
|
|
- item = {}
|
|
|
- acl_get(path, item, os.stat(path), numeric_ids=numeric_ids)
|
|
|
- return item
|
|
|
-
|
|
|
- def set_acl(self, path, access=None, default=None, numeric_ids=False):
|
|
|
- item = {"acl_access": access, "acl_default": default}
|
|
|
- acl_set(path, item, numeric_ids=numeric_ids)
|
|
|
-
|
|
|
- @unittest.skipIf(not are_acls_working(), "ACLs do not work")
|
|
|
- def test_access_acl(self):
|
|
|
- file = tempfile.NamedTemporaryFile()
|
|
|
- self.assert_equal(self.get_acl(file.name), {})
|
|
|
- self.set_acl(
|
|
|
- file.name,
|
|
|
- access=b"user::rw-\ngroup::r--\nmask::rw-\nother::---\nuser:root:rw-:9999\ngroup:root:rw-:9999\n",
|
|
|
- numeric_ids=False,
|
|
|
- )
|
|
|
- self.assert_in(b"user:root:rw-:0", self.get_acl(file.name)["acl_access"])
|
|
|
- self.assert_in(b"group:root:rw-:0", self.get_acl(file.name)["acl_access"])
|
|
|
- self.assert_in(b"user:0:rw-:0", self.get_acl(file.name, numeric_ids=True)["acl_access"])
|
|
|
- file2 = tempfile.NamedTemporaryFile()
|
|
|
- self.set_acl(
|
|
|
- file2.name,
|
|
|
- access=b"user::rw-\ngroup::r--\nmask::rw-\nother::---\nuser:root:rw-:9999\ngroup:root:rw-:9999\n",
|
|
|
- numeric_ids=True,
|
|
|
- )
|
|
|
- self.assert_in(b"user:9999:rw-:9999", self.get_acl(file2.name)["acl_access"])
|
|
|
- self.assert_in(b"group:9999:rw-:9999", self.get_acl(file2.name)["acl_access"])
|
|
|
-
|
|
|
- @unittest.skipIf(not are_acls_working(), "ACLs do not work")
|
|
|
- def test_default_acl(self):
|
|
|
- self.assert_equal(self.get_acl(self.tmpdir), {})
|
|
|
- self.set_acl(self.tmpdir, access=ACCESS_ACL, default=DEFAULT_ACL)
|
|
|
- self.assert_equal(self.get_acl(self.tmpdir)["acl_access"], ACCESS_ACL)
|
|
|
- self.assert_equal(self.get_acl(self.tmpdir)["acl_default"], DEFAULT_ACL)
|
|
|
-
|
|
|
- @unittest.skipIf(not user_exists("übel"), "requires übel user")
|
|
|
- @unittest.skipIf(not are_acls_working(), "ACLs do not work")
|
|
|
- def test_non_ascii_acl(self):
|
|
|
- # Testing non-ascii ACL processing to see whether our code is robust.
|
|
|
- # I have no idea whether non-ascii ACLs are allowed by the standard,
|
|
|
- # but in practice they seem to be out there and must not make our code explode.
|
|
|
- file = tempfile.NamedTemporaryFile()
|
|
|
- self.assert_equal(self.get_acl(file.name), {})
|
|
|
- nothing_special = b"user::rw-\ngroup::r--\nmask::rw-\nother::---\n"
|
|
|
- # TODO: can this be tested without having an existing system user übel with uid 666 gid 666?
|
|
|
- user_entry = "user:übel:rw-:666".encode()
|
|
|
- user_entry_numeric = b"user:666:rw-:666"
|
|
|
- group_entry = "group:übel:rw-:666".encode()
|
|
|
- group_entry_numeric = b"group:666:rw-:666"
|
|
|
- acl = b"\n".join([nothing_special, user_entry, group_entry])
|
|
|
- self.set_acl(file.name, access=acl, numeric_ids=False)
|
|
|
- acl_access = self.get_acl(file.name, numeric_ids=False)["acl_access"]
|
|
|
- self.assert_in(user_entry, acl_access)
|
|
|
- self.assert_in(group_entry, acl_access)
|
|
|
- acl_access_numeric = self.get_acl(file.name, numeric_ids=True)["acl_access"]
|
|
|
- self.assert_in(user_entry_numeric, acl_access_numeric)
|
|
|
- self.assert_in(group_entry_numeric, acl_access_numeric)
|
|
|
- file2 = tempfile.NamedTemporaryFile()
|
|
|
- self.set_acl(file2.name, access=acl, numeric_ids=True)
|
|
|
- acl_access = self.get_acl(file2.name, numeric_ids=False)["acl_access"]
|
|
|
- self.assert_in(user_entry, acl_access)
|
|
|
- self.assert_in(group_entry, acl_access)
|
|
|
- acl_access_numeric = self.get_acl(file.name, numeric_ids=True)["acl_access"]
|
|
|
- self.assert_in(user_entry_numeric, acl_access_numeric)
|
|
|
- self.assert_in(group_entry_numeric, acl_access_numeric)
|
|
|
-
|
|
|
- def test_utils(self):
|
|
|
- from ..platform.linux import acl_use_local_uid_gid
|
|
|
-
|
|
|
- self.assert_equal(acl_use_local_uid_gid(b"user:nonexistent1234:rw-:1234"), b"user:1234:rw-")
|
|
|
- self.assert_equal(acl_use_local_uid_gid(b"group:nonexistent1234:rw-:1234"), b"group:1234:rw-")
|
|
|
- self.assert_equal(acl_use_local_uid_gid(b"user:root:rw-:0"), b"user:0:rw-")
|
|
|
- self.assert_equal(acl_use_local_uid_gid(b"group:root:rw-:0"), b"group:0:rw-")
|
|
|
-
|
|
|
-
|
|
|
-@unittest.skipUnless(sys.platform.startswith("darwin"), "macOS only test")
|
|
|
-@unittest.skipIf(fakeroot_detected(), "not compatible with fakeroot")
|
|
|
-class PlatformDarwinTestCase(BaseTestCase):
|
|
|
- def setUp(self):
|
|
|
- self.tmpdir = tempfile.mkdtemp()
|
|
|
-
|
|
|
- def tearDown(self):
|
|
|
- shutil.rmtree(self.tmpdir)
|
|
|
-
|
|
|
- def get_acl(self, path, numeric_ids=False):
|
|
|
- item = {}
|
|
|
- acl_get(path, item, os.stat(path), numeric_ids=numeric_ids)
|
|
|
- return item
|
|
|
-
|
|
|
- def set_acl(self, path, acl, numeric_ids=False):
|
|
|
- item = {"acl_extended": acl}
|
|
|
- acl_set(path, item, numeric_ids=numeric_ids)
|
|
|
-
|
|
|
- @unittest.skipIf(not are_acls_working(), "ACLs do not work")
|
|
|
- def test_access_acl(self):
|
|
|
- file = tempfile.NamedTemporaryFile()
|
|
|
- file2 = tempfile.NamedTemporaryFile()
|
|
|
- self.assert_equal(self.get_acl(file.name), {})
|
|
|
- self.set_acl(
|
|
|
- file.name,
|
|
|
- b"!#acl 1\n"
|
|
|
- b"group:ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000000:staff:0:allow:read\n"
|
|
|
- b"user:FFFFEEEE-DDDD-CCCC-BBBB-AAAA00000000:root:0:allow:read\n",
|
|
|
- numeric_ids=False,
|
|
|
- )
|
|
|
- self.assert_in(
|
|
|
- b"group:ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000014:staff:20:allow:read", self.get_acl(file.name)["acl_extended"]
|
|
|
- )
|
|
|
- self.assert_in(
|
|
|
- b"user:FFFFEEEE-DDDD-CCCC-BBBB-AAAA00000000:root:0:allow:read", self.get_acl(file.name)["acl_extended"]
|
|
|
- )
|
|
|
- self.set_acl(
|
|
|
- file2.name,
|
|
|
- b"!#acl 1\n"
|
|
|
- b"group:ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000000:staff:0:allow:read\n"
|
|
|
- b"user:FFFFEEEE-DDDD-CCCC-BBBB-AAAA00000000:root:0:allow:read\n",
|
|
|
- numeric_ids=True,
|
|
|
- )
|
|
|
- self.assert_in(
|
|
|
- b"group:ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000000:wheel:0:allow:read", self.get_acl(file2.name)["acl_extended"]
|
|
|
- )
|
|
|
- self.assert_in(
|
|
|
- b"group:ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000000::0:allow:read",
|
|
|
- self.get_acl(file2.name, numeric_ids=True)["acl_extended"],
|
|
|
- )
|
|
|
-
|
|
|
-
|
|
|
-@unittest.skipUnless(sys.platform.startswith(("linux", "freebsd", "darwin")), "POSIX only tests")
|
|
|
-class PlatformPosixTestCase(BaseTestCase):
|
|
|
- def test_swidth_ascii(self):
|
|
|
- self.assert_equal(swidth("borg"), 4)
|
|
|
-
|
|
|
- def test_swidth_cjk(self):
|
|
|
- self.assert_equal(swidth("バックアップ"), 6 * 2)
|
|
|
-
|
|
|
- def test_swidth_mixed(self):
|
|
|
- self.assert_equal(swidth("borgバックアップ"), 4 + 6 * 2)
|
|
|
+# define skips available to platform tests
|
|
|
+skipif_not_linux = pytest.mark.skipif(not is_linux, reason="linux only test")
|
|
|
+skipif_not_darwin = pytest.mark.skipif(not is_darwin, reason="darwin only test")
|
|
|
+skipif_not_posix = pytest.mark.skipif(not (is_linux or is_freebsd or is_darwin), reason="POSIX only tests")
|
|
|
+skipif_fakeroot_detected = pytest.mark.skipif(fakeroot_detected(), reason="not compatible with fakeroot")
|
|
|
+skipif_acls_not_working = pytest.mark.skipif(not are_acls_working(), reason="ACLs do not work")
|
|
|
+skipif_no_ubel_user = pytest.mark.skipif(not user_exists("übel"), reason="requires übel user")
|
|
|
|
|
|
|
|
|
def test_process_alive(free_pid):
|