mirror of https://github.com/borgbackup/borg.git
105 lines
4.1 KiB
Python
105 lines
4.1 KiB
Python
import os
|
|
import shutil
|
|
import sys
|
|
import tempfile
|
|
import unittest
|
|
from attic.platform import acl_get, acl_set
|
|
from attic.testsuite import BaseTestCase
|
|
|
|
|
|
ACCESS_ACL = """
|
|
user::rw-
|
|
user:root:rw-:0
|
|
user:9999:r--:9999
|
|
group::r--
|
|
group:root:r--:0
|
|
group:9999:r--:9999
|
|
mask::rw-
|
|
other::r--
|
|
""".strip().encode('ascii')
|
|
|
|
DEFAULT_ACL = """
|
|
user::rw-
|
|
user:root:r--:0
|
|
user:8888:r--:8888
|
|
group::r--
|
|
group:root:r--:0
|
|
group:8888:r--:8888
|
|
mask::rw-
|
|
other::r--
|
|
""".strip().encode('ascii')
|
|
|
|
|
|
def fakeroot_detected():
|
|
return 'FAKEROOTKEY' in os.environ
|
|
|
|
|
|
@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_owner=False):
|
|
item = {}
|
|
acl_get(path, item, os.stat(path), numeric_owner=numeric_owner)
|
|
return item
|
|
|
|
def set_acl(self, path, access=None, default=None, numeric_owner=False):
|
|
item = {b'acl_access': access, b'acl_default': default}
|
|
acl_set(path, item, numeric_owner=numeric_owner)
|
|
|
|
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_owner=False)
|
|
self.assert_in(b'user:root:rw-:0', self.get_acl(file.name)[b'acl_access'])
|
|
self.assert_in(b'group:root:rw-:0', self.get_acl(file.name)[b'acl_access'])
|
|
self.assert_in(b'user:0:rw-:0', self.get_acl(file.name, numeric_owner=True)[b'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_owner=True)
|
|
self.assert_in(b'user:9999:rw-:9999', self.get_acl(file2.name)[b'acl_access'])
|
|
self.assert_in(b'group:9999:rw-:9999', self.get_acl(file2.name)[b'acl_access'])
|
|
|
|
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)[b'acl_access'], ACCESS_ACL)
|
|
self.assert_equal(self.get_acl(self.tmpdir)[b'acl_default'], DEFAULT_ACL)
|
|
|
|
|
|
@unittest.skipUnless(sys.platform.startswith('darwin'), 'OS X 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_owner=False):
|
|
item = {}
|
|
acl_get(path, item, os.stat(path), numeric_owner=numeric_owner)
|
|
return item
|
|
|
|
def set_acl(self, path, acl, numeric_owner=False):
|
|
item = {b'acl_extended': acl}
|
|
acl_set(path, item, numeric_owner=numeric_owner)
|
|
|
|
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\ngroup:ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000000:staff:0:allow:read\nuser:FFFFEEEE-DDDD-CCCC-BBBB-AAAA00000000:root:0:allow:read\n', numeric_owner=False)
|
|
self.assert_in(b'group:ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000014:staff:20:allow:read', self.get_acl(file.name)[b'acl_extended'])
|
|
self.assert_in(b'user:FFFFEEEE-DDDD-CCCC-BBBB-AAAA00000000:root:0:allow:read', self.get_acl(file.name)[b'acl_extended'])
|
|
self.set_acl(file2.name, b'!#acl 1\ngroup:ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000000:staff:0:allow:read\nuser:FFFFEEEE-DDDD-CCCC-BBBB-AAAA00000000:root:0:allow:read\n', numeric_owner=True)
|
|
self.assert_in(b'group:ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000000:wheel:0:allow:read', self.get_acl(file2.name)[b'acl_extended'])
|
|
self.assert_in(b'group:ABCDEFAB-CDEF-ABCD-EFAB-CDEF00000000::0:allow:read', self.get_acl(file2.name, numeric_owner=True)[b'acl_extended'])
|
|
|