Index: third_party/gsutil/gslib/tests/test_du.py |
diff --git a/third_party/gsutil/gslib/tests/test_du.py b/third_party/gsutil/gslib/tests/test_du.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..2774c32df701f3f6b6c180e4eae10ff8e0a09fe5 |
--- /dev/null |
+++ b/third_party/gsutil/gslib/tests/test_du.py |
@@ -0,0 +1,237 @@ |
+# -*- coding: utf-8 -*- |
+# Copyright 2013 Google Inc. All Rights Reserved. |
+# |
+# Licensed under the Apache License, Version 2.0 (the "License"); |
+# you may not use this file except in compliance with the License. |
+# You may obtain a copy of the License at |
+# |
+# http://www.apache.org/licenses/LICENSE-2.0 |
+# |
+# Unless required by applicable law or agreed to in writing, software |
+# distributed under the License is distributed on an "AS IS" BASIS, |
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
+# See the License for the specific language governing permissions and |
+# limitations under the License. |
+"""Tests for du command.""" |
+ |
+from __future__ import absolute_import |
+ |
+import gslib.tests.testcase as testcase |
+from gslib.tests.testcase.integration_testcase import SkipForS3 |
+from gslib.tests.util import ObjectToURI as suri |
+from gslib.util import Retry |
+ |
+ |
+class TestDu(testcase.GsUtilIntegrationTestCase): |
+ """Integration tests for du command.""" |
+ |
+ def _create_nested_subdir(self): |
+ """Creates a nested subdirectory for use by tests in this module.""" |
+ bucket_uri = self.CreateBucket() |
+ obj_uris = [] |
+ obj_uris.append(self.CreateObject( |
+ bucket_uri=bucket_uri, object_name='sub1/five', contents='5five')) |
+ obj_uris.append(self.CreateObject( |
+ bucket_uri=bucket_uri, object_name='sub1/four', contents='four')) |
+ obj_uris.append(self.CreateObject( |
+ bucket_uri=bucket_uri, object_name='sub1/sub2/five', contents='5five')) |
+ obj_uris.append(self.CreateObject( |
+ bucket_uri=bucket_uri, object_name='sub1/sub2/four', contents='four')) |
+ self.AssertNObjectsInBucket(bucket_uri, 4) |
+ return bucket_uri, obj_uris |
+ |
+ def test_object(self): |
+ obj_uri = self.CreateObject(contents='foo') |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil(['du', suri(obj_uri)], return_stdout=True) |
+ self.assertEqual(stdout, '%-10s %s\n' % (3, suri(obj_uri))) |
+ _Check() |
+ |
+ def test_bucket(self): |
+ bucket_uri = self.CreateBucket() |
+ obj_uri = self.CreateObject(bucket_uri=bucket_uri, contents='foo') |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil(['du', suri(bucket_uri)], return_stdout=True) |
+ self.assertEqual(stdout, '%-10s %s\n' % (3, suri(obj_uri))) |
+ _Check() |
+ |
+ def test_subdirs(self): |
+ """Tests that subdirectory sizes are correctly calculated and listed.""" |
+ bucket_uri, obj_uris = self._create_nested_subdir() |
+ |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil(['du', suri(bucket_uri)], return_stdout=True) |
+ self.assertSetEqual(set(stdout.splitlines()), set([ |
+ '%-10s %s' % (5, suri(obj_uris[0])), |
+ '%-10s %s' % (4, suri(obj_uris[1])), |
+ '%-10s %s' % (5, suri(obj_uris[2])), |
+ '%-10s %s' % (4, suri(obj_uris[3])), |
+ '%-10s %s/sub1/sub2/' % (9, suri(bucket_uri)), |
+ '%-10s %s/sub1/' % (18, suri(bucket_uri)), |
+ ])) |
+ _Check() |
+ |
+ def test_multi_args(self): |
+ """Tests running du with multiple command line arguments.""" |
+ bucket_uri = self.CreateBucket() |
+ obj_uri1 = self.CreateObject(bucket_uri=bucket_uri, contents='foo') |
+ obj_uri2 = self.CreateObject(bucket_uri=bucket_uri, contents='foo2') |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil(['du', suri(obj_uri1), suri(obj_uri2)], |
+ return_stdout=True) |
+ self.assertSetEqual(set(stdout.splitlines()), set([ |
+ '%-10s %s' % (3, suri(obj_uri1)), |
+ '%-10s %s' % (4, suri(obj_uri2)), |
+ ])) |
+ _Check() |
+ |
+ def test_total(self): |
+ """Tests total size listing via the -c flag.""" |
+ bucket_uri = self.CreateBucket() |
+ obj_uri1 = self.CreateObject(bucket_uri=bucket_uri, contents='foo') |
+ obj_uri2 = self.CreateObject(bucket_uri=bucket_uri, contents='zebra') |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil(['du', '-c', suri(bucket_uri)], |
+ return_stdout=True) |
+ self.assertSetEqual(set(stdout.splitlines()), set([ |
+ '%-10s %s' % (3, suri(obj_uri1)), |
+ '%-10s %s' % (5, suri(obj_uri2)), |
+ '%-10s total' % 8, |
+ ])) |
+ _Check() |
+ |
+ def test_human_readable(self): |
+ obj_uri = self.CreateObject(contents='x' * 2048) |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil(['du', '-h', suri(obj_uri)], return_stdout=True) |
+ self.assertEqual(stdout, '%-10s %s\n' % ('2 KiB', suri(obj_uri))) |
+ _Check() |
+ |
+ def test_summary(self): |
+ """Tests summary listing with the -s flag.""" |
+ bucket_uri1, _ = self._create_nested_subdir() |
+ bucket_uri2, _ = self._create_nested_subdir() |
+ |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil([ |
+ 'du', '-s', suri(bucket_uri1), suri(bucket_uri2)], return_stdout=True) |
+ self.assertSetEqual(set(stdout.splitlines()), set([ |
+ '%-10s %s' % (18, suri(bucket_uri1)), |
+ '%-10s %s' % (18, suri(bucket_uri2)), |
+ ])) |
+ _Check() |
+ |
+ def test_subdir_summary(self): |
+ """Tests summary listing with the -s flag on a subdirectory.""" |
+ bucket_uri1, _ = self._create_nested_subdir() |
+ bucket_uri2, _ = self._create_nested_subdir() |
+ subdir1 = suri(bucket_uri1, 'sub1') |
+ subdir2 = suri(bucket_uri2, 'sub1') |
+ |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil( |
+ ['du', '-s', subdir1, subdir2], return_stdout=True) |
+ self.assertSetEqual(set(stdout.splitlines()), set([ |
+ '%-10s %s' % (18, subdir1), |
+ '%-10s %s' % (18, subdir2), |
+ ])) |
+ _Check() |
+ |
+ @SkipForS3('S3 lists versions in reverse order.') |
+ def test_versioned(self): |
+ """Tests listing all versions with the -a flag.""" |
+ bucket_uri = self.CreateVersionedBucket() |
+ object_uri1 = self.CreateObject( |
+ bucket_uri=bucket_uri, object_name='foo', contents='foo') |
+ object_uri2 = self.CreateObject( |
+ bucket_uri=bucket_uri, object_name='foo', contents='foo2') |
+ |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check1(): |
+ stdout = self.RunGsUtil(['du', suri(bucket_uri)], return_stdout=True) |
+ self.assertEqual(stdout, '%-10s %s\n' % (4, suri(object_uri2))) |
+ _Check1() |
+ |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check2(): |
+ stdout = self.RunGsUtil(['du', '-a', suri(bucket_uri)], |
+ return_stdout=True) |
+ self.assertSetEqual(set(stdout.splitlines()), set([ |
+ '%-10s %s#%s' % ( |
+ 3, suri(object_uri1), object_uri1.generation), |
+ '%-10s %s#%s' % ( |
+ 4, suri(object_uri2), object_uri2.generation), |
+ ])) |
+ _Check2() |
+ |
+ def test_null_endings(self): |
+ """Tests outputting 0-endings with the -0 flag.""" |
+ bucket_uri = self.CreateBucket() |
+ obj_uri1 = self.CreateObject(bucket_uri=bucket_uri, contents='foo') |
+ obj_uri2 = self.CreateObject(bucket_uri=bucket_uri, contents='zebra') |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil(['du', '-0c', suri(bucket_uri)], |
+ return_stdout=True) |
+ self.assertSetEqual(set(stdout.split('\0')), set([ |
+ '%-10s %s' % (3, suri(obj_uri1)), |
+ '%-10s %s' % (5, suri(obj_uri2)), |
+ '%-10s total' % 8, |
+ '' |
+ ])) |
+ _Check() |
+ |
+ def test_excludes(self): |
+ """Tests exclude pattern excluding certain file paths.""" |
+ bucket_uri, obj_uris = self._create_nested_subdir() |
+ |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil([ |
+ 'du', '-e', '*sub2/five*', '-e', '*sub1/four', |
+ suri(bucket_uri)], return_stdout=True) |
+ self.assertSetEqual(set(stdout.splitlines()), set([ |
+ '%-10s %s' % (5, suri(obj_uris[0])), |
+ '%-10s %s' % (4, suri(obj_uris[3])), |
+ '%-10s %s/sub1/sub2/' % (4, suri(bucket_uri)), |
+ '%-10s %s/sub1/' % (9, suri(bucket_uri)), |
+ ])) |
+ _Check() |
+ |
+ def test_excludes_file(self): |
+ """Tests file exclusion with the -X flag.""" |
+ bucket_uri, obj_uris = self._create_nested_subdir() |
+ fpath = self.CreateTempFile(contents='*sub2/five*\n*sub1/four') |
+ |
+ # Use @Retry as hedge against bucket listing eventual consistency. |
+ @Retry(AssertionError, tries=3, timeout_secs=1) |
+ def _Check(): |
+ stdout = self.RunGsUtil([ |
+ 'du', '-X', fpath, suri(bucket_uri)], return_stdout=True) |
+ self.assertSetEqual(set(stdout.splitlines()), set([ |
+ '%-10s %s' % (5, suri(obj_uris[0])), |
+ '%-10s %s' % (4, suri(obj_uris[3])), |
+ '%-10s %s/sub1/sub2/' % (4, suri(bucket_uri)), |
+ '%-10s %s/sub1/' % (9, suri(bucket_uri)), |
+ ])) |
+ _Check() |