Change get_disk_stats to always take a Unicode path, and work around os.statvfs not accepting Unicode paths. refs #2375

Signed-off-by: Daira Hopwood <daira@jacaranda.org>
This commit is contained in:
Daira Hopwood 2015-02-05 23:28:10 +00:00
parent 15dcab825a
commit 03d01fe81d
3 changed files with 10 additions and 5 deletions

View File

@ -352,7 +352,7 @@ class Server(unittest.TestCase):
if 'cygwin' in syslow or 'windows' in syslow or 'darwin' in syslow: if 'cygwin' in syslow or 'windows' in syslow or 'darwin' in syslow:
raise unittest.SkipTest("If your filesystem doesn't support efficient sparse files then it is very expensive (Mac OS X and Windows don't support efficient sparse files).") raise unittest.SkipTest("If your filesystem doesn't support efficient sparse files then it is very expensive (Mac OS X and Windows don't support efficient sparse files).")
avail = fileutil.get_available_space('.', 512*2**20) avail = fileutil.get_available_space(u".", 512*2**20)
if avail <= 4*2**30: if avail <= 4*2**30:
raise unittest.SkipTest("This test will spuriously fail if you have less than 4 GiB free on your filesystem.") raise unittest.SkipTest("This test will spuriously fail if you have less than 4 GiB free on your filesystem.")

View File

@ -536,11 +536,11 @@ class FileUtil(ReallyEqualMixin, unittest.TestCase):
self.failUnlessReallyEqual(fileutil.windows_expanduser(u"a\\~\\foo"), u"a\\~\\foo") self.failUnlessReallyEqual(fileutil.windows_expanduser(u"a\\~\\foo"), u"a\\~\\foo")
def test_disk_stats(self): def test_disk_stats(self):
avail = fileutil.get_available_space('.', 2**14) avail = fileutil.get_available_space(u".", 2**14)
if avail == 0: if avail == 0:
raise unittest.SkipTest("This test will spuriously fail there is no disk space left.") raise unittest.SkipTest("This test will spuriously fail there is no disk space left.")
disk = fileutil.get_disk_stats('.', 2**13) disk = fileutil.get_disk_stats(u".", 2**13)
self.failUnless(disk['total'] > 0, disk['total']) self.failUnless(disk['total'] > 0, disk['total'])
# we tolerate used==0 for a Travis-CI bug, see #2290 # we tolerate used==0 for a Travis-CI bug, see #2290
self.failUnless(disk['used'] >= 0, disk['used']) self.failUnless(disk['used'] >= 0, disk['used'])
@ -551,7 +551,7 @@ class FileUtil(ReallyEqualMixin, unittest.TestCase):
def test_disk_stats_avail_nonnegative(self): def test_disk_stats_avail_nonnegative(self):
# This test will spuriously fail if you have more than 2^128 # This test will spuriously fail if you have more than 2^128
# bytes of available space on your filesystem. # bytes of available space on your filesystem.
disk = fileutil.get_disk_stats('.', 2**128) disk = fileutil.get_disk_stats(u".", 2**128)
self.failUnlessEqual(disk['avail'], 0) self.failUnlessEqual(disk['avail'], 0)
class PollMixinTests(unittest.TestCase): class PollMixinTests(unittest.TestCase):

View File

@ -452,6 +452,9 @@ def get_disk_stats(whichdir, reserved_space=0):
filesystem as reserved_space. filesystem as reserved_space.
""" """
if not isinstance(whichdir, unicode):
raise AssertionError("whichdir must be Unicode")
if have_GetDiskFreeSpaceExW: if have_GetDiskFreeSpaceExW:
# If this is a Windows system and GetDiskFreeSpaceExW is available, use it. # If this is a Windows system and GetDiskFreeSpaceExW is available, use it.
# (This might put up an error dialog unless # (This might put up an error dialog unless
@ -475,7 +478,9 @@ def get_disk_stats(whichdir, reserved_space=0):
# <http://docs.python.org/library/os.html#os.statvfs> # <http://docs.python.org/library/os.html#os.statvfs>
# <http://opengroup.org/onlinepubs/7990989799/xsh/fstatvfs.html> # <http://opengroup.org/onlinepubs/7990989799/xsh/fstatvfs.html>
# <http://opengroup.org/onlinepubs/7990989799/xsh/sysstatvfs.h.html> # <http://opengroup.org/onlinepubs/7990989799/xsh/sysstatvfs.h.html>
s = os.statvfs(whichdir)
from allmydata.util.encodingutil import get_filesystem_encoding
s = os.statvfs(whichdir.encode(get_filesystem_encoding()))
# on my mac laptop: # on my mac laptop:
# statvfs(2) is a wrapper around statfs(2). # statvfs(2) is a wrapper around statfs(2).