#14807: fix BB failures on Windows - avoid to to rely too many details of the mode string.

This commit is contained in:
Giampaolo Rodola' 2012-05-16 16:01:59 +02:00
parent 12ea86adce
commit e126678216
1 changed files with 22 additions and 11 deletions

View File

@ -23,24 +23,35 @@ class TestFilemode(unittest.TestCase):
def test_mode(self): def test_mode(self):
with open(TESTFN, 'w'): with open(TESTFN, 'w'):
pass pass
os.chmod(TESTFN, 0o700) if os.name == 'posix':
self.assertEqual(get_mode(), '-rwx------') os.chmod(TESTFN, 0o700)
os.chmod(TESTFN, 0o070) self.assertEqual(get_mode(), '-rwx------')
self.assertEqual(get_mode(), '----rwx---') os.chmod(TESTFN, 0o070)
os.chmod(TESTFN, 0o007) self.assertEqual(get_mode(), '----rwx---')
self.assertEqual(get_mode(), '-------rwx') os.chmod(TESTFN, 0o007)
os.chmod(TESTFN, 0o444) self.assertEqual(get_mode(), '-------rwx')
self.assertEqual(get_mode(), '-r--r--r--') os.chmod(TESTFN, 0o444)
self.assertEqual(get_mode(), '-r--r--r--')
else:
os.chmod(TESTFN, 0o700)
self.assertEqual(get_mode()[:3], '-rw')
def test_directory(self): def test_directory(self):
os.mkdir(TESTFN) os.mkdir(TESTFN)
os.chmod(TESTFN, 0o700) os.chmod(TESTFN, 0o700)
self.assertEqual(get_mode(), 'drwx------') if os.name == 'posix':
self.assertEqual(get_mode(), 'drwx------')
else:
self.assertEqual(get_mode()[0], 'd')
@unittest.skipUnless(hasattr(os, 'symlink'), 'os.symlink not available') @unittest.skipUnless(hasattr(os, 'symlink'), 'os.symlink not available')
def test_link(self): def test_link(self):
os.symlink(os.getcwd(), TESTFN) try:
self.assertEqual(get_mode()[0], 'l') os.symlink(os.getcwd(), TESTFN)
except (OSError, NotImplementedError) as err:
raise unittest.SkipTest(str(err))
else:
self.assertEqual(get_mode()[0], 'l')
@unittest.skipUnless(hasattr(os, 'mkfifo'), 'os.mkfifo not available') @unittest.skipUnless(hasattr(os, 'mkfifo'), 'os.mkfifo not available')
def test_fifo(self): def test_fifo(self):