Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(255)

Side by Side Diff: third_party/gsutil/boto/tests/integration/s3/test_multidelete.py

Issue 12317103: Added gsutil to depot tools (Closed) Base URL: https://chromium.googlesource.com/chromium/tools/depot_tools.git@master
Patch Set: added readme Created 7 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 # -*- coding: utf-8 -*-
2
3 # Copyright (c) 2011 Mitch Garnaat http://garnaat.org/
4 # All rights reserved.
5 #
6 # Permission is hereby granted, free of charge, to any person obtaining a
7 # copy of this software and associated documentation files (the
8 # "Software"), to deal in the Software without restriction, including
9 # without limitation the rights to use, copy, modify, merge, publish, dis-
10 # tribute, sublicense, and/or sell copies of the Software, and to permit
11 # persons to whom the Software is furnished to do so, subject to the fol-
12 # lowing conditions:
13 #
14 # The above copyright notice and this permission notice shall be included
15 # in all copies or substantial portions of the Software.
16 #
17 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
18 # OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
19 # ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
20 # SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
21 # WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22 # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
23 # IN THE SOFTWARE.
24
25 """
26 Some unit tests for the S3 MultiDelete
27 """
28
29 import unittest
30 import time
31 from boto.s3.key import Key
32 from boto.s3.deletemarker import DeleteMarker
33 from boto.s3.prefix import Prefix
34 from boto.s3.connection import S3Connection
35 from boto.exception import S3ResponseError
36
37 class S3MultiDeleteTest(unittest.TestCase):
38 s3 = True
39
40 def setUp(self):
41 self.conn = S3Connection()
42 self.bucket_name = 'multidelete-%d' % int(time.time())
43 self.bucket = self.conn.create_bucket(self.bucket_name)
44
45 def tearDown(self):
46 for key in self.bucket:
47 key.delete()
48 self.bucket.delete()
49
50 def test_delete_nothing(self):
51 result = self.bucket.delete_keys([])
52 self.assertEqual(len(result.deleted), 0)
53 self.assertEqual(len(result.errors), 0)
54
55 def test_delete_illegal(self):
56 result = self.bucket.delete_keys([{"dict":"notallowed"}])
57 self.assertEqual(len(result.deleted), 0)
58 self.assertEqual(len(result.errors), 1)
59
60 def test_delete_mix(self):
61 result = self.bucket.delete_keys(["king",
62 ("mice", None),
63 Key(name="regular"),
64 Key(),
65 Prefix(name="folder/"),
66 DeleteMarker(name="deleted"),
67 {"bad":"type"}])
68 self.assertEqual(len(result.deleted), 4)
69 self.assertEqual(len(result.errors), 3)
70
71 def test_delete_quietly(self):
72 result = self.bucket.delete_keys(["king"], quiet=True)
73 self.assertEqual(len(result.deleted), 0)
74 self.assertEqual(len(result.errors), 0)
75
76 def test_delete_must_escape(self):
77 result = self.bucket.delete_keys([Key(name=">_<;")])
78 self.assertEqual(len(result.deleted), 1)
79 self.assertEqual(len(result.errors), 0)
80
81 def test_delete_unknown_version(self):
82 no_ver = Key(name="no")
83 no_ver.version_id = "version"
84 result = self.bucket.delete_keys([no_ver])
85 self.assertEqual(len(result.deleted), 0)
86 self.assertEqual(len(result.errors), 1)
87
88 def test_delete_kanji(self):
89 result = self.bucket.delete_keys([u"漢字", Key(name=u"日本語")])
90 self.assertEqual(len(result.deleted), 2)
91 self.assertEqual(len(result.errors), 0)
92
93 def test_delete_empty_by_list(self):
94 result = self.bucket.delete_keys(self.bucket.list())
95 self.assertEqual(len(result.deleted), 0)
96 self.assertEqual(len(result.errors), 0)
97
98 def test_delete_kanji_by_list(self):
99 for key_name in [u"漢字", u"日本語", u"テスト"]:
100 key = self.bucket.new_key(key_name)
101 key.set_contents_from_string('this is a test')
102 result = self.bucket.delete_keys(self.bucket.list())
103 self.assertEqual(len(result.deleted), 3)
104 self.assertEqual(len(result.errors), 0)
105
106 def test_delete_with_prefixes(self):
107 for key_name in ["a", "a/b", "b"]:
108 key = self.bucket.new_key(key_name)
109 key.set_contents_from_string('this is a test')
110
111 # First delete all "files": "a" and "b"
112 result = self.bucket.delete_keys(self.bucket.list(delimiter="/"))
113 self.assertEqual(len(result.deleted), 2)
114 # Using delimiter will cause 1 common prefix to be listed
115 # which will be skipped as an error.
116 self.assertEqual(len(result.errors), 1)
117 self.assertEqual(result.errors[0].key, "a/")
118
119 # Next delete any remaining objects: "a/b"
120 result = self.bucket.delete_keys(self.bucket.list())
121 self.assertEqual(len(result.deleted), 1)
122 self.assertEqual(len(result.errors), 0)
123 self.assertEqual(result.deleted[0].key, "a/b")
124
125 def test_delete_too_many_versions(self):
126 # configure versioning first
127 self.bucket.configure_versioning(True)
128
129 # Add 1000 initial versions as DMs by deleting them :-)
130 # Adding 1000 objects is painful otherwise...
131 key_names = ['key-%03d' % i for i in range(0, 1000)]
132 result = self.bucket.delete_keys(key_names)
133 self.assertEqual(len(result.deleted), 1000)
134 self.assertEqual(len(result.errors), 0)
135
136 # delete them again to create 1000 more delete markers
137 result = self.bucket.delete_keys(key_names)
138 self.assertEqual(len(result.deleted), 1000)
139 self.assertEqual(len(result.errors), 0)
140
141 # Sometimes takes AWS sometime to settle
142 time.sleep(10)
143
144 # delete all versions to delete 2000 objects.
145 # this tests the 1000 limit.
146 result = self.bucket.delete_keys(self.bucket.list_versions())
147 self.assertEqual(len(result.deleted), 2000)
148 self.assertEqual(len(result.errors), 0)
149
150 def test_1(self):
151 nkeys = 100
152
153 # create a bunch of keynames
154 key_names = ['key-%03d' % i for i in range(0, nkeys)]
155
156 # create the corresponding keys
157 for key_name in key_names:
158 key = self.bucket.new_key(key_name)
159 key.set_contents_from_string('this is a test')
160
161 # now count keys in bucket
162 n = 0
163 for key in self.bucket:
164 n += 1
165
166 self.assertEqual(n, nkeys)
167
168 # now delete them all
169 result = self.bucket.delete_keys(key_names)
170
171 self.assertEqual(len(result.deleted), nkeys)
172 self.assertEqual(len(result.errors), 0)
173
174 time.sleep(5)
175
176 # now count keys in bucket
177 n = 0
178 for key in self.bucket:
179 n += 1
180
181 self.assertEqual(n, 0)
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698