gcloud 0.0.7 → 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (998) hide show
  1. checksums.yaml +7 -0
  2. data/{packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/ext/__init__.py → .gemtest} +0 -0
  3. data/.rubocop.yml +17 -0
  4. data/CHANGELOG.md +5 -0
  5. data/CONTRIBUTING.md +93 -0
  6. data/LICENSE +201 -674
  7. data/Manifest.txt +66 -0
  8. data/README.md +110 -12
  9. data/Rakefile +34 -3
  10. data/gcloud.gemspec +48 -17
  11. data/lib/gcloud.rb +8 -0
  12. data/lib/gcloud/backoff.rb +115 -0
  13. data/lib/gcloud/credentials.rb +124 -0
  14. data/lib/gcloud/datastore.rb +66 -0
  15. data/lib/gcloud/datastore/connection.rb +177 -0
  16. data/lib/gcloud/datastore/credentials.rb +41 -0
  17. data/lib/gcloud/datastore/dataset.rb +259 -0
  18. data/lib/gcloud/datastore/dataset/lookup_results.rb +60 -0
  19. data/lib/gcloud/datastore/dataset/query_results.rb +87 -0
  20. data/lib/gcloud/datastore/entity.rb +257 -0
  21. data/lib/gcloud/datastore/errors.rb +65 -0
  22. data/lib/gcloud/datastore/key.rb +151 -0
  23. data/lib/gcloud/datastore/properties.rb +102 -0
  24. data/lib/gcloud/datastore/proto.rb +253 -0
  25. data/lib/gcloud/datastore/query.rb +189 -0
  26. data/lib/gcloud/datastore/transaction.rb +116 -0
  27. data/lib/gcloud/proto/datastore_v1.pb.rb +377 -0
  28. data/lib/gcloud/storage.rb +78 -0
  29. data/lib/gcloud/storage/bucket.rb +254 -0
  30. data/lib/gcloud/storage/bucket/acl.rb +311 -0
  31. data/lib/gcloud/storage/bucket/list.rb +45 -0
  32. data/lib/gcloud/storage/connection.rb +358 -0
  33. data/{packages/gsutil/gslib/commands/__init__.py → lib/gcloud/storage/credentials.rb} +13 -2
  34. data/lib/gcloud/storage/errors.rb +78 -0
  35. data/lib/gcloud/storage/file.rb +287 -0
  36. data/lib/gcloud/storage/file/acl.rb +172 -0
  37. data/lib/gcloud/storage/file/list.rb +52 -0
  38. data/lib/gcloud/storage/file/verifier.rb +65 -0
  39. data/lib/gcloud/storage/project.rb +119 -0
  40. data/lib/gcloud/version.rb +5 -0
  41. data/{packages/gsutil/gslib/tests/testcase/__init__.py → rakelib/console.rake} +14 -4
  42. data/{packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/version.py → rakelib/manifest.rake} +11 -4
  43. data/{packages/gsutil/gslib/addlhelp/__init__.py → rakelib/proto.rake} +4 -2
  44. data/{packages/gsutil/gslib/tests/__init__.py → rakelib/rubocop.rake} +4 -2
  45. data/rakelib/test.rake +144 -0
  46. data/test/gcloud/datastore/proto/test_cursor.rb +36 -0
  47. data/test/gcloud/datastore/proto/test_direction.rb +60 -0
  48. data/test/gcloud/datastore/proto/test_operator.rb +76 -0
  49. data/test/gcloud/datastore/proto/test_value.rb +231 -0
  50. data/test/gcloud/datastore/test_connection.rb +93 -0
  51. data/test/gcloud/datastore/test_credentials.rb +38 -0
  52. data/test/gcloud/datastore/test_dataset.rb +413 -0
  53. data/test/gcloud/datastore/test_entity.rb +161 -0
  54. data/test/gcloud/datastore/test_entity_exclude.rb +225 -0
  55. data/test/gcloud/datastore/test_key.rb +189 -0
  56. data/test/gcloud/datastore/test_query.rb +271 -0
  57. data/test/gcloud/datastore/test_transaction.rb +121 -0
  58. data/test/gcloud/storage/test_backoff.rb +127 -0
  59. data/test/gcloud/storage/test_bucket.rb +270 -0
  60. data/test/gcloud/storage/test_bucket_acl.rb +253 -0
  61. data/test/gcloud/storage/test_default_acl.rb +256 -0
  62. data/test/gcloud/storage/test_file.rb +221 -0
  63. data/test/gcloud/storage/test_file_acl.rb +367 -0
  64. data/test/gcloud/storage/test_project.rb +180 -0
  65. data/{packages/gsutil/gslib/no_op_auth_plugin.py → test/gcloud/storage/test_storage.rb} +14 -15
  66. data/test/gcloud/storage/test_verifier.rb +62 -0
  67. data/test/gcloud/test_version.rb +8 -0
  68. data/test/helper.rb +91 -0
  69. metadata +259 -1020
  70. data.tar.gz.sig +0 -2
  71. data/CHANGELOG +0 -14
  72. data/Makefile +0 -13
  73. data/Manifest +0 -937
  74. data/TODO +0 -2
  75. data/bin/gcloud +0 -7
  76. data/bin/gcutil-symlink +0 -53
  77. data/bin/gsutil-symlink +0 -377
  78. data/init.rb +0 -3
  79. data/packages/README +0 -6
  80. data/packages/gcutil-1.7.1.tar.gz +0 -0
  81. data/packages/gcutil-1.7.1/CHANGELOG +0 -197
  82. data/packages/gcutil-1.7.1/LICENSE +0 -202
  83. data/packages/gcutil-1.7.1/VERSION +0 -1
  84. data/packages/gcutil-1.7.1/gcutil +0 -53
  85. data/packages/gcutil-1.7.1/lib/google_api_python_client/LICENSE +0 -23
  86. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/__init__.py +0 -1
  87. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/__init__.pyc +0 -0
  88. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/discovery.py +0 -743
  89. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/discovery.pyc +0 -0
  90. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/errors.py +0 -123
  91. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/errors.pyc +0 -0
  92. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/http.py +0 -1443
  93. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/http.pyc +0 -0
  94. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/mimeparse.py +0 -172
  95. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/mimeparse.pyc +0 -0
  96. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/model.py +0 -385
  97. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/model.pyc +0 -0
  98. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/schema.py +0 -303
  99. data/packages/gcutil-1.7.1/lib/google_api_python_client/apiclient/schema.pyc +0 -0
  100. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/__init__.py +0 -1
  101. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/__init__.pyc +0 -0
  102. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/anyjson.py +0 -32
  103. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/anyjson.pyc +0 -0
  104. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/appengine.py +0 -528
  105. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/client.py +0 -1139
  106. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/client.pyc +0 -0
  107. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/clientsecrets.py +0 -105
  108. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/clientsecrets.pyc +0 -0
  109. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/crypt.py +0 -244
  110. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/crypt.pyc +0 -0
  111. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/django_orm.py +0 -124
  112. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/file.py +0 -107
  113. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/locked_file.py +0 -343
  114. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/locked_file.pyc +0 -0
  115. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/multistore_file.py +0 -379
  116. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/multistore_file.pyc +0 -0
  117. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/tools.py +0 -174
  118. data/packages/gcutil-1.7.1/lib/google_api_python_client/oauth2client/tools.pyc +0 -0
  119. data/packages/gcutil-1.7.1/lib/google_api_python_client/uritemplate/__init__.py +0 -147
  120. data/packages/gcutil-1.7.1/lib/google_api_python_client/uritemplate/__init__.pyc +0 -0
  121. data/packages/gcutil-1.7.1/lib/google_apputils/LICENSE +0 -202
  122. data/packages/gcutil-1.7.1/lib/google_apputils/google/__init__.py +0 -3
  123. data/packages/gcutil-1.7.1/lib/google_apputils/google/__init__.pyc +0 -0
  124. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/__init__.py +0 -3
  125. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/__init__.pyc +0 -0
  126. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/app.py +0 -356
  127. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/app.pyc +0 -0
  128. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/appcommands.py +0 -783
  129. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/appcommands.pyc +0 -0
  130. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/basetest.py +0 -1260
  131. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/datelib.py +0 -421
  132. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/debug.py +0 -60
  133. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/file_util.py +0 -181
  134. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/resources.py +0 -67
  135. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/run_script_module.py +0 -217
  136. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/setup_command.py +0 -159
  137. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/shellutil.py +0 -49
  138. data/packages/gcutil-1.7.1/lib/google_apputils/google/apputils/stopwatch.py +0 -204
  139. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/__init__.py +0 -0
  140. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/__init__.pyc +0 -0
  141. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/auth_helper.py +0 -140
  142. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/auth_helper.pyc +0 -0
  143. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/auth_helper_test.py +0 -149
  144. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/auto_auth.py +0 -130
  145. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/auto_auth.pyc +0 -0
  146. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/auto_auth_test.py +0 -75
  147. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/basic_cmds.py +0 -128
  148. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/basic_cmds.pyc +0 -0
  149. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/basic_cmds_test.py +0 -111
  150. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/command_base.py +0 -1808
  151. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/command_base.pyc +0 -0
  152. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/command_base_test.py +0 -1651
  153. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/compute/v1beta13.json +0 -2851
  154. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/compute/v1beta14.json +0 -3361
  155. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/disk_cmds.py +0 -342
  156. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/disk_cmds.pyc +0 -0
  157. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/disk_cmds_test.py +0 -474
  158. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/firewall_cmds.py +0 -344
  159. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/firewall_cmds.pyc +0 -0
  160. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/firewall_cmds_test.py +0 -231
  161. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/flags_cache.py +0 -274
  162. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/flags_cache.pyc +0 -0
  163. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/gcutil +0 -89
  164. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/gcutil_logging.py +0 -69
  165. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/gcutil_logging.pyc +0 -0
  166. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/image_cmds.py +0 -262
  167. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/image_cmds.pyc +0 -0
  168. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/image_cmds_test.py +0 -172
  169. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/instance_cmds.py +0 -1506
  170. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/instance_cmds.pyc +0 -0
  171. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/instance_cmds_test.py +0 -1904
  172. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/kernel_cmds.py +0 -91
  173. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/kernel_cmds.pyc +0 -0
  174. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/kernel_cmds_test.py +0 -56
  175. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/machine_type_cmds.py +0 -106
  176. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/machine_type_cmds.pyc +0 -0
  177. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/machine_type_cmds_test.py +0 -59
  178. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/metadata.py +0 -96
  179. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/metadata.pyc +0 -0
  180. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/metadata_lib.py +0 -357
  181. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/metadata_lib.pyc +0 -0
  182. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/metadata_test.py +0 -84
  183. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/mock_api.py +0 -420
  184. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/mock_metadata.py +0 -58
  185. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/move_cmds.py +0 -824
  186. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/move_cmds.pyc +0 -0
  187. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/move_cmds_test.py +0 -307
  188. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/network_cmds.py +0 -178
  189. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/network_cmds.pyc +0 -0
  190. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/network_cmds_test.py +0 -133
  191. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/operation_cmds.py +0 -181
  192. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/operation_cmds.pyc +0 -0
  193. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/operation_cmds_test.py +0 -196
  194. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/path_initializer.py +0 -38
  195. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/path_initializer.pyc +0 -0
  196. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/project_cmds.py +0 -173
  197. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/project_cmds.pyc +0 -0
  198. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/project_cmds_test.py +0 -111
  199. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/scopes.py +0 -61
  200. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/scopes.pyc +0 -0
  201. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/scopes_test.py +0 -50
  202. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/snapshot_cmds.py +0 -276
  203. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/snapshot_cmds.pyc +0 -0
  204. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/snapshot_cmds_test.py +0 -260
  205. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/ssh_keys.py +0 -266
  206. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/ssh_keys.pyc +0 -0
  207. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/ssh_keys_test.py +0 -128
  208. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/table_formatter.py +0 -563
  209. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/table_formatter.pyc +0 -0
  210. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/thread_pool.py +0 -188
  211. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/thread_pool.pyc +0 -0
  212. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/thread_pool_test.py +0 -88
  213. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/utils.py +0 -208
  214. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/utils.pyc +0 -0
  215. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/utils_test.py +0 -193
  216. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/version.pyc +0 -0
  217. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/version_checker.py +0 -246
  218. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/version_checker.pyc +0 -0
  219. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/version_checker_test.py +0 -271
  220. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/zone_cmds.py +0 -151
  221. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/zone_cmds.pyc +0 -0
  222. data/packages/gcutil-1.7.1/lib/google_compute_engine/gcutil/zone_cmds_test.py +0 -60
  223. data/packages/gcutil-1.7.1/lib/httplib2/LICENSE +0 -21
  224. data/packages/gcutil-1.7.1/lib/httplib2/httplib2/__init__.py +0 -1630
  225. data/packages/gcutil-1.7.1/lib/httplib2/httplib2/__init__.pyc +0 -0
  226. data/packages/gcutil-1.7.1/lib/httplib2/httplib2/cacerts.txt +0 -714
  227. data/packages/gcutil-1.7.1/lib/httplib2/httplib2/iri2uri.py +0 -110
  228. data/packages/gcutil-1.7.1/lib/httplib2/httplib2/iri2uri.pyc +0 -0
  229. data/packages/gcutil-1.7.1/lib/httplib2/httplib2/socks.py +0 -438
  230. data/packages/gcutil-1.7.1/lib/httplib2/httplib2/socks.pyc +0 -0
  231. data/packages/gcutil-1.7.1/lib/iso8601/LICENSE +0 -20
  232. data/packages/gcutil-1.7.1/lib/iso8601/iso8601/__init__.py +0 -1
  233. data/packages/gcutil-1.7.1/lib/iso8601/iso8601/__init__.pyc +0 -0
  234. data/packages/gcutil-1.7.1/lib/iso8601/iso8601/iso8601.py +0 -102
  235. data/packages/gcutil-1.7.1/lib/iso8601/iso8601/iso8601.pyc +0 -0
  236. data/packages/gcutil-1.7.1/lib/iso8601/iso8601/test_iso8601.py +0 -111
  237. data/packages/gcutil-1.7.1/lib/python_gflags/AUTHORS +0 -2
  238. data/packages/gcutil-1.7.1/lib/python_gflags/LICENSE +0 -28
  239. data/packages/gcutil-1.7.1/lib/python_gflags/gflags.py +0 -2862
  240. data/packages/gcutil-1.7.1/lib/python_gflags/gflags.pyc +0 -0
  241. data/packages/gcutil-1.7.1/lib/python_gflags/gflags2man.py +0 -544
  242. data/packages/gcutil-1.7.1/lib/python_gflags/gflags_validators.py +0 -187
  243. data/packages/gcutil-1.7.1/lib/python_gflags/gflags_validators.pyc +0 -0
  244. data/packages/gsutil.tar.gz +0 -0
  245. data/packages/gsutil/CHECKSUM +0 -1
  246. data/packages/gsutil/COPYING +0 -202
  247. data/packages/gsutil/LICENSE.third_party +0 -295
  248. data/packages/gsutil/MANIFEST.in +0 -5
  249. data/packages/gsutil/README +0 -38
  250. data/packages/gsutil/README.pkg +0 -49
  251. data/packages/gsutil/ReleaseNotes.txt +0 -780
  252. data/packages/gsutil/VERSION +0 -1
  253. data/packages/gsutil/boto/Changelog.rst +0 -35
  254. data/packages/gsutil/boto/LICENSE +0 -18
  255. data/packages/gsutil/boto/MANIFEST.in +0 -12
  256. data/packages/gsutil/boto/README.rst +0 -163
  257. data/packages/gsutil/boto/bin/asadmin +0 -290
  258. data/packages/gsutil/boto/bin/bundle_image +0 -27
  259. data/packages/gsutil/boto/bin/cfadmin +0 -108
  260. data/packages/gsutil/boto/bin/cq +0 -89
  261. data/packages/gsutil/boto/bin/cwutil +0 -140
  262. data/packages/gsutil/boto/bin/elbadmin +0 -284
  263. data/packages/gsutil/boto/bin/fetch_file +0 -43
  264. data/packages/gsutil/boto/bin/glacier +0 -154
  265. data/packages/gsutil/boto/bin/instance_events +0 -145
  266. data/packages/gsutil/boto/bin/kill_instance +0 -35
  267. data/packages/gsutil/boto/bin/launch_instance +0 -252
  268. data/packages/gsutil/boto/bin/list_instances +0 -90
  269. data/packages/gsutil/boto/bin/lss3 +0 -77
  270. data/packages/gsutil/boto/bin/mturk +0 -465
  271. data/packages/gsutil/boto/bin/pyami_sendmail +0 -52
  272. data/packages/gsutil/boto/bin/route53 +0 -205
  273. data/packages/gsutil/boto/bin/s3put +0 -374
  274. data/packages/gsutil/boto/bin/sdbadmin +0 -194
  275. data/packages/gsutil/boto/bin/taskadmin +0 -116
  276. data/packages/gsutil/boto/boto/__init__.py +0 -793
  277. data/packages/gsutil/boto/boto/__init__.pyc +0 -0
  278. data/packages/gsutil/boto/boto/auth.py +0 -682
  279. data/packages/gsutil/boto/boto/auth.pyc +0 -0
  280. data/packages/gsutil/boto/boto/auth_handler.py +0 -58
  281. data/packages/gsutil/boto/boto/auth_handler.pyc +0 -0
  282. data/packages/gsutil/boto/boto/beanstalk/__init__.py +0 -65
  283. data/packages/gsutil/boto/boto/beanstalk/exception.py +0 -64
  284. data/packages/gsutil/boto/boto/beanstalk/layer1.py +0 -1153
  285. data/packages/gsutil/boto/boto/beanstalk/response.py +0 -703
  286. data/packages/gsutil/boto/boto/beanstalk/wrapper.py +0 -29
  287. data/packages/gsutil/boto/boto/cacerts/__init__.py +0 -22
  288. data/packages/gsutil/boto/boto/cacerts/__init__.pyc +0 -0
  289. data/packages/gsutil/boto/boto/cacerts/cacerts.txt +0 -633
  290. data/packages/gsutil/boto/boto/cloudformation/__init__.py +0 -68
  291. data/packages/gsutil/boto/boto/cloudformation/connection.py +0 -364
  292. data/packages/gsutil/boto/boto/cloudformation/stack.py +0 -360
  293. data/packages/gsutil/boto/boto/cloudformation/template.py +0 -43
  294. data/packages/gsutil/boto/boto/cloudfront/__init__.py +0 -324
  295. data/packages/gsutil/boto/boto/cloudfront/distribution.py +0 -745
  296. data/packages/gsutil/boto/boto/cloudfront/exception.py +0 -26
  297. data/packages/gsutil/boto/boto/cloudfront/identity.py +0 -122
  298. data/packages/gsutil/boto/boto/cloudfront/invalidation.py +0 -216
  299. data/packages/gsutil/boto/boto/cloudfront/logging.py +0 -38
  300. data/packages/gsutil/boto/boto/cloudfront/object.py +0 -48
  301. data/packages/gsutil/boto/boto/cloudfront/origin.py +0 -150
  302. data/packages/gsutil/boto/boto/cloudfront/signers.py +0 -60
  303. data/packages/gsutil/boto/boto/cloudsearch/__init__.py +0 -45
  304. data/packages/gsutil/boto/boto/cloudsearch/document.py +0 -265
  305. data/packages/gsutil/boto/boto/cloudsearch/domain.py +0 -394
  306. data/packages/gsutil/boto/boto/cloudsearch/layer1.py +0 -738
  307. data/packages/gsutil/boto/boto/cloudsearch/layer2.py +0 -67
  308. data/packages/gsutil/boto/boto/cloudsearch/optionstatus.py +0 -248
  309. data/packages/gsutil/boto/boto/cloudsearch/search.py +0 -365
  310. data/packages/gsutil/boto/boto/cloudsearch/sourceattribute.py +0 -75
  311. data/packages/gsutil/boto/boto/compat.py +0 -28
  312. data/packages/gsutil/boto/boto/compat.pyc +0 -0
  313. data/packages/gsutil/boto/boto/connection.py +0 -1081
  314. data/packages/gsutil/boto/boto/connection.pyc +0 -0
  315. data/packages/gsutil/boto/boto/contrib/__init__.py +0 -22
  316. data/packages/gsutil/boto/boto/contrib/ymlmessage.py +0 -52
  317. data/packages/gsutil/boto/boto/core/README +0 -58
  318. data/packages/gsutil/boto/boto/core/__init__.py +0 -23
  319. data/packages/gsutil/boto/boto/core/auth.py +0 -78
  320. data/packages/gsutil/boto/boto/core/credentials.py +0 -154
  321. data/packages/gsutil/boto/boto/core/dictresponse.py +0 -178
  322. data/packages/gsutil/boto/boto/core/service.py +0 -67
  323. data/packages/gsutil/boto/boto/datapipeline/__init__.py +0 -0
  324. data/packages/gsutil/boto/boto/datapipeline/exceptions.py +0 -42
  325. data/packages/gsutil/boto/boto/datapipeline/layer1.py +0 -546
  326. data/packages/gsutil/boto/boto/dynamodb/__init__.py +0 -66
  327. data/packages/gsutil/boto/boto/dynamodb/batch.py +0 -262
  328. data/packages/gsutil/boto/boto/dynamodb/condition.py +0 -170
  329. data/packages/gsutil/boto/boto/dynamodb/exceptions.py +0 -64
  330. data/packages/gsutil/boto/boto/dynamodb/item.py +0 -196
  331. data/packages/gsutil/boto/boto/dynamodb/layer1.py +0 -575
  332. data/packages/gsutil/boto/boto/dynamodb/layer2.py +0 -798
  333. data/packages/gsutil/boto/boto/dynamodb/schema.py +0 -112
  334. data/packages/gsutil/boto/boto/dynamodb/table.py +0 -540
  335. data/packages/gsutil/boto/boto/dynamodb/types.py +0 -326
  336. data/packages/gsutil/boto/boto/ec2/__init__.py +0 -96
  337. data/packages/gsutil/boto/boto/ec2/address.py +0 -103
  338. data/packages/gsutil/boto/boto/ec2/autoscale/__init__.py +0 -781
  339. data/packages/gsutil/boto/boto/ec2/autoscale/activity.py +0 -74
  340. data/packages/gsutil/boto/boto/ec2/autoscale/group.py +0 -337
  341. data/packages/gsutil/boto/boto/ec2/autoscale/instance.py +0 -60
  342. data/packages/gsutil/boto/boto/ec2/autoscale/launchconfig.py +0 -209
  343. data/packages/gsutil/boto/boto/ec2/autoscale/policy.py +0 -166
  344. data/packages/gsutil/boto/boto/ec2/autoscale/request.py +0 -38
  345. data/packages/gsutil/boto/boto/ec2/autoscale/scheduled.py +0 -60
  346. data/packages/gsutil/boto/boto/ec2/autoscale/tag.py +0 -84
  347. data/packages/gsutil/boto/boto/ec2/blockdevicemapping.py +0 -141
  348. data/packages/gsutil/boto/boto/ec2/bundleinstance.py +0 -78
  349. data/packages/gsutil/boto/boto/ec2/buyreservation.py +0 -84
  350. data/packages/gsutil/boto/boto/ec2/cloudwatch/__init__.py +0 -603
  351. data/packages/gsutil/boto/boto/ec2/cloudwatch/alarm.py +0 -316
  352. data/packages/gsutil/boto/boto/ec2/cloudwatch/datapoint.py +0 -40
  353. data/packages/gsutil/boto/boto/ec2/cloudwatch/dimension.py +0 -38
  354. data/packages/gsutil/boto/boto/ec2/cloudwatch/listelement.py +0 -31
  355. data/packages/gsutil/boto/boto/ec2/cloudwatch/metric.py +0 -175
  356. data/packages/gsutil/boto/boto/ec2/connection.py +0 -3409
  357. data/packages/gsutil/boto/boto/ec2/ec2object.py +0 -107
  358. data/packages/gsutil/boto/boto/ec2/elb/__init__.py +0 -553
  359. data/packages/gsutil/boto/boto/ec2/elb/healthcheck.py +0 -89
  360. data/packages/gsutil/boto/boto/ec2/elb/instancestate.py +0 -62
  361. data/packages/gsutil/boto/boto/ec2/elb/listelement.py +0 -36
  362. data/packages/gsutil/boto/boto/ec2/elb/listener.py +0 -75
  363. data/packages/gsutil/boto/boto/ec2/elb/loadbalancer.py +0 -324
  364. data/packages/gsutil/boto/boto/ec2/elb/policies.py +0 -89
  365. data/packages/gsutil/boto/boto/ec2/elb/securitygroup.py +0 -38
  366. data/packages/gsutil/boto/boto/ec2/group.py +0 -39
  367. data/packages/gsutil/boto/boto/ec2/image.py +0 -350
  368. data/packages/gsutil/boto/boto/ec2/instance.py +0 -661
  369. data/packages/gsutil/boto/boto/ec2/instanceinfo.py +0 -51
  370. data/packages/gsutil/boto/boto/ec2/instancestatus.py +0 -207
  371. data/packages/gsutil/boto/boto/ec2/keypair.py +0 -113
  372. data/packages/gsutil/boto/boto/ec2/launchspecification.py +0 -105
  373. data/packages/gsutil/boto/boto/ec2/networkinterface.py +0 -247
  374. data/packages/gsutil/boto/boto/ec2/placementgroup.py +0 -51
  375. data/packages/gsutil/boto/boto/ec2/regioninfo.py +0 -34
  376. data/packages/gsutil/boto/boto/ec2/reservedinstance.py +0 -227
  377. data/packages/gsutil/boto/boto/ec2/securitygroup.py +0 -357
  378. data/packages/gsutil/boto/boto/ec2/snapshot.py +0 -170
  379. data/packages/gsutil/boto/boto/ec2/spotdatafeedsubscription.py +0 -63
  380. data/packages/gsutil/boto/boto/ec2/spotinstancerequest.py +0 -188
  381. data/packages/gsutil/boto/boto/ec2/spotpricehistory.py +0 -55
  382. data/packages/gsutil/boto/boto/ec2/tag.py +0 -87
  383. data/packages/gsutil/boto/boto/ec2/vmtype.py +0 -58
  384. data/packages/gsutil/boto/boto/ec2/volume.py +0 -293
  385. data/packages/gsutil/boto/boto/ec2/volumestatus.py +0 -200
  386. data/packages/gsutil/boto/boto/ec2/zone.py +0 -80
  387. data/packages/gsutil/boto/boto/ecs/__init__.py +0 -90
  388. data/packages/gsutil/boto/boto/ecs/item.py +0 -153
  389. data/packages/gsutil/boto/boto/elasticache/__init__.py +0 -62
  390. data/packages/gsutil/boto/boto/elasticache/layer1.py +0 -1252
  391. data/packages/gsutil/boto/boto/elastictranscoder/__init__.py +0 -62
  392. data/packages/gsutil/boto/boto/elastictranscoder/exceptions.py +0 -46
  393. data/packages/gsutil/boto/boto/elastictranscoder/layer1.py +0 -509
  394. data/packages/gsutil/boto/boto/emr/__init__.py +0 -73
  395. data/packages/gsutil/boto/boto/emr/bootstrap_action.py +0 -44
  396. data/packages/gsutil/boto/boto/emr/connection.py +0 -531
  397. data/packages/gsutil/boto/boto/emr/emrobject.py +0 -176
  398. data/packages/gsutil/boto/boto/emr/instance_group.py +0 -43
  399. data/packages/gsutil/boto/boto/emr/step.py +0 -281
  400. data/packages/gsutil/boto/boto/exception.py +0 -476
  401. data/packages/gsutil/boto/boto/exception.pyc +0 -0
  402. data/packages/gsutil/boto/boto/file/README +0 -49
  403. data/packages/gsutil/boto/boto/file/__init__.py +0 -28
  404. data/packages/gsutil/boto/boto/file/bucket.py +0 -112
  405. data/packages/gsutil/boto/boto/file/connection.py +0 -33
  406. data/packages/gsutil/boto/boto/file/key.py +0 -199
  407. data/packages/gsutil/boto/boto/file/simpleresultset.py +0 -30
  408. data/packages/gsutil/boto/boto/fps/__init__.py +0 -21
  409. data/packages/gsutil/boto/boto/fps/connection.py +0 -369
  410. data/packages/gsutil/boto/boto/fps/exception.py +0 -344
  411. data/packages/gsutil/boto/boto/fps/response.py +0 -175
  412. data/packages/gsutil/boto/boto/glacier/__init__.py +0 -57
  413. data/packages/gsutil/boto/boto/glacier/concurrent.py +0 -409
  414. data/packages/gsutil/boto/boto/glacier/exceptions.py +0 -58
  415. data/packages/gsutil/boto/boto/glacier/job.py +0 -152
  416. data/packages/gsutil/boto/boto/glacier/layer1.py +0 -637
  417. data/packages/gsutil/boto/boto/glacier/layer2.py +0 -93
  418. data/packages/gsutil/boto/boto/glacier/response.py +0 -48
  419. data/packages/gsutil/boto/boto/glacier/utils.py +0 -163
  420. data/packages/gsutil/boto/boto/glacier/vault.py +0 -387
  421. data/packages/gsutil/boto/boto/glacier/writer.py +0 -242
  422. data/packages/gsutil/boto/boto/gs/__init__.py +0 -22
  423. data/packages/gsutil/boto/boto/gs/__init__.pyc +0 -0
  424. data/packages/gsutil/boto/boto/gs/acl.py +0 -304
  425. data/packages/gsutil/boto/boto/gs/acl.pyc +0 -0
  426. data/packages/gsutil/boto/boto/gs/bucket.py +0 -870
  427. data/packages/gsutil/boto/boto/gs/bucket.pyc +0 -0
  428. data/packages/gsutil/boto/boto/gs/bucketlistresultset.py +0 -64
  429. data/packages/gsutil/boto/boto/gs/bucketlistresultset.pyc +0 -0
  430. data/packages/gsutil/boto/boto/gs/connection.py +0 -103
  431. data/packages/gsutil/boto/boto/gs/connection.pyc +0 -0
  432. data/packages/gsutil/boto/boto/gs/cors.py +0 -169
  433. data/packages/gsutil/boto/boto/gs/cors.pyc +0 -0
  434. data/packages/gsutil/boto/boto/gs/key.py +0 -704
  435. data/packages/gsutil/boto/boto/gs/key.pyc +0 -0
  436. data/packages/gsutil/boto/boto/gs/resumable_upload_handler.py +0 -659
  437. data/packages/gsutil/boto/boto/gs/resumable_upload_handler.pyc +0 -0
  438. data/packages/gsutil/boto/boto/gs/user.py +0 -54
  439. data/packages/gsutil/boto/boto/gs/user.pyc +0 -0
  440. data/packages/gsutil/boto/boto/handler.py +0 -44
  441. data/packages/gsutil/boto/boto/handler.pyc +0 -0
  442. data/packages/gsutil/boto/boto/https_connection.py +0 -124
  443. data/packages/gsutil/boto/boto/https_connection.pyc +0 -0
  444. data/packages/gsutil/boto/boto/iam/__init__.py +0 -74
  445. data/packages/gsutil/boto/boto/iam/connection.py +0 -1317
  446. data/packages/gsutil/boto/boto/iam/summarymap.py +0 -42
  447. data/packages/gsutil/boto/boto/jsonresponse.py +0 -163
  448. data/packages/gsutil/boto/boto/jsonresponse.pyc +0 -0
  449. data/packages/gsutil/boto/boto/manage/__init__.py +0 -23
  450. data/packages/gsutil/boto/boto/manage/cmdshell.py +0 -241
  451. data/packages/gsutil/boto/boto/manage/propget.py +0 -64
  452. data/packages/gsutil/boto/boto/manage/server.py +0 -556
  453. data/packages/gsutil/boto/boto/manage/task.py +0 -175
  454. data/packages/gsutil/boto/boto/manage/test_manage.py +0 -34
  455. data/packages/gsutil/boto/boto/manage/volume.py +0 -420
  456. data/packages/gsutil/boto/boto/mashups/__init__.py +0 -23
  457. data/packages/gsutil/boto/boto/mashups/interactive.py +0 -97
  458. data/packages/gsutil/boto/boto/mashups/iobject.py +0 -115
  459. data/packages/gsutil/boto/boto/mashups/order.py +0 -211
  460. data/packages/gsutil/boto/boto/mashups/server.py +0 -395
  461. data/packages/gsutil/boto/boto/mturk/__init__.py +0 -23
  462. data/packages/gsutil/boto/boto/mturk/connection.py +0 -1027
  463. data/packages/gsutil/boto/boto/mturk/layoutparam.py +0 -55
  464. data/packages/gsutil/boto/boto/mturk/notification.py +0 -103
  465. data/packages/gsutil/boto/boto/mturk/price.py +0 -48
  466. data/packages/gsutil/boto/boto/mturk/qualification.py +0 -137
  467. data/packages/gsutil/boto/boto/mturk/question.py +0 -455
  468. data/packages/gsutil/boto/boto/mws/__init__.py +0 -21
  469. data/packages/gsutil/boto/boto/mws/connection.py +0 -813
  470. data/packages/gsutil/boto/boto/mws/exception.py +0 -75
  471. data/packages/gsutil/boto/boto/mws/response.py +0 -655
  472. data/packages/gsutil/boto/boto/plugin.py +0 -90
  473. data/packages/gsutil/boto/boto/plugin.pyc +0 -0
  474. data/packages/gsutil/boto/boto/provider.py +0 -337
  475. data/packages/gsutil/boto/boto/provider.pyc +0 -0
  476. data/packages/gsutil/boto/boto/pyami/__init__.py +0 -22
  477. data/packages/gsutil/boto/boto/pyami/__init__.pyc +0 -0
  478. data/packages/gsutil/boto/boto/pyami/bootstrap.py +0 -134
  479. data/packages/gsutil/boto/boto/pyami/config.py +0 -229
  480. data/packages/gsutil/boto/boto/pyami/config.pyc +0 -0
  481. data/packages/gsutil/boto/boto/pyami/copybot.cfg +0 -60
  482. data/packages/gsutil/boto/boto/pyami/copybot.py +0 -97
  483. data/packages/gsutil/boto/boto/pyami/helloworld.py +0 -28
  484. data/packages/gsutil/boto/boto/pyami/installers/__init__.py +0 -64
  485. data/packages/gsutil/boto/boto/pyami/installers/ubuntu/__init__.py +0 -22
  486. data/packages/gsutil/boto/boto/pyami/installers/ubuntu/apache.py +0 -43
  487. data/packages/gsutil/boto/boto/pyami/installers/ubuntu/ebs.py +0 -238
  488. data/packages/gsutil/boto/boto/pyami/installers/ubuntu/installer.py +0 -96
  489. data/packages/gsutil/boto/boto/pyami/installers/ubuntu/mysql.py +0 -109
  490. data/packages/gsutil/boto/boto/pyami/installers/ubuntu/trac.py +0 -139
  491. data/packages/gsutil/boto/boto/pyami/launch_ami.py +0 -178
  492. data/packages/gsutil/boto/boto/pyami/scriptbase.py +0 -44
  493. data/packages/gsutil/boto/boto/pyami/startup.py +0 -60
  494. data/packages/gsutil/boto/boto/rds/__init__.py +0 -1194
  495. data/packages/gsutil/boto/boto/rds/dbinstance.py +0 -357
  496. data/packages/gsutil/boto/boto/rds/dbsecuritygroup.py +0 -177
  497. data/packages/gsutil/boto/boto/rds/dbsnapshot.py +0 -108
  498. data/packages/gsutil/boto/boto/rds/event.py +0 -49
  499. data/packages/gsutil/boto/boto/rds/parametergroup.py +0 -201
  500. data/packages/gsutil/boto/boto/rds/regioninfo.py +0 -32
  501. data/packages/gsutil/boto/boto/regioninfo.py +0 -63
  502. data/packages/gsutil/boto/boto/regioninfo.pyc +0 -0
  503. data/packages/gsutil/boto/boto/resultset.py +0 -169
  504. data/packages/gsutil/boto/boto/resultset.pyc +0 -0
  505. data/packages/gsutil/boto/boto/roboto/__init__.py +0 -1
  506. data/packages/gsutil/boto/boto/roboto/awsqueryrequest.py +0 -504
  507. data/packages/gsutil/boto/boto/roboto/awsqueryservice.py +0 -121
  508. data/packages/gsutil/boto/boto/roboto/param.py +0 -147
  509. data/packages/gsutil/boto/boto/route53/__init__.py +0 -75
  510. data/packages/gsutil/boto/boto/route53/connection.py +0 -403
  511. data/packages/gsutil/boto/boto/route53/exception.py +0 -27
  512. data/packages/gsutil/boto/boto/route53/hostedzone.py +0 -56
  513. data/packages/gsutil/boto/boto/route53/record.py +0 -306
  514. data/packages/gsutil/boto/boto/route53/status.py +0 -42
  515. data/packages/gsutil/boto/boto/route53/zone.py +0 -412
  516. data/packages/gsutil/boto/boto/s3/__init__.py +0 -84
  517. data/packages/gsutil/boto/boto/s3/__init__.pyc +0 -0
  518. data/packages/gsutil/boto/boto/s3/acl.py +0 -164
  519. data/packages/gsutil/boto/boto/s3/acl.pyc +0 -0
  520. data/packages/gsutil/boto/boto/s3/bucket.py +0 -1634
  521. data/packages/gsutil/boto/boto/s3/bucket.pyc +0 -0
  522. data/packages/gsutil/boto/boto/s3/bucketlistresultset.py +0 -139
  523. data/packages/gsutil/boto/boto/s3/bucketlistresultset.pyc +0 -0
  524. data/packages/gsutil/boto/boto/s3/bucketlogging.py +0 -83
  525. data/packages/gsutil/boto/boto/s3/bucketlogging.pyc +0 -0
  526. data/packages/gsutil/boto/boto/s3/connection.py +0 -540
  527. data/packages/gsutil/boto/boto/s3/connection.pyc +0 -0
  528. data/packages/gsutil/boto/boto/s3/cors.py +0 -210
  529. data/packages/gsutil/boto/boto/s3/cors.pyc +0 -0
  530. data/packages/gsutil/boto/boto/s3/deletemarker.py +0 -55
  531. data/packages/gsutil/boto/boto/s3/deletemarker.pyc +0 -0
  532. data/packages/gsutil/boto/boto/s3/key.py +0 -1712
  533. data/packages/gsutil/boto/boto/s3/key.pyc +0 -0
  534. data/packages/gsutil/boto/boto/s3/keyfile.py +0 -134
  535. data/packages/gsutil/boto/boto/s3/keyfile.pyc +0 -0
  536. data/packages/gsutil/boto/boto/s3/lifecycle.py +0 -231
  537. data/packages/gsutil/boto/boto/s3/lifecycle.pyc +0 -0
  538. data/packages/gsutil/boto/boto/s3/multidelete.py +0 -138
  539. data/packages/gsutil/boto/boto/s3/multidelete.pyc +0 -0
  540. data/packages/gsutil/boto/boto/s3/multipart.py +0 -315
  541. data/packages/gsutil/boto/boto/s3/multipart.pyc +0 -0
  542. data/packages/gsutil/boto/boto/s3/prefix.py +0 -42
  543. data/packages/gsutil/boto/boto/s3/prefix.pyc +0 -0
  544. data/packages/gsutil/boto/boto/s3/resumable_download_handler.py +0 -339
  545. data/packages/gsutil/boto/boto/s3/resumable_download_handler.pyc +0 -0
  546. data/packages/gsutil/boto/boto/s3/tagging.py +0 -71
  547. data/packages/gsutil/boto/boto/s3/tagging.pyc +0 -0
  548. data/packages/gsutil/boto/boto/s3/user.py +0 -49
  549. data/packages/gsutil/boto/boto/s3/user.pyc +0 -0
  550. data/packages/gsutil/boto/boto/s3/website.py +0 -237
  551. data/packages/gsutil/boto/boto/s3/website.pyc +0 -0
  552. data/packages/gsutil/boto/boto/sdb/__init__.py +0 -67
  553. data/packages/gsutil/boto/boto/sdb/connection.py +0 -617
  554. data/packages/gsutil/boto/boto/sdb/db/__init__.py +0 -20
  555. data/packages/gsutil/boto/boto/sdb/db/blob.py +0 -75
  556. data/packages/gsutil/boto/boto/sdb/db/key.py +0 -59
  557. data/packages/gsutil/boto/boto/sdb/db/manager/__init__.py +0 -85
  558. data/packages/gsutil/boto/boto/sdb/db/manager/sdbmanager.py +0 -732
  559. data/packages/gsutil/boto/boto/sdb/db/manager/xmlmanager.py +0 -517
  560. data/packages/gsutil/boto/boto/sdb/db/model.py +0 -294
  561. data/packages/gsutil/boto/boto/sdb/db/property.py +0 -703
  562. data/packages/gsutil/boto/boto/sdb/db/query.py +0 -85
  563. data/packages/gsutil/boto/boto/sdb/db/sequence.py +0 -226
  564. data/packages/gsutil/boto/boto/sdb/db/test_db.py +0 -231
  565. data/packages/gsutil/boto/boto/sdb/domain.py +0 -377
  566. data/packages/gsutil/boto/boto/sdb/item.py +0 -181
  567. data/packages/gsutil/boto/boto/sdb/queryresultset.py +0 -92
  568. data/packages/gsutil/boto/boto/sdb/regioninfo.py +0 -32
  569. data/packages/gsutil/boto/boto/services/__init__.py +0 -23
  570. data/packages/gsutil/boto/boto/services/bs.py +0 -179
  571. data/packages/gsutil/boto/boto/services/message.py +0 -58
  572. data/packages/gsutil/boto/boto/services/result.py +0 -136
  573. data/packages/gsutil/boto/boto/services/service.py +0 -161
  574. data/packages/gsutil/boto/boto/services/servicedef.py +0 -91
  575. data/packages/gsutil/boto/boto/services/sonofmmm.cfg +0 -43
  576. data/packages/gsutil/boto/boto/services/sonofmmm.py +0 -81
  577. data/packages/gsutil/boto/boto/services/submit.py +0 -88
  578. data/packages/gsutil/boto/boto/ses/__init__.py +0 -54
  579. data/packages/gsutil/boto/boto/ses/connection.py +0 -521
  580. data/packages/gsutil/boto/boto/ses/exceptions.py +0 -77
  581. data/packages/gsutil/boto/boto/sns/__init__.py +0 -78
  582. data/packages/gsutil/boto/boto/sns/connection.py +0 -431
  583. data/packages/gsutil/boto/boto/sqs/__init__.py +0 -56
  584. data/packages/gsutil/boto/boto/sqs/attributes.py +0 -46
  585. data/packages/gsutil/boto/boto/sqs/batchresults.py +0 -95
  586. data/packages/gsutil/boto/boto/sqs/connection.py +0 -417
  587. data/packages/gsutil/boto/boto/sqs/jsonmessage.py +0 -43
  588. data/packages/gsutil/boto/boto/sqs/message.py +0 -253
  589. data/packages/gsutil/boto/boto/sqs/queue.py +0 -478
  590. data/packages/gsutil/boto/boto/sqs/regioninfo.py +0 -32
  591. data/packages/gsutil/boto/boto/storage_uri.py +0 -835
  592. data/packages/gsutil/boto/boto/storage_uri.pyc +0 -0
  593. data/packages/gsutil/boto/boto/sts/__init__.py +0 -55
  594. data/packages/gsutil/boto/boto/sts/connection.py +0 -207
  595. data/packages/gsutil/boto/boto/sts/credentials.py +0 -215
  596. data/packages/gsutil/boto/boto/swf/__init__.py +0 -60
  597. data/packages/gsutil/boto/boto/swf/exceptions.py +0 -44
  598. data/packages/gsutil/boto/boto/swf/layer1.py +0 -1512
  599. data/packages/gsutil/boto/boto/swf/layer1_decisions.py +0 -287
  600. data/packages/gsutil/boto/boto/swf/layer2.py +0 -342
  601. data/packages/gsutil/boto/boto/utils.py +0 -927
  602. data/packages/gsutil/boto/boto/utils.pyc +0 -0
  603. data/packages/gsutil/boto/boto/vpc/__init__.py +0 -910
  604. data/packages/gsutil/boto/boto/vpc/customergateway.py +0 -54
  605. data/packages/gsutil/boto/boto/vpc/dhcpoptions.py +0 -72
  606. data/packages/gsutil/boto/boto/vpc/internetgateway.py +0 -72
  607. data/packages/gsutil/boto/boto/vpc/routetable.py +0 -109
  608. data/packages/gsutil/boto/boto/vpc/subnet.py +0 -57
  609. data/packages/gsutil/boto/boto/vpc/vpc.py +0 -54
  610. data/packages/gsutil/boto/boto/vpc/vpnconnection.py +0 -60
  611. data/packages/gsutil/boto/boto/vpc/vpngateway.py +0 -83
  612. data/packages/gsutil/boto/docs/BotoCheatSheet.pdf +0 -0
  613. data/packages/gsutil/boto/docs/Makefile +0 -89
  614. data/packages/gsutil/boto/docs/make.bat +0 -113
  615. data/packages/gsutil/boto/docs/source/_templates/layout.html +0 -3
  616. data/packages/gsutil/boto/docs/source/autoscale_tut.rst +0 -220
  617. data/packages/gsutil/boto/docs/source/boto_config_tut.rst +0 -125
  618. data/packages/gsutil/boto/docs/source/boto_theme/static/boto.css_t +0 -239
  619. data/packages/gsutil/boto/docs/source/boto_theme/static/pygments.css +0 -61
  620. data/packages/gsutil/boto/docs/source/boto_theme/theme.conf +0 -3
  621. data/packages/gsutil/boto/docs/source/cloudfront_tut.rst +0 -196
  622. data/packages/gsutil/boto/docs/source/cloudsearch_tut.rst +0 -411
  623. data/packages/gsutil/boto/docs/source/cloudwatch_tut.rst +0 -116
  624. data/packages/gsutil/boto/docs/source/conf.py +0 -32
  625. data/packages/gsutil/boto/docs/source/contributing.rst +0 -204
  626. data/packages/gsutil/boto/docs/source/documentation.rst +0 -59
  627. data/packages/gsutil/boto/docs/source/dynamodb_tut.rst +0 -339
  628. data/packages/gsutil/boto/docs/source/ec2_tut.rst +0 -86
  629. data/packages/gsutil/boto/docs/source/elb_tut.rst +0 -257
  630. data/packages/gsutil/boto/docs/source/emr_tut.rst +0 -108
  631. data/packages/gsutil/boto/docs/source/index.rst +0 -146
  632. data/packages/gsutil/boto/docs/source/rds_tut.rst +0 -108
  633. data/packages/gsutil/boto/docs/source/ref/autoscale.rst +0 -62
  634. data/packages/gsutil/boto/docs/source/ref/beanstalk.rst +0 -26
  635. data/packages/gsutil/boto/docs/source/ref/boto.rst +0 -47
  636. data/packages/gsutil/boto/docs/source/ref/cloudformation.rst +0 -34
  637. data/packages/gsutil/boto/docs/source/ref/cloudfront.rst +0 -68
  638. data/packages/gsutil/boto/docs/source/ref/cloudsearch.rst +0 -59
  639. data/packages/gsutil/boto/docs/source/ref/cloudwatch.rst +0 -27
  640. data/packages/gsutil/boto/docs/source/ref/contrib.rst +0 -32
  641. data/packages/gsutil/boto/docs/source/ref/datapipeline.rst +0 -26
  642. data/packages/gsutil/boto/docs/source/ref/dynamodb.rst +0 -61
  643. data/packages/gsutil/boto/docs/source/ref/ec2.rst +0 -140
  644. data/packages/gsutil/boto/docs/source/ref/ecs.rst +0 -19
  645. data/packages/gsutil/boto/docs/source/ref/elasticache.rst +0 -19
  646. data/packages/gsutil/boto/docs/source/ref/elastictranscoder.rst +0 -26
  647. data/packages/gsutil/boto/docs/source/ref/elb.rst +0 -47
  648. data/packages/gsutil/boto/docs/source/ref/emr.rst +0 -34
  649. data/packages/gsutil/boto/docs/source/ref/file.rst +0 -34
  650. data/packages/gsutil/boto/docs/source/ref/fps.rst +0 -19
  651. data/packages/gsutil/boto/docs/source/ref/glacier.rst +0 -63
  652. data/packages/gsutil/boto/docs/source/ref/gs.rst +0 -72
  653. data/packages/gsutil/boto/docs/source/ref/iam.rst +0 -27
  654. data/packages/gsutil/boto/docs/source/ref/index.rst +0 -40
  655. data/packages/gsutil/boto/docs/source/ref/manage.rst +0 -47
  656. data/packages/gsutil/boto/docs/source/ref/mturk.rst +0 -54
  657. data/packages/gsutil/boto/docs/source/ref/mws.rst +0 -33
  658. data/packages/gsutil/boto/docs/source/ref/pyami.rst +0 -103
  659. data/packages/gsutil/boto/docs/source/ref/rds.rst +0 -47
  660. data/packages/gsutil/boto/docs/source/ref/route53.rst +0 -34
  661. data/packages/gsutil/boto/docs/source/ref/s3.rst +0 -111
  662. data/packages/gsutil/boto/docs/source/ref/sdb.rst +0 -45
  663. data/packages/gsutil/boto/docs/source/ref/sdb_db.rst +0 -83
  664. data/packages/gsutil/boto/docs/source/ref/services.rst +0 -61
  665. data/packages/gsutil/boto/docs/source/ref/ses.rst +0 -21
  666. data/packages/gsutil/boto/docs/source/ref/sns.rst +0 -17
  667. data/packages/gsutil/boto/docs/source/ref/sqs.rst +0 -61
  668. data/packages/gsutil/boto/docs/source/ref/sts.rst +0 -25
  669. data/packages/gsutil/boto/docs/source/ref/swf.rst +0 -22
  670. data/packages/gsutil/boto/docs/source/ref/vpc.rst +0 -54
  671. data/packages/gsutil/boto/docs/source/s3_tut.rst +0 -450
  672. data/packages/gsutil/boto/docs/source/security_groups.rst +0 -82
  673. data/packages/gsutil/boto/docs/source/ses_tut.rst +0 -171
  674. data/packages/gsutil/boto/docs/source/simpledb_tut.rst +0 -188
  675. data/packages/gsutil/boto/docs/source/sqs_tut.rst +0 -246
  676. data/packages/gsutil/boto/docs/source/vpc_tut.rst +0 -100
  677. data/packages/gsutil/boto/pylintrc +0 -305
  678. data/packages/gsutil/boto/requirements.txt +0 -10
  679. data/packages/gsutil/boto/setup.py +0 -89
  680. data/packages/gsutil/boto/tests/__init__.py +0 -20
  681. data/packages/gsutil/boto/tests/db/test_lists.py +0 -96
  682. data/packages/gsutil/boto/tests/db/test_password.py +0 -128
  683. data/packages/gsutil/boto/tests/db/test_query.py +0 -152
  684. data/packages/gsutil/boto/tests/db/test_sequence.py +0 -109
  685. data/packages/gsutil/boto/tests/devpay/__init__.py +0 -0
  686. data/packages/gsutil/boto/tests/devpay/test_s3.py +0 -181
  687. data/packages/gsutil/boto/tests/fps/__init__.py +0 -0
  688. data/packages/gsutil/boto/tests/fps/test.py +0 -100
  689. data/packages/gsutil/boto/tests/fps/test_verify_signature.py +0 -12
  690. data/packages/gsutil/boto/tests/integration/__init__.py +0 -0
  691. data/packages/gsutil/boto/tests/integration/beanstalk/test_wrapper.py +0 -209
  692. data/packages/gsutil/boto/tests/integration/cloudformation/__init__.py +0 -21
  693. data/packages/gsutil/boto/tests/integration/cloudformation/test_cert_verification.py +0 -40
  694. data/packages/gsutil/boto/tests/integration/cloudformation/test_connection.py +0 -110
  695. data/packages/gsutil/boto/tests/integration/cloudsearch/__init__.py +0 -21
  696. data/packages/gsutil/boto/tests/integration/cloudsearch/test_cert_verification.py +0 -40
  697. data/packages/gsutil/boto/tests/integration/datapipeline/test_layer1.py +0 -122
  698. data/packages/gsutil/boto/tests/integration/dynamodb/__init__.py +0 -20
  699. data/packages/gsutil/boto/tests/integration/dynamodb/test_cert_verification.py +0 -40
  700. data/packages/gsutil/boto/tests/integration/dynamodb/test_layer1.py +0 -266
  701. data/packages/gsutil/boto/tests/integration/dynamodb/test_layer2.py +0 -484
  702. data/packages/gsutil/boto/tests/integration/dynamodb/test_table.py +0 -84
  703. data/packages/gsutil/boto/tests/integration/ec2/__init__.py +0 -20
  704. data/packages/gsutil/boto/tests/integration/ec2/autoscale/__init__.py +0 -21
  705. data/packages/gsutil/boto/tests/integration/ec2/autoscale/test_cert_verification.py +0 -40
  706. data/packages/gsutil/boto/tests/integration/ec2/autoscale/test_connection.py +0 -167
  707. data/packages/gsutil/boto/tests/integration/ec2/cloudwatch/__init__.py +0 -20
  708. data/packages/gsutil/boto/tests/integration/ec2/cloudwatch/test_cert_verification.py +0 -40
  709. data/packages/gsutil/boto/tests/integration/ec2/cloudwatch/test_connection.py +0 -277
  710. data/packages/gsutil/boto/tests/integration/ec2/elb/__init__.py +0 -20
  711. data/packages/gsutil/boto/tests/integration/ec2/elb/test_cert_verification.py +0 -40
  712. data/packages/gsutil/boto/tests/integration/ec2/elb/test_connection.py +0 -130
  713. data/packages/gsutil/boto/tests/integration/ec2/test_cert_verification.py +0 -40
  714. data/packages/gsutil/boto/tests/integration/ec2/test_connection.py +0 -192
  715. data/packages/gsutil/boto/tests/integration/ec2/vpc/__init__.py +0 -0
  716. data/packages/gsutil/boto/tests/integration/ec2/vpc/test_connection.py +0 -95
  717. data/packages/gsutil/boto/tests/integration/elasticache/__init__.py +0 -0
  718. data/packages/gsutil/boto/tests/integration/elasticache/test_layer1.py +0 -67
  719. data/packages/gsutil/boto/tests/integration/elastictranscoder/__init__.py +0 -0
  720. data/packages/gsutil/boto/tests/integration/elastictranscoder/test_cert_verification.py +0 -35
  721. data/packages/gsutil/boto/tests/integration/elastictranscoder/test_layer1.py +0 -115
  722. data/packages/gsutil/boto/tests/integration/emr/__init__.py +0 -20
  723. data/packages/gsutil/boto/tests/integration/emr/test_cert_verification.py +0 -40
  724. data/packages/gsutil/boto/tests/integration/glacier/__init__.py +0 -22
  725. data/packages/gsutil/boto/tests/integration/glacier/test_cert_verification.py +0 -40
  726. data/packages/gsutil/boto/tests/integration/glacier/test_layer1.py +0 -44
  727. data/packages/gsutil/boto/tests/integration/glacier/test_layer2.py +0 -45
  728. data/packages/gsutil/boto/tests/integration/gs/__init__.py +0 -0
  729. data/packages/gsutil/boto/tests/integration/gs/cb_test_harness.py +0 -71
  730. data/packages/gsutil/boto/tests/integration/gs/test_basic.py +0 -379
  731. data/packages/gsutil/boto/tests/integration/gs/test_generation_conditionals.py +0 -399
  732. data/packages/gsutil/boto/tests/integration/gs/test_resumable_downloads.py +0 -358
  733. data/packages/gsutil/boto/tests/integration/gs/test_resumable_uploads.py +0 -525
  734. data/packages/gsutil/boto/tests/integration/gs/test_storage_uri.py +0 -125
  735. data/packages/gsutil/boto/tests/integration/gs/test_versioning.py +0 -268
  736. data/packages/gsutil/boto/tests/integration/gs/testcase.py +0 -116
  737. data/packages/gsutil/boto/tests/integration/gs/util.py +0 -63
  738. data/packages/gsutil/boto/tests/integration/iam/__init__.py +0 -20
  739. data/packages/gsutil/boto/tests/integration/iam/test_cert_verification.py +0 -40
  740. data/packages/gsutil/boto/tests/integration/mws/__init__.py +0 -0
  741. data/packages/gsutil/boto/tests/integration/mws/test.py +0 -100
  742. data/packages/gsutil/boto/tests/integration/rds/__init__.py +0 -21
  743. data/packages/gsutil/boto/tests/integration/rds/test_cert_verification.py +0 -40
  744. data/packages/gsutil/boto/tests/integration/route53/__init__.py +0 -20
  745. data/packages/gsutil/boto/tests/integration/route53/test_cert_verification.py +0 -40
  746. data/packages/gsutil/boto/tests/integration/route53/test_zone.py +0 -132
  747. data/packages/gsutil/boto/tests/integration/s3/__init__.py +0 -20
  748. data/packages/gsutil/boto/tests/integration/s3/mock_storage_service.py +0 -589
  749. data/packages/gsutil/boto/tests/integration/s3/other_cacerts.txt +0 -70
  750. data/packages/gsutil/boto/tests/integration/s3/test_bucket.py +0 -263
  751. data/packages/gsutil/boto/tests/integration/s3/test_cert_verification.py +0 -40
  752. data/packages/gsutil/boto/tests/integration/s3/test_connection.py +0 -245
  753. data/packages/gsutil/boto/tests/integration/s3/test_cors.py +0 -78
  754. data/packages/gsutil/boto/tests/integration/s3/test_encryption.py +0 -115
  755. data/packages/gsutil/boto/tests/integration/s3/test_https_cert_validation.py +0 -141
  756. data/packages/gsutil/boto/tests/integration/s3/test_key.py +0 -375
  757. data/packages/gsutil/boto/tests/integration/s3/test_mfa.py +0 -95
  758. data/packages/gsutil/boto/tests/integration/s3/test_multidelete.py +0 -181
  759. data/packages/gsutil/boto/tests/integration/s3/test_multipart.py +0 -139
  760. data/packages/gsutil/boto/tests/integration/s3/test_pool.py +0 -246
  761. data/packages/gsutil/boto/tests/integration/s3/test_versioning.py +0 -158
  762. data/packages/gsutil/boto/tests/integration/sdb/__init__.py +0 -20
  763. data/packages/gsutil/boto/tests/integration/sdb/test_cert_verification.py +0 -40
  764. data/packages/gsutil/boto/tests/integration/sdb/test_connection.py +0 -119
  765. data/packages/gsutil/boto/tests/integration/ses/__init__.py +0 -0
  766. data/packages/gsutil/boto/tests/integration/ses/test_cert_verification.py +0 -40
  767. data/packages/gsutil/boto/tests/integration/ses/test_connection.py +0 -38
  768. data/packages/gsutil/boto/tests/integration/sns/__init__.py +0 -20
  769. data/packages/gsutil/boto/tests/integration/sns/test_cert_verification.py +0 -40
  770. data/packages/gsutil/boto/tests/integration/sqs/__init__.py +0 -20
  771. data/packages/gsutil/boto/tests/integration/sqs/test_cert_verification.py +0 -40
  772. data/packages/gsutil/boto/tests/integration/sqs/test_connection.py +0 -217
  773. data/packages/gsutil/boto/tests/integration/sts/__init__.py +0 -20
  774. data/packages/gsutil/boto/tests/integration/sts/test_cert_verification.py +0 -40
  775. data/packages/gsutil/boto/tests/integration/sts/test_session_token.py +0 -65
  776. data/packages/gsutil/boto/tests/integration/swf/__init__.py +0 -0
  777. data/packages/gsutil/boto/tests/integration/swf/test_cert_verification.py +0 -40
  778. data/packages/gsutil/boto/tests/integration/swf/test_layer1.py +0 -246
  779. data/packages/gsutil/boto/tests/integration/swf/test_layer1_workflow_execution.py +0 -173
  780. data/packages/gsutil/boto/tests/mturk/__init__.py +0 -0
  781. data/packages/gsutil/boto/tests/mturk/_init_environment.py +0 -28
  782. data/packages/gsutil/boto/tests/mturk/all_tests.py +0 -24
  783. data/packages/gsutil/boto/tests/mturk/cleanup_tests.py +0 -47
  784. data/packages/gsutil/boto/tests/mturk/common.py +0 -45
  785. data/packages/gsutil/boto/tests/mturk/create_free_text_question_regex.doctest +0 -100
  786. data/packages/gsutil/boto/tests/mturk/create_hit.doctest +0 -92
  787. data/packages/gsutil/boto/tests/mturk/create_hit_binary.doctest +0 -94
  788. data/packages/gsutil/boto/tests/mturk/create_hit_external.py +0 -21
  789. data/packages/gsutil/boto/tests/mturk/create_hit_from_hit_type.doctest +0 -103
  790. data/packages/gsutil/boto/tests/mturk/create_hit_test.py +0 -21
  791. data/packages/gsutil/boto/tests/mturk/create_hit_with_qualifications.py +0 -16
  792. data/packages/gsutil/boto/tests/mturk/hit_persistence.py +0 -27
  793. data/packages/gsutil/boto/tests/mturk/mocks.py +0 -11
  794. data/packages/gsutil/boto/tests/mturk/reviewable_hits.doctest +0 -129
  795. data/packages/gsutil/boto/tests/mturk/run-doctest.py +0 -13
  796. data/packages/gsutil/boto/tests/mturk/search_hits.doctest +0 -16
  797. data/packages/gsutil/boto/tests/mturk/selenium_support.py +0 -61
  798. data/packages/gsutil/boto/tests/mturk/support.py +0 -7
  799. data/packages/gsutil/boto/tests/mturk/test_disable_hit.py +0 -11
  800. data/packages/gsutil/boto/tests/test.py +0 -59
  801. data/packages/gsutil/boto/tests/unit/__init__.py +0 -79
  802. data/packages/gsutil/boto/tests/unit/auth/__init__.py +0 -0
  803. data/packages/gsutil/boto/tests/unit/auth/test_sigv4.py +0 -73
  804. data/packages/gsutil/boto/tests/unit/beanstalk/__init__.py +0 -0
  805. data/packages/gsutil/boto/tests/unit/beanstalk/test_layer1.py +0 -128
  806. data/packages/gsutil/boto/tests/unit/cloudformation/__init__.py +0 -0
  807. data/packages/gsutil/boto/tests/unit/cloudformation/test_connection.py +0 -605
  808. data/packages/gsutil/boto/tests/unit/cloudformation/test_stack.py +0 -63
  809. data/packages/gsutil/boto/tests/unit/cloudfront/__init__.py +0 -0
  810. data/packages/gsutil/boto/tests/unit/cloudfront/test_invalidation_list.py +0 -113
  811. data/packages/gsutil/boto/tests/unit/cloudfront/test_signed_urls.py +0 -354
  812. data/packages/gsutil/boto/tests/unit/cloudsearch/__init__.py +0 -1
  813. data/packages/gsutil/boto/tests/unit/cloudsearch/test_connection.py +0 -241
  814. data/packages/gsutil/boto/tests/unit/cloudsearch/test_document.py +0 -324
  815. data/packages/gsutil/boto/tests/unit/cloudsearch/test_search.py +0 -325
  816. data/packages/gsutil/boto/tests/unit/dynamodb/__init__.py +0 -0
  817. data/packages/gsutil/boto/tests/unit/dynamodb/test_batch.py +0 -103
  818. data/packages/gsutil/boto/tests/unit/dynamodb/test_layer2.py +0 -119
  819. data/packages/gsutil/boto/tests/unit/dynamodb/test_types.py +0 -82
  820. data/packages/gsutil/boto/tests/unit/ec2/__init__.py +0 -0
  821. data/packages/gsutil/boto/tests/unit/ec2/autoscale/__init__.py +0 -0
  822. data/packages/gsutil/boto/tests/unit/ec2/autoscale/test_group.py +0 -162
  823. data/packages/gsutil/boto/tests/unit/ec2/test_address.py +0 -39
  824. data/packages/gsutil/boto/tests/unit/ec2/test_blockdevicemapping.py +0 -79
  825. data/packages/gsutil/boto/tests/unit/ec2/test_connection.py +0 -480
  826. data/packages/gsutil/boto/tests/unit/ec2/test_instance.py +0 -243
  827. data/packages/gsutil/boto/tests/unit/ec2/test_networkinterface.py +0 -140
  828. data/packages/gsutil/boto/tests/unit/ec2/test_volume.py +0 -248
  829. data/packages/gsutil/boto/tests/unit/emr/test_emr_responses.py +0 -373
  830. data/packages/gsutil/boto/tests/unit/glacier/__init__.py +0 -0
  831. data/packages/gsutil/boto/tests/unit/glacier/test_concurrent.py +0 -120
  832. data/packages/gsutil/boto/tests/unit/glacier/test_job.py +0 -60
  833. data/packages/gsutil/boto/tests/unit/glacier/test_layer1.py +0 -98
  834. data/packages/gsutil/boto/tests/unit/glacier/test_layer2.py +0 -266
  835. data/packages/gsutil/boto/tests/unit/glacier/test_utils.py +0 -116
  836. data/packages/gsutil/boto/tests/unit/glacier/test_vault.py +0 -100
  837. data/packages/gsutil/boto/tests/unit/glacier/test_writer.py +0 -185
  838. data/packages/gsutil/boto/tests/unit/provider/__init__.py +0 -0
  839. data/packages/gsutil/boto/tests/unit/provider/test_provider.py +0 -176
  840. data/packages/gsutil/boto/tests/unit/rds/__init__.py +0 -0
  841. data/packages/gsutil/boto/tests/unit/rds/test_connection.py +0 -131
  842. data/packages/gsutil/boto/tests/unit/s3/__init__.py +0 -0
  843. data/packages/gsutil/boto/tests/unit/s3/test_cors_configuration.py +0 -77
  844. data/packages/gsutil/boto/tests/unit/s3/test_key.py +0 -75
  845. data/packages/gsutil/boto/tests/unit/s3/test_keyfile.py +0 -101
  846. data/packages/gsutil/boto/tests/unit/s3/test_lifecycle.py +0 -97
  847. data/packages/gsutil/boto/tests/unit/s3/test_tagging.py +0 -47
  848. data/packages/gsutil/boto/tests/unit/s3/test_uri.py +0 -257
  849. data/packages/gsutil/boto/tests/unit/s3/test_website.py +0 -188
  850. data/packages/gsutil/boto/tests/unit/sns/__init__.py +0 -0
  851. data/packages/gsutil/boto/tests/unit/sns/test_connection.py +0 -99
  852. data/packages/gsutil/boto/tests/unit/sqs/__init__.py +0 -0
  853. data/packages/gsutil/boto/tests/unit/sqs/test_connection.py +0 -98
  854. data/packages/gsutil/boto/tests/unit/sqs/test_queue.py +0 -40
  855. data/packages/gsutil/boto/tests/unit/sts/test_connection.py +0 -74
  856. data/packages/gsutil/boto/tests/unit/test_connection.py +0 -60
  857. data/packages/gsutil/boto/tests/unit/utils/test_utils.py +0 -109
  858. data/packages/gsutil/boto/tox.ini +0 -8
  859. data/packages/gsutil/gslib/README +0 -5
  860. data/packages/gsutil/gslib/__init__.py +0 -22
  861. data/packages/gsutil/gslib/__init__.pyc +0 -0
  862. data/packages/gsutil/gslib/addlhelp/acls.py +0 -234
  863. data/packages/gsutil/gslib/addlhelp/anon.py +0 -57
  864. data/packages/gsutil/gslib/addlhelp/command_opts.py +0 -116
  865. data/packages/gsutil/gslib/addlhelp/dev.py +0 -139
  866. data/packages/gsutil/gslib/addlhelp/metadata.py +0 -186
  867. data/packages/gsutil/gslib/addlhelp/naming.py +0 -173
  868. data/packages/gsutil/gslib/addlhelp/prod.py +0 -160
  869. data/packages/gsutil/gslib/addlhelp/projects.py +0 -130
  870. data/packages/gsutil/gslib/addlhelp/subdirs.py +0 -110
  871. data/packages/gsutil/gslib/addlhelp/support.py +0 -86
  872. data/packages/gsutil/gslib/addlhelp/versioning.py +0 -242
  873. data/packages/gsutil/gslib/addlhelp/wildcards.py +0 -170
  874. data/packages/gsutil/gslib/bucket_listing_ref.py +0 -175
  875. data/packages/gsutil/gslib/bucket_listing_ref.pyc +0 -0
  876. data/packages/gsutil/gslib/command.py +0 -722
  877. data/packages/gsutil/gslib/command.pyc +0 -0
  878. data/packages/gsutil/gslib/command_runner.py +0 -101
  879. data/packages/gsutil/gslib/command_runner.pyc +0 -0
  880. data/packages/gsutil/gslib/commands/__init__.pyc +0 -0
  881. data/packages/gsutil/gslib/commands/cat.py +0 -131
  882. data/packages/gsutil/gslib/commands/cat.pyc +0 -0
  883. data/packages/gsutil/gslib/commands/chacl.py +0 -532
  884. data/packages/gsutil/gslib/commands/chacl.pyc +0 -0
  885. data/packages/gsutil/gslib/commands/config.py +0 -694
  886. data/packages/gsutil/gslib/commands/config.pyc +0 -0
  887. data/packages/gsutil/gslib/commands/cp.py +0 -1818
  888. data/packages/gsutil/gslib/commands/cp.pyc +0 -0
  889. data/packages/gsutil/gslib/commands/disablelogging.py +0 -101
  890. data/packages/gsutil/gslib/commands/disablelogging.pyc +0 -0
  891. data/packages/gsutil/gslib/commands/enablelogging.py +0 -149
  892. data/packages/gsutil/gslib/commands/enablelogging.pyc +0 -0
  893. data/packages/gsutil/gslib/commands/getacl.py +0 -82
  894. data/packages/gsutil/gslib/commands/getacl.pyc +0 -0
  895. data/packages/gsutil/gslib/commands/getcors.py +0 -121
  896. data/packages/gsutil/gslib/commands/getcors.pyc +0 -0
  897. data/packages/gsutil/gslib/commands/getdefacl.py +0 -86
  898. data/packages/gsutil/gslib/commands/getdefacl.pyc +0 -0
  899. data/packages/gsutil/gslib/commands/getlogging.py +0 -137
  900. data/packages/gsutil/gslib/commands/getlogging.pyc +0 -0
  901. data/packages/gsutil/gslib/commands/getversioning.py +0 -116
  902. data/packages/gsutil/gslib/commands/getversioning.pyc +0 -0
  903. data/packages/gsutil/gslib/commands/getwebcfg.py +0 -122
  904. data/packages/gsutil/gslib/commands/getwebcfg.pyc +0 -0
  905. data/packages/gsutil/gslib/commands/help.py +0 -218
  906. data/packages/gsutil/gslib/commands/help.pyc +0 -0
  907. data/packages/gsutil/gslib/commands/ls.py +0 -578
  908. data/packages/gsutil/gslib/commands/ls.pyc +0 -0
  909. data/packages/gsutil/gslib/commands/mb.py +0 -172
  910. data/packages/gsutil/gslib/commands/mb.pyc +0 -0
  911. data/packages/gsutil/gslib/commands/mv.py +0 -159
  912. data/packages/gsutil/gslib/commands/mv.pyc +0 -0
  913. data/packages/gsutil/gslib/commands/perfdiag.py +0 -903
  914. data/packages/gsutil/gslib/commands/perfdiag.pyc +0 -0
  915. data/packages/gsutil/gslib/commands/rb.py +0 -113
  916. data/packages/gsutil/gslib/commands/rb.pyc +0 -0
  917. data/packages/gsutil/gslib/commands/rm.py +0 -239
  918. data/packages/gsutil/gslib/commands/rm.pyc +0 -0
  919. data/packages/gsutil/gslib/commands/setacl.py +0 -138
  920. data/packages/gsutil/gslib/commands/setacl.pyc +0 -0
  921. data/packages/gsutil/gslib/commands/setcors.py +0 -145
  922. data/packages/gsutil/gslib/commands/setcors.pyc +0 -0
  923. data/packages/gsutil/gslib/commands/setdefacl.py +0 -105
  924. data/packages/gsutil/gslib/commands/setdefacl.pyc +0 -0
  925. data/packages/gsutil/gslib/commands/setmeta.py +0 -428
  926. data/packages/gsutil/gslib/commands/setmeta.pyc +0 -0
  927. data/packages/gsutil/gslib/commands/setversioning.py +0 -114
  928. data/packages/gsutil/gslib/commands/setversioning.pyc +0 -0
  929. data/packages/gsutil/gslib/commands/setwebcfg.py +0 -190
  930. data/packages/gsutil/gslib/commands/setwebcfg.pyc +0 -0
  931. data/packages/gsutil/gslib/commands/test.py +0 -228
  932. data/packages/gsutil/gslib/commands/test.pyc +0 -0
  933. data/packages/gsutil/gslib/commands/update.py +0 -305
  934. data/packages/gsutil/gslib/commands/update.pyc +0 -0
  935. data/packages/gsutil/gslib/commands/version.py +0 -150
  936. data/packages/gsutil/gslib/commands/version.pyc +0 -0
  937. data/packages/gsutil/gslib/exception.py +0 -76
  938. data/packages/gsutil/gslib/exception.pyc +0 -0
  939. data/packages/gsutil/gslib/help_provider.py +0 -81
  940. data/packages/gsutil/gslib/help_provider.pyc +0 -0
  941. data/packages/gsutil/gslib/name_expansion.py +0 -550
  942. data/packages/gsutil/gslib/name_expansion.pyc +0 -0
  943. data/packages/gsutil/gslib/plurality_checkable_iterator.py +0 -56
  944. data/packages/gsutil/gslib/plurality_checkable_iterator.pyc +0 -0
  945. data/packages/gsutil/gslib/project_id.py +0 -67
  946. data/packages/gsutil/gslib/project_id.pyc +0 -0
  947. data/packages/gsutil/gslib/storage_uri_builder.py +0 -56
  948. data/packages/gsutil/gslib/storage_uri_builder.pyc +0 -0
  949. data/packages/gsutil/gslib/tests/__init__.pyc +0 -0
  950. data/packages/gsutil/gslib/tests/test_chacl.py +0 -236
  951. data/packages/gsutil/gslib/tests/test_cp.py +0 -267
  952. data/packages/gsutil/gslib/tests/test_data/test.gif +0 -0
  953. data/packages/gsutil/gslib/tests/test_data/test.mp3 +0 -0
  954. data/packages/gsutil/gslib/tests/test_ls.py +0 -66
  955. data/packages/gsutil/gslib/tests/test_mv.py +0 -69
  956. data/packages/gsutil/gslib/tests/test_naming.py +0 -989
  957. data/packages/gsutil/gslib/tests/test_perfdiag.py +0 -41
  958. data/packages/gsutil/gslib/tests/test_plurality_checkable_iterator.py +0 -67
  959. data/packages/gsutil/gslib/tests/test_rm.py +0 -143
  960. data/packages/gsutil/gslib/tests/test_setacl.py +0 -152
  961. data/packages/gsutil/gslib/tests/test_setcors.py +0 -168
  962. data/packages/gsutil/gslib/tests/test_setmeta.py +0 -91
  963. data/packages/gsutil/gslib/tests/test_setversioning.py +0 -44
  964. data/packages/gsutil/gslib/tests/test_setwebcfg.py +0 -63
  965. data/packages/gsutil/gslib/tests/test_thread_pool.py +0 -92
  966. data/packages/gsutil/gslib/tests/test_wildcard_iterator.py +0 -364
  967. data/packages/gsutil/gslib/tests/testcase/base.py +0 -89
  968. data/packages/gsutil/gslib/tests/testcase/integration_testcase.py +0 -197
  969. data/packages/gsutil/gslib/tests/testcase/unit_testcase.py +0 -230
  970. data/packages/gsutil/gslib/tests/util.py +0 -125
  971. data/packages/gsutil/gslib/tests/util.pyc +0 -0
  972. data/packages/gsutil/gslib/thread_pool.py +0 -79
  973. data/packages/gsutil/gslib/thread_pool.pyc +0 -0
  974. data/packages/gsutil/gslib/util.py +0 -151
  975. data/packages/gsutil/gslib/util.pyc +0 -0
  976. data/packages/gsutil/gslib/wildcard_iterator.py +0 -492
  977. data/packages/gsutil/gslib/wildcard_iterator.pyc +0 -0
  978. data/packages/gsutil/gsutil +0 -377
  979. data/packages/gsutil/gsutil.spec.in +0 -75
  980. data/packages/gsutil/oauth2_plugin/__init__.py +0 -22
  981. data/packages/gsutil/oauth2_plugin/__init__.pyc +0 -0
  982. data/packages/gsutil/oauth2_plugin/oauth2_client.py +0 -642
  983. data/packages/gsutil/oauth2_plugin/oauth2_client.pyc +0 -0
  984. data/packages/gsutil/oauth2_plugin/oauth2_client_test.py +0 -374
  985. data/packages/gsutil/oauth2_plugin/oauth2_helper.py +0 -110
  986. data/packages/gsutil/oauth2_plugin/oauth2_helper.pyc +0 -0
  987. data/packages/gsutil/oauth2_plugin/oauth2_plugin.py +0 -24
  988. data/packages/gsutil/oauth2_plugin/oauth2_plugin.pyc +0 -0
  989. data/packages/gsutil/pkg_gen.sh +0 -54
  990. data/packages/gsutil/pkg_util.py +0 -60
  991. data/packages/gsutil/setup.py +0 -141
  992. data/packages/gsutil/third_party/__init__.py +0 -0
  993. data/packages/gsutil/third_party/__init__.pyc +0 -0
  994. data/packages/gsutil/third_party/fancy_urllib/README +0 -21
  995. data/packages/gsutil/third_party/fancy_urllib/__init__.py +0 -398
  996. data/packages/gsutil/third_party/fancy_urllib/__init__.pyc +0 -0
  997. data/tasks/rubygem.rake +0 -31
  998. metadata.gz.sig +0 -0
@@ -1,66 +0,0 @@
1
- # Copyright 2013 Google Inc. All Rights Reserved.
2
- #
3
- # Licensed under the Apache License, Version 2.0 (the "License");
4
- # you may not use this file except in compliance with the License.
5
- # You may obtain a copy of the License at
6
- #
7
- # http://www.apache.org/licenses/LICENSE-2.0
8
- #
9
- # Unless required by applicable law or agreed to in writing, software
10
- # distributed under the License is distributed on an "AS IS" BASIS,
11
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
- # See the License for the specific language governing permissions and
13
- # limitations under the License.
14
-
15
- import gslib.tests.testcase as testcase
16
- from gslib.tests.util import ObjectToURI as suri
17
-
18
-
19
- class TestLs(testcase.GsUtilIntegrationTestCase):
20
- """Integration tests for ls command."""
21
-
22
- def test_blank_ls(self):
23
- self.RunGsUtil(['ls'])
24
-
25
- def test_empty_bucket(self):
26
- bucket_uri = self.CreateBucket()
27
- stdout = self.RunGsUtil(['ls', suri(bucket_uri)], return_stdout=True)
28
- self.assertEqual('', stdout)
29
-
30
- def test_empty_bucket_with_b(self):
31
- bucket_uri = self.CreateBucket()
32
- stdout = self.RunGsUtil(['ls', '-b', suri(bucket_uri)], return_stdout=True)
33
- self.assertEqual('%s/\n' % suri(bucket_uri), stdout)
34
-
35
- def test_with_one_object(self):
36
- bucket_uri = self.CreateBucket(test_objects=1)
37
- stdout = self.RunGsUtil(['ls', suri(bucket_uri)], return_stdout=True)
38
- objuri = [suri(bucket_uri.clone_replace_name(key.name))
39
- for key in bucket_uri.list_bucket()][0]
40
- self.assertEqual('%s\n' % objuri, stdout)
41
-
42
- def test_subdir(self):
43
- bucket_uri = self.CreateBucket(test_objects=1)
44
- k1_uri = bucket_uri.clone_replace_name('foo')
45
- k1_uri.set_contents_from_string('baz')
46
- k2_uri = bucket_uri.clone_replace_name('dir/foo')
47
- k2_uri.set_contents_from_string('bar')
48
- stdout = self.RunGsUtil(['ls', '%s/dir' % suri(bucket_uri)],
49
- return_stdout=True)
50
- self.assertEqual('%s\n' % suri(k2_uri), stdout)
51
- stdout = self.RunGsUtil(['ls', suri(k1_uri)], return_stdout=True)
52
- self.assertEqual('%s\n' % suri(k1_uri), stdout)
53
-
54
- def test_versioning(self):
55
- bucket1_uri = self.CreateBucket(test_objects=1)
56
- bucket2_uri = self.CreateVersionedBucket(test_objects=1)
57
- bucket_list = list(bucket1_uri.list_bucket())
58
- objuri = [bucket1_uri.clone_replace_key(key).versionless_uri
59
- for key in bucket_list][0]
60
- self.RunGsUtil(['cp', objuri, suri(bucket2_uri)])
61
- self.RunGsUtil(['cp', objuri, suri(bucket2_uri)])
62
- stdout = self.RunGsUtil(['ls', '-a', suri(bucket2_uri)], return_stdout=True)
63
- self.assertNumLines(stdout, 3)
64
- stdout = self.RunGsUtil(['ls', '-la', suri(bucket2_uri)], return_stdout=True)
65
- self.assertIn('%s#' % bucket2_uri.clone_replace_name(bucket_list[0].name), stdout)
66
- self.assertIn('meta_generation=', stdout)
@@ -1,69 +0,0 @@
1
- # Copyright 2013 Google Inc. All Rights Reserved.
2
- #
3
- # Licensed under the Apache License, Version 2.0 (the "License");
4
- # you may not use this file except in compliance with the License.
5
- # You may obtain a copy of the License at
6
- #
7
- # http://www.apache.org/licenses/LICENSE-2.0
8
- #
9
- # Unless required by applicable law or agreed to in writing, software
10
- # distributed under the License is distributed on an "AS IS" BASIS,
11
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
- # See the License for the specific language governing permissions and
13
- # limitations under the License.
14
-
15
- import gslib.tests.testcase as testcase
16
- from gslib.tests.util import ObjectToURI as suri
17
-
18
-
19
- class TestMv(testcase.GsUtilIntegrationTestCase):
20
- """Integration tests for mv command."""
21
-
22
- def test_moving(self):
23
- # Create two buckets, one with 2 objects and one with 0 objects, and verify.
24
- bucket1_uri = self.CreateBucket(test_objects=2)
25
- stdout = self.RunGsUtil(['ls', suri(bucket1_uri)], return_stdout=True)
26
- self.assertNumLines(stdout, 2)
27
- bucket2_uri = self.CreateBucket()
28
- stdout = self.RunGsUtil(['ls', suri(bucket2_uri)], return_stdout=True)
29
- self.assertNumLines(stdout, 0)
30
-
31
- # Move two objects from bucket1 to bucket2.
32
- objs = [bucket1_uri.clone_replace_key(key).versionless_uri
33
- for key in bucket1_uri.list_bucket()]
34
- cmd = (['-m', 'mv'] + objs + [suri(bucket2_uri)])
35
- stderr = self.RunGsUtil(cmd, return_stderr=True)
36
- self.assertEqual(stderr.count('Copying'), 2)
37
- self.assertEqual(stderr.count('Removing'), 2)
38
-
39
- # Verify objects were moved.
40
- stdout = self.RunGsUtil(['ls', suri(bucket1_uri)], return_stdout=True)
41
- self.assertNumLines(stdout, 0)
42
- stdout = self.RunGsUtil(['ls', suri(bucket2_uri)], return_stdout=True)
43
- self.assertNumLines(stdout, 2)
44
-
45
- # Remove one of the objects.
46
- objs = [bucket2_uri.clone_replace_key(key).versionless_uri
47
- for key in bucket2_uri.list_bucket()]
48
- obj1 = objs[0]
49
- self.RunGsUtil(['rm', obj1])
50
-
51
- # Verify there are now 1 and 0 objects.
52
- stdout = self.RunGsUtil(['ls', suri(bucket1_uri)], return_stdout=True)
53
- self.assertNumLines(stdout, 0)
54
- stdout = self.RunGsUtil(['ls', suri(bucket2_uri)], return_stdout=True)
55
- self.assertNumLines(stdout, 1)
56
-
57
- # Move the 1 remaining object back.
58
- objs = [suri(bucket2_uri.clone_replace_key(key))
59
- for key in bucket2_uri.list_bucket()]
60
- cmd = (['-m', 'mv'] + objs + [suri(bucket1_uri)])
61
- stderr = self.RunGsUtil(cmd, return_stderr=True)
62
- self.assertEqual(stderr.count('Copying'), 1)
63
- self.assertEqual(stderr.count('Removing'), 1)
64
-
65
- # Verify object moved.
66
- stdout = self.RunGsUtil(['ls', suri(bucket1_uri)], return_stdout=True)
67
- self.assertNumLines(stdout, 1)
68
- stdout = self.RunGsUtil(['ls', suri(bucket2_uri)], return_stdout=True)
69
- self.assertNumLines(stdout, 0)
@@ -1,989 +0,0 @@
1
- # Copyright 2010 Google Inc. All Rights Reserved.
2
- #
3
- # Permission is hereby granted, free of charge, to any person obtaining a
4
- # copy of this software and associated documentation files (the
5
- # "Software"), to deal in the Software without restriction, including
6
- # without limitation the rights to use, copy, modify, merge, publish, dis-
7
- # tribute, sublicense, and/or sell copies of the Software, and to permit
8
- # persons to whom the Software is furnished to do so, subject to the fol-
9
- # lowing conditions:
10
- #
11
- # The above copyright notice and this permission notice shall be included
12
- # in all copies or substantial portions of the Software.
13
- #
14
- # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
15
- # OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
16
- # ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
17
- # SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
18
- # WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
- # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
20
- # IN THE SOFTWARE.
21
-
22
- """Tests for gsutil naming logic.
23
- The test code in this file runs against an in-memory storage service mock,
24
- so runs very quickly. This is valuable for testing changes that impact the
25
- naming rules, since those rules are complex and it's useful to be able to
26
- make small incremental changes and rerun the tests frequently. Additional
27
- end-to-end tests (which send traffic to the production Google Cloud Storage
28
- service) are available via the gsutil test command.
29
- """
30
-
31
- import gzip
32
- import os
33
- import posixpath
34
- import StringIO
35
-
36
- import boto
37
- from boto.exception import StorageResponseError
38
- from boto import storage_uri
39
-
40
- from gslib.commands import cp
41
- from gslib.exception import CommandException
42
- import gslib.tests.testcase as testcase
43
- from gslib.tests.util import ObjectToURI as suri
44
-
45
-
46
- class GsutilNamingTests(testcase.GsUtilUnitTestCase):
47
- """gsutil command method test suite"""
48
-
49
- def testGetPathBeforeFinalDir(self):
50
- """Tests _GetPathBeforeFinalDir() (unit test)"""
51
- self.assertEqual('gs://',
52
- cp._GetPathBeforeFinalDir(storage_uri('gs://bucket/')))
53
- self.assertEqual('gs://bucket',
54
- cp._GetPathBeforeFinalDir(storage_uri('gs://bucket/dir/')))
55
- self.assertEqual('gs://bucket',
56
- cp._GetPathBeforeFinalDir(storage_uri('gs://bucket/dir')))
57
- self.assertEqual('gs://bucket/dir',
58
- cp._GetPathBeforeFinalDir(
59
- storage_uri('gs://bucket/dir/obj')))
60
- src_dir = self.CreateTempDir()
61
- subdir = os.path.join(src_dir, 'subdir')
62
- os.mkdir(subdir)
63
- self.assertEqual(suri(src_dir),
64
- cp._GetPathBeforeFinalDir(storage_uri(suri(subdir))))
65
-
66
- def testCopyingTopLevelFileToBucket(self):
67
- """Tests copying one top-level file to a bucket"""
68
- src_file = self.CreateTempFile(file_name='f0')
69
- dst_bucket_uri = self.CreateBucket()
70
- self.RunCommand('cp', [src_file, suri(dst_bucket_uri)])
71
- actual = list(self._test_wildcard_iterator(
72
- suri(dst_bucket_uri, '**')).IterUris())
73
- self.assertEqual(1, len(actual))
74
- self.assertEqual('f0', actual[0].object_name)
75
-
76
- def testCopyingAbsolutePathDirToBucket(self):
77
- """Tests recursively copying absolute path directory to a bucket"""
78
- dst_bucket_uri = self.CreateBucket()
79
- src_dir_root = self.CreateTempDir(test_files=[
80
- 'f0', 'f1', 'f2.txt', ('dir0', 'dir1', 'nested')])
81
- self.RunCommand('cp', ['-R', src_dir_root, suri(dst_bucket_uri)])
82
- actual = set(str(u) for u in self._test_wildcard_iterator(
83
- suri(dst_bucket_uri, '**')).IterUris())
84
- src_tmpdir = os.path.split(src_dir_root)[1]
85
- expected = set([
86
- suri(dst_bucket_uri, src_tmpdir, 'f0'),
87
- suri(dst_bucket_uri, src_tmpdir, 'f1'),
88
- suri(dst_bucket_uri, src_tmpdir, 'f2.txt'),
89
- suri(dst_bucket_uri, src_tmpdir, 'dir0', 'dir1', 'nested')])
90
- self.assertEqual(expected, actual)
91
-
92
- def testCopyingRelativePathDirToBucket(self):
93
- """Tests recursively copying relative directory to a bucket"""
94
- dst_bucket_uri = self.CreateBucket()
95
- src_dir = self.CreateTempDir(test_files=[('dir0', 'f1')])
96
- self.RunCommand('cp', ['-R', 'dir0', suri(dst_bucket_uri)], cwd=src_dir)
97
- actual = set(str(u) for u in self._test_wildcard_iterator(
98
- suri(dst_bucket_uri, '**')).IterUris())
99
- expected = set([suri(dst_bucket_uri, 'dir0', 'f1')])
100
- self.assertEqual(expected, actual)
101
-
102
- def testCopyingRelPathSubDirToBucketSubdirWithDollarFolderObj(self):
103
- """Tests recursively copying relative sub-directory to bucket subdir
104
- signified by a $folder$ object"""
105
- # Create a $folder$ object to simulate a folder created by GCS manager (or
106
- # various other tools), which gsutil understands to mean there is a folder
107
- # into which the object is being copied.
108
- dst_bucket_uri = self.CreateBucket()
109
- self.CreateObject(bucket_uri=dst_bucket_uri, object_name='abc_$folder$',
110
- contents='')
111
- src_dir = self.CreateTempDir(test_files=[('dir0', 'dir1', 'f1')])
112
- self.RunCommand('cp', ['-R', os.path.join('dir0', 'dir1'),
113
- suri(dst_bucket_uri, 'abc')], cwd=src_dir)
114
- actual = set(str(u) for u in self._test_wildcard_iterator(
115
- suri(dst_bucket_uri, '**')).IterUris())
116
- expected = set([suri(dst_bucket_uri, 'abc_$folder$'),
117
- suri(dst_bucket_uri, 'abc', 'dir1', 'f1')])
118
- self.assertEqual(expected, actual)
119
-
120
- def testCopyingRelativePathSubDirToBucketSubdirSignifiedBySlash(self):
121
- """Tests recursively copying relative sub-directory to bucket subdir
122
- signified by a / object"""
123
- dst_bucket_uri = self.CreateBucket()
124
- src_dir = self.CreateTempDir(test_files=[('dir0', 'dir1', 'f1')])
125
- self.RunCommand('cp', ['-R', os.path.join('dir0', 'dir1'),
126
- suri(dst_bucket_uri, 'abc') + '/'], cwd=src_dir)
127
- actual = set(str(u) for u in self._test_wildcard_iterator(
128
- suri(dst_bucket_uri, '**')).IterUris())
129
- expected = set([suri(dst_bucket_uri, 'abc', 'dir1', 'f1')])
130
- self.assertEqual(expected, actual)
131
-
132
- def testCopyingRelativePathSubDirToBucket(self):
133
- """Tests recursively copying relative sub-directory to a bucket"""
134
- dst_bucket_uri = self.CreateBucket()
135
- src_dir = self.CreateTempDir(test_files=[('dir0', 'dir1', 'f1')])
136
- self.RunCommand('cp', ['-R', os.path.join('dir0', 'dir1'),
137
- suri(dst_bucket_uri)], cwd=src_dir)
138
- actual = set(str(u) for u in self._test_wildcard_iterator(
139
- suri(dst_bucket_uri, '**')).IterUris())
140
- expected = set([suri(dst_bucket_uri, 'dir1', 'f1')])
141
- self.assertEqual(expected, actual)
142
-
143
- def testCopyingDotSlashToBucket(self):
144
- """Tests copying ./ to a bucket produces expected naming"""
145
- # When running a command like gsutil cp -r . gs://dest we expect the dest
146
- # obj names to be of the form gs://dest/abc, not gs://dest/./abc.
147
- dst_bucket_uri = self.CreateBucket()
148
- src_dir = self.CreateTempDir(test_files=['foo'])
149
- for rel_src_dir in ['.', '.%s' % os.sep]:
150
- self.RunCommand('cp', ['-R', rel_src_dir, suri(dst_bucket_uri)],
151
- cwd=src_dir)
152
- actual = set(str(u) for u in self._test_wildcard_iterator(
153
- suri(dst_bucket_uri, '**')).IterUris())
154
- expected = set([suri(dst_bucket_uri, 'foo')])
155
- self.assertEqual(expected, actual)
156
-
157
- def testCopyingDirContainingOneFileToBucket(self):
158
- """Tests copying a directory containing 1 file to a bucket.
159
- We test this case to ensure that correct bucket handling isn't dependent
160
- on the copy being treated as a multi-source copy.
161
- """
162
- dst_bucket_uri = self.CreateBucket()
163
- src_dir = self.CreateTempDir(test_files=[('dir0', 'dir1', 'foo')])
164
- self.RunCommand('cp', ['-R', os.path.join(src_dir, 'dir0', 'dir1'),
165
- suri(dst_bucket_uri)])
166
- actual = list((str(u) for u in self._test_wildcard_iterator(
167
- suri(dst_bucket_uri, '**')).IterUris()))
168
- self.assertEqual(1, len(actual))
169
- self.assertEqual(suri(dst_bucket_uri, 'dir1', 'foo'), actual[0])
170
-
171
- def testCopyingBucketToDir(self):
172
- """Tests copying from a bucket to a directory"""
173
- src_bucket_uri = self.CreateBucket(test_objects=['foo', 'dir/foo2'])
174
- dst_dir = self.CreateTempDir()
175
- self.RunCommand('cp', ['-R', suri(src_bucket_uri), dst_dir])
176
- actual = set(str(u) for u in self._test_wildcard_iterator(
177
- '%s%s**' % (dst_dir, os.sep)).IterUris())
178
- expected = set([suri(dst_dir, src_bucket_uri.bucket_name, 'foo'),
179
- suri(dst_dir, src_bucket_uri.bucket_name, 'dir', 'foo2')])
180
- self.assertEqual(expected, actual)
181
-
182
- def testCopyingBucketToBucket(self):
183
- """Tests copying from a bucket-only URI to a bucket"""
184
- src_bucket_uri = self.CreateBucket(test_objects=['foo', 'dir/foo2'])
185
- dst_bucket_uri = self.CreateBucket()
186
- self.RunCommand('cp', ['-R', suri(src_bucket_uri), suri(dst_bucket_uri)])
187
- actual = set(str(u) for u in self._test_wildcard_iterator(
188
- suri(dst_bucket_uri, '**')).IterUris())
189
- expected = set([
190
- suri(dst_bucket_uri, src_bucket_uri.bucket_name, 'foo'),
191
- suri(dst_bucket_uri, src_bucket_uri.bucket_name, 'dir', 'foo2')])
192
- self.assertEqual(expected, actual)
193
-
194
- def testCopyingDirectoryToDirectory(self):
195
- """Tests copying from a directory to a directory"""
196
- src_dir = self.CreateTempDir(test_files=['foo', ('dir', 'foo2')])
197
- dst_dir = self.CreateTempDir()
198
- self.RunCommand('cp', ['-R', src_dir, dst_dir])
199
- actual = set(str(u) for u in self._test_wildcard_iterator(
200
- '%s%s**' % (dst_dir, os.sep)).IterUris())
201
- src_dir_base = os.path.split(src_dir)[1]
202
- expected = set([suri(dst_dir, src_dir_base, 'foo'),
203
- suri(dst_dir, src_dir_base, 'dir', 'foo2')])
204
- self.assertEqual(expected, actual)
205
-
206
- def testCopyingFilesAndDirNonRecursive(self):
207
- """Tests copying containing files and a directory without -R"""
208
- src_dir = self.CreateTempDir(test_files=['foo', 'bar', ('d1', 'f2'),
209
- ('d2', 'f3'), ('d3', 'd4', 'f4')])
210
- dst_dir = self.CreateTempDir()
211
- self.RunCommand('cp', ['%s%s*' % (src_dir, os.sep), dst_dir])
212
- actual = set(str(u) for u in self._test_wildcard_iterator(
213
- '%s%s**' % (dst_dir, os.sep)).IterUris())
214
- expected = set([suri(dst_dir, 'foo'), suri(dst_dir, 'bar')])
215
- self.assertEqual(expected, actual)
216
-
217
- def testCopyingFileToDir(self):
218
- """Tests copying one file to a directory"""
219
- src_file = self.CreateTempFile(file_name='foo')
220
- dst_dir = self.CreateTempDir()
221
- self.RunCommand('cp', [src_file, dst_dir])
222
- actual = list(self._test_wildcard_iterator(
223
- '%s%s*' % (dst_dir, os.sep)).IterUris())
224
- self.assertEqual(1, len(actual))
225
- self.assertEqual(suri(dst_dir, 'foo'), actual[0].uri)
226
-
227
- def testCopyingFileToObjectWithConsecutiveSlashes(self):
228
- """Tests copying a file to an object containing consecutive slashes"""
229
- src_file = self.CreateTempFile(file_name='f0')
230
- dst_bucket_uri = self.CreateBucket()
231
- self.RunCommand('cp', [src_file, suri(dst_bucket_uri) + '//obj'])
232
- actual = list(self._test_wildcard_iterator(
233
- suri(dst_bucket_uri, '**')).IterUris())
234
- self.assertEqual(1, len(actual))
235
- self.assertEqual('/obj', actual[0].object_name)
236
-
237
- def testCopyingCompressedFileToBucket(self):
238
- """Tests copying one file with compression to a bucket"""
239
- src_file = self.CreateTempFile(contents='plaintext', file_name='f2.txt')
240
- dst_bucket_uri = self.CreateBucket()
241
- self.RunCommand('cp', ['-z', 'txt', src_file, suri(dst_bucket_uri)],)
242
- actual = list(str(u) for u in self._test_wildcard_iterator(
243
- suri(dst_bucket_uri, '*')).IterUris())
244
- self.assertEqual(1, len(actual))
245
- expected_dst_uri = dst_bucket_uri.clone_replace_name('f2.txt')
246
- self.assertEqual(expected_dst_uri.uri, actual[0])
247
- dst_key = expected_dst_uri.get_key()
248
- dst_key.open_read()
249
- self.assertEqual('gzip', dst_key.content_encoding)
250
- contents = dst_key.read()
251
- f = gzip.GzipFile(fileobj=StringIO.StringIO(contents), mode='rb')
252
- try:
253
- self.assertEqual(f.read(), 'plaintext')
254
- finally:
255
- f.close()
256
-
257
- def testCopyingObjectToObject(self):
258
- """Tests copying an object to an object"""
259
- src_bucket_uri = self.CreateBucket(test_objects=['obj'])
260
- dst_bucket_uri = self.CreateBucket()
261
- self.RunCommand('cp', [suri(src_bucket_uri, 'obj'), suri(dst_bucket_uri)])
262
- actual = list(self._test_wildcard_iterator(
263
- suri(dst_bucket_uri, '*')).IterUris())
264
- self.assertEqual(1, len(actual))
265
- self.assertEqual('obj', actual[0].object_name)
266
-
267
- def testCopyingObjsAndFilesToDir(self):
268
- """Tests copying objects and files to a directory"""
269
- src_bucket_uri = self.CreateBucket(test_objects=['f1'])
270
- src_dir = self.CreateTempDir(test_files=['f2'])
271
- dst_dir = self.CreateTempDir()
272
- self.RunCommand('cp', ['-R', suri(src_bucket_uri, '**'),
273
- os.path.join(src_dir, '**'), dst_dir])
274
- actual = set(str(u) for u in self._test_wildcard_iterator(
275
- os.path.join(dst_dir, '**')).IterUris())
276
- expected = set([suri(dst_dir, 'f1'), suri(dst_dir, 'f2')])
277
- self.assertEqual(expected, actual)
278
-
279
- def testCopyingObjToDot(self):
280
- """Tests that copying an object to . or ./ downloads to correct name"""
281
- src_bucket_uri = self.CreateBucket(test_objects=['f1'])
282
- dst_dir = self.CreateTempDir()
283
- for final_char in ('/', ''):
284
- self.RunCommand('cp', [suri(src_bucket_uri, 'f1'), '.%s' % final_char],
285
- cwd=dst_dir)
286
- actual = set()
287
- for dirname, dirnames, filenames in os.walk(dst_dir):
288
- for subdirname in dirnames:
289
- actual.add(os.path.join(dirname, subdirname))
290
- for filename in filenames:
291
- actual.add(os.path.join(dirname, filename))
292
- expected = set([os.path.join(dst_dir, 'f1')])
293
- self.assertEqual(expected, actual)
294
-
295
- def testCopyingObjsAndFilesToBucket(self):
296
- """Tests copying objects and files to a bucket"""
297
- src_bucket_uri = self.CreateBucket(test_objects=['f1'])
298
- src_dir = self.CreateTempDir(test_files=['f2'])
299
- dst_bucket_uri = self.CreateBucket()
300
- self.RunCommand('cp', ['-R', suri(src_bucket_uri, '**'),
301
- '%s%s**' % (src_dir, os.sep), suri(dst_bucket_uri)])
302
- actual = set(str(u) for u in self._test_wildcard_iterator(
303
- suri(dst_bucket_uri, '**')).IterUris())
304
- expected = set([suri(dst_bucket_uri, 'f1'), suri(dst_bucket_uri, 'f2')])
305
- self.assertEqual(expected, actual)
306
-
307
- def testAttemptDirCopyWithoutRecursion(self):
308
- """Tests copying a directory without -R"""
309
- src_dir = self.CreateTempDir(test_files=1)
310
- dst_dir = self.CreateTempDir()
311
- try:
312
- self.RunCommand('cp', [src_dir, dst_dir])
313
- self.fail('Did not get expected CommandException')
314
- except CommandException, e:
315
- self.assertIn('No URIs matched', e.reason)
316
-
317
- def testAttemptCopyingProviderOnlySrc(self):
318
- """Attempts to copy a src specified as a provider-only URI"""
319
- src_bucket_uri = self.CreateBucket()
320
- try:
321
- self.RunCommand('cp', ['gs://', suri(src_bucket_uri)])
322
- self.fail('Did not get expected CommandException')
323
- except CommandException, e:
324
- self.assertIn('provider-only', e.reason)
325
-
326
- def testAttemptCopyingOverlappingSrcDstFile(self):
327
- """Attempts to an object atop itself"""
328
- src_file = self.CreateTempFile()
329
- try:
330
- self.RunCommand('cp', [src_file, src_file])
331
- self.fail('Did not get expected CommandException')
332
- except CommandException, e:
333
- self.assertIn('are the same file - abort', e.reason)
334
-
335
- def testAttemptCopyingToMultiMatchWildcard(self):
336
- """Attempts to copy where dst wildcard matches >1 obj"""
337
- src_bucket_uri = self.CreateBucket()
338
- try:
339
- self.RunCommand('cp', [suri(src_bucket_uri, 'obj0'),
340
- suri(src_bucket_uri, '*')])
341
- self.fail('Did not get expected CommandException')
342
- except CommandException, e:
343
- self.assertNotEqual(e.reason.find('must match exactly 1 URI'), -1)
344
-
345
- def testAttemptCopyingMultiObjsToFile(self):
346
- """Attempts to copy multiple objects to a file"""
347
- src_bucket_uri = self.CreateBucket(test_objects=2)
348
- dst_file = self.CreateTempFile()
349
- try:
350
- self.RunCommand('cp', ['-R', suri(src_bucket_uri, '*'), dst_file])
351
- self.fail('Did not get expected CommandException')
352
- except CommandException, e:
353
- self.assertIn('must name a directory, bucket, or', e.reason)
354
-
355
- def testAttemptCopyingWithFileDirConflict(self):
356
- """Attempts to copy objects that cause a file/directory conflict"""
357
- # Create objects with name conflicts (a/b and a). Use 'dst' bucket because
358
- # it gets cleared after each test.
359
- bucket_uri = self.CreateBucket()
360
- self.CreateObject(bucket_uri=bucket_uri, object_name='a')
361
- self.CreateObject(bucket_uri=bucket_uri, object_name='b/a')
362
- dst_dir = self.CreateTempDir()
363
- try:
364
- self.RunCommand('cp', ['-R', suri(bucket_uri), dst_dir])
365
- self.fail('Did not get expected CommandException')
366
- except CommandException, e:
367
- self.assertNotEqual('exists where a directory needs to be created',
368
- e.reason)
369
-
370
- def testAttemptCopyingWithDirFileConflict(self):
371
- """Attempts to copy an object that causes a directory/file conflict"""
372
- # Create an object that conflicts with dest subdir.
373
- tmpdir = self.CreateTempDir()
374
- os.mkdir(os.path.join(tmpdir, 'abc'))
375
- src_uri = self.CreateObject(object_name='abc', contents='bar')
376
- try:
377
- self.RunCommand('cp', [suri(src_uri), tmpdir + '/'])
378
- self.fail('Did not get expected CommandException')
379
- except CommandException, e:
380
- self.assertNotEqual('where the file needs to be created', e.reason)
381
-
382
- def testWildcardMoveWithinBucket(self):
383
- """Attempts to move using src wildcard that overlaps dest object.
384
- We want to ensure that this doesn't stomp the result data. See the
385
- comment starting with 'Expand wildcards before' in commands/mv.py
386
- for details.
387
- """
388
- dst_bucket_uri = self.CreateBucket(test_objects=['old'])
389
- self.RunCommand('mv', [suri(dst_bucket_uri, 'old*'),
390
- suri(dst_bucket_uri, 'new')])
391
- actual = set(str(u) for u in self._test_wildcard_iterator(
392
- suri(dst_bucket_uri, '**')).IterUris())
393
- expected = set([suri(dst_bucket_uri, 'new')])
394
- self.assertEqual(expected, actual)
395
-
396
- def testLsNonExistentObjectWithPrefixName(self):
397
- """Test ls of non-existent obj that matches prefix of existing objs"""
398
- # Use an object name that matches a prefix of other names at that level, to
399
- # ensure the ls subdir handling logic doesn't pick up anything extra.
400
- src_bucket_uri = self.CreateBucket()
401
- try:
402
- output = self.RunCommand('ls', [suri(src_bucket_uri, 'obj')],
403
- return_stdout=True)
404
- except CommandException, e:
405
- self.assertIn('No such object', e.reason)
406
-
407
- def testLsBucketNonRecursive(self):
408
- """Test that ls of a bucket returns expected results"""
409
- src_bucket_uri = self.CreateBucket(test_objects=['foo1', 'd0/foo2',
410
- 'd1/d2/foo3'])
411
- output = self.RunCommand('ls', [suri(src_bucket_uri, '*')],
412
- return_stdout=True)
413
- expected = set([suri(src_bucket_uri, 'foo1'),
414
- suri(src_bucket_uri, 'd1', ':'),
415
- suri(src_bucket_uri, 'd1', 'd2') + src_bucket_uri.delim,
416
- suri(src_bucket_uri, 'd0', ':'),
417
- suri(src_bucket_uri, 'd0', 'foo2')])
418
- expected.add('') # Blank line between subdir listings.
419
- actual = set(output.split('\n'))
420
- self.assertEqual(expected, actual)
421
-
422
- def testLsBucketRecursive(self):
423
- """Test that ls -R of a bucket returns expected results"""
424
- src_bucket_uri = self.CreateBucket(test_objects=['foo1', 'd0/foo2',
425
- 'd1/d2/foo3'])
426
- output = self.RunCommand('ls', ['-R', suri(src_bucket_uri, '*')],
427
- return_stdout=True)
428
- expected = set([suri(src_bucket_uri, 'foo1'),
429
- suri(src_bucket_uri, 'd1', ':'),
430
- suri(src_bucket_uri, 'd1', 'd2', ':'),
431
- suri(src_bucket_uri, 'd1', 'd2', 'foo3'),
432
- suri(src_bucket_uri, 'd0', ':'),
433
- suri(src_bucket_uri, 'd0', 'foo2')])
434
- expected.add('') # Blank line between subdir listings.
435
- actual = set(output.split('\n'))
436
- self.assertEqual(expected, actual)
437
-
438
- def testLsBucketRecursiveWithLeadingSlashObjectName(self):
439
- """Test that ls -R of a bucket with an object that has leading slash"""
440
- dst_bucket_uri = self.CreateBucket(test_objects=['f0'])
441
- output = self.RunCommand('ls', ['-R', suri(dst_bucket_uri) + '*'],
442
- return_stdout=True)
443
- expected = set([suri(dst_bucket_uri, 'f0')])
444
- expected.add('') # Blank line between subdir listings.
445
- actual = set(output.split('\n'))
446
- self.assertEqual(expected, actual)
447
-
448
- def testLsBucketSubdirNonRecursive(self):
449
- """Test that ls of a bucket subdir returns expected results"""
450
- src_bucket_uri = self.CreateBucket(test_objects=['src_subdir/foo',
451
- 'src_subdir/nested/foo2'])
452
- output = self.RunCommand('ls', [suri(src_bucket_uri, 'src_subdir')],
453
- return_stdout=True)
454
- expected = set([
455
- suri(src_bucket_uri, 'src_subdir', 'foo'),
456
- suri(src_bucket_uri, 'src_subdir', 'nested') + src_bucket_uri.delim])
457
- expected.add('') # Blank line between subdir listings.
458
- actual = set(output.split('\n'))
459
- self.assertEqual(expected, actual)
460
-
461
- def testLsBucketSubdirRecursive(self):
462
- """Test that ls -R of a bucket subdir returns expected results"""
463
- src_bucket_uri = self.CreateBucket(test_objects=['src_subdir/foo',
464
- 'src_subdir/nested/foo2'])
465
- for final_char in ('/', ''):
466
- output = self.RunCommand(
467
- 'ls', ['-R', suri(src_bucket_uri, 'src_subdir') + final_char],
468
- return_stdout=True)
469
- expected = set([
470
- suri(src_bucket_uri, 'src_subdir', ':'),
471
- suri(src_bucket_uri, 'src_subdir', 'foo'),
472
- suri(src_bucket_uri, 'src_subdir', 'nested', ':'),
473
- suri(src_bucket_uri, 'src_subdir', 'nested', 'foo2')])
474
- expected.add('') # Blank line between subdir listings.
475
- actual = set(output.split('\n'))
476
- self.assertEqual(expected, actual)
477
-
478
- def testSetAclOnBucketRuns(self):
479
- """Test that the setacl command basically runs"""
480
- # We don't test reading back the acl (via getacl command) because at present
481
- # MockStorageService doesn't translate canned ACLs into actual ACL XML.
482
- src_bucket_uri = self.CreateBucket()
483
- self.RunCommand('setacl', ['private', suri(src_bucket_uri)])
484
-
485
- def testSetAclOnWildcardNamedBucketRuns(self):
486
- """Test that setacl basically runs against wildcard-named bucket"""
487
- # We don't test reading back the acl (via getacl command) because at present
488
- # MockStorageService doesn't translate canned ACLs into actual ACL XML.
489
- src_bucket_uri = self.CreateBucket(test_objects=['f0'])
490
- self.RunCommand('setacl', ['private', suri(src_bucket_uri)[:-2] + '*'])
491
-
492
- def testSetAclOnObjectRuns(self):
493
- """Test that the setacl command basically runs"""
494
- src_bucket_uri = self.CreateBucket(test_objects=['f0'])
495
- self.RunCommand('setacl', ['private', suri(src_bucket_uri, '*')])
496
-
497
- def testSetDefAclOnBucketRuns(self):
498
- """Test that the setdefacl command basically runs"""
499
- src_bucket_uri = self.CreateBucket()
500
- self.RunCommand('setdefacl', ['private', suri(src_bucket_uri)])
501
-
502
- def testSetDefAclOnObjectFails(self):
503
- """Test that the setdefacl command fails when run against an object"""
504
- src_bucket_uri = self.CreateBucket()
505
- try:
506
- self.RunCommand('setdefacl', ['private', suri(src_bucket_uri, '*')])
507
- self.fail('Did not get expected CommandException')
508
- except CommandException, e:
509
- self.assertIn('URI must name a bucket', e.reason)
510
-
511
- def testMinusDOptionWorks(self):
512
- """Tests using gsutil -D option"""
513
- src_file = self.CreateTempFile(file_name='f0')
514
- dst_bucket_uri = self.CreateBucket()
515
- self.RunCommand('cp', [src_file, suri(dst_bucket_uri)], debug=3)
516
- actual = list(self._test_wildcard_iterator(
517
- suri(dst_bucket_uri, '*')).IterUris())
518
- self.assertEqual(1, len(actual))
519
- self.assertEqual('f0', actual[0].object_name)
520
-
521
- def DownloadTestHelper(self, func):
522
- """
523
- Test resumable download with custom test function to distort downloaded
524
- data. We expect an exception to be raised and the dest file to be removed.
525
- """
526
- object_uri = self.CreateObject()
527
- dst_dir = self.CreateTempDir()
528
- try:
529
- self.RunCommand('cp', [suri(object_uri), dst_dir], test_method=func)
530
- self.fail('Did not get expected CommandException')
531
- except CommandException:
532
- self.assertFalse(os.listdir(dst_dir))
533
- except:
534
- self.fail('Unexpected exception raised')
535
-
536
- def testDownloadWithObjectSizeChange(self):
537
- """
538
- Test resumable download on an object that changes size before the
539
- downloaded file's checksum is validated.
540
- """
541
- def append(fp):
542
- """Append a byte at end of an open file and flush contents."""
543
- fp.seek(0,2)
544
- fp.write('x')
545
- fp.flush()
546
- self.DownloadTestHelper(append)
547
-
548
- def testDownloadWithFileContentChange(self):
549
- """
550
- Tests resumable download on an object where the file content changes
551
- before the downloaded file's checksum is validated.
552
- """
553
- def overwrite(fp):
554
- """Overwrite first byte in an open file and flush contents."""
555
- fp.seek(0)
556
- fp.write('x')
557
- fp.flush()
558
- self.DownloadTestHelper(overwrite)
559
-
560
- def testFlatCopyingObjsAndFilesToBucketSubDir(self):
561
- """Tests copying flatly listed objects and files to bucket subdir"""
562
- src_bucket_uri = self.CreateBucket(test_objects=['f0', 'd0/f1', 'd1/d2/f2'])
563
- src_dir = self.CreateTempDir(test_files=['f3', ('d3', 'f4'),
564
- ('d4', 'd5', 'f5')])
565
- dst_bucket_uri = self.CreateBucket(test_objects=['dst_subdir0/existing',
566
- 'dst_subdir1/existing'])
567
- # Test with and without final slash on dest subdir.
568
- for i, final_char in enumerate(('/', '')):
569
- self.RunCommand(
570
- 'cp', ['-R', suri(src_bucket_uri, '**'), os.path.join(src_dir, '**'),
571
- suri(dst_bucket_uri, 'dst_subdir%d' % i) + final_char])
572
-
573
- actual = set(str(u) for u in self._test_wildcard_iterator(
574
- suri(dst_bucket_uri, '**')).IterUris())
575
- expected = set()
576
- for i in range(2):
577
- expected.add(suri(dst_bucket_uri, 'dst_subdir%d' % i, 'existing'))
578
- for j in range(6):
579
- expected.add(suri(dst_bucket_uri, 'dst_subdir%d' % i, 'f%d' % j))
580
- self.assertEqual(expected, actual)
581
-
582
- def testRecursiveCopyObjsAndFilesToExistingBucketSubDir(self):
583
- """Tests recursive copy of objects and files to existing bucket subdir"""
584
- src_bucket_uri = self.CreateBucket(test_objects=['f0', 'nested/f1'])
585
- dst_bucket_uri = self.CreateBucket(test_objects=[
586
- 'dst_subdir0/existing_obj', 'dst_subdir1/existing_obj'])
587
- src_dir = self.CreateTempDir(test_files=['f2', ('nested', 'f3')])
588
- # Test with and without final slash on dest subdir.
589
- for i, final_char in enumerate(('/', '')):
590
- self.RunCommand(
591
- 'cp', ['-R', suri(src_bucket_uri), src_dir,
592
- suri(dst_bucket_uri, 'dst_subdir%d' % i) + final_char])
593
- actual = set(str(u) for u in self._test_wildcard_iterator(
594
- suri(dst_bucket_uri, 'dst_subdir%d' % i, '**')).IterUris())
595
- tmp_dirname = os.path.split(src_dir)[1]
596
- bucketname = src_bucket_uri.bucket_name
597
- expected = set([
598
- suri(dst_bucket_uri, 'dst_subdir%d' % i, 'existing_obj'),
599
- suri(dst_bucket_uri, 'dst_subdir%d' % i, bucketname, 'f0'),
600
- suri(dst_bucket_uri, 'dst_subdir%d' % i, bucketname, 'nested', 'f1'),
601
- suri(dst_bucket_uri, 'dst_subdir%d' % i, tmp_dirname, 'f2'),
602
- suri(dst_bucket_uri, 'dst_subdir%d' % i, tmp_dirname, 'nested', 'f3')
603
- ])
604
- self.assertEqual(expected, actual)
605
-
606
- def testRecursiveCopyObjsAndFilesToNonExistentBucketSubDir(self):
607
- """Tests recursive copy of objs + files to non-existent bucket subdir"""
608
- src_bucket_uri = self.CreateBucket(test_objects=['f0', 'nested/f1'])
609
- src_dir = self.CreateTempDir(test_files=['f2', ('nested', 'f3')])
610
- dst_bucket_uri = self.CreateBucket()
611
- x = ['-R', src_dir, suri(src_bucket_uri),
612
- suri(dst_bucket_uri, 'dst_subdir')]
613
- stdout = self.RunCommand(
614
- 'cp', x, return_stdout=True)
615
- actual = set(str(u) for u in self._test_wildcard_iterator(
616
- suri(dst_bucket_uri, '**')).IterUris())
617
- expected = set([suri(dst_bucket_uri, 'dst_subdir', 'f0'),
618
- suri(dst_bucket_uri, 'dst_subdir', 'nested', 'f1'),
619
- suri(dst_bucket_uri, 'dst_subdir', 'f2'),
620
- suri(dst_bucket_uri, 'dst_subdir', 'nested', 'f3')])
621
- self.assertEqual(expected, actual)
622
-
623
- def testCopyingBucketSubDirToDir(self):
624
- """Tests copying a bucket subdir to a directory"""
625
- src_bucket_uri = self.CreateBucket(test_objects=['src_subdir/obj'])
626
- dst_dir = self.CreateTempDir()
627
- # Test with and without final slash on dest subdir.
628
- for (final_src_char, final_dst_char) in (
629
- ('', ''), ('', '/'), ('/', ''), ('/', '/') ):
630
- self.RunCommand(
631
- 'cp', ['-R', suri(src_bucket_uri, 'src_subdir') + final_src_char,
632
- dst_dir + final_dst_char])
633
- actual = set(str(u) for u in self._test_wildcard_iterator(
634
- '%s%s**' % (dst_dir, os.sep)).IterUris())
635
- expected = set([suri(dst_dir, 'src_subdir', 'obj')])
636
- self.assertEqual(expected, actual)
637
-
638
- def testCopyingWildcardSpecifiedBucketSubDirToExistingDir(self):
639
- """Tests copying a wildcard-specified bucket subdir to a directory"""
640
- src_bucket_uri = self.CreateBucket(
641
- test_objects=['src_sub0dir/foo', 'src_sub1dir/foo', 'src_sub2dir/foo',
642
- 'src_sub3dir/foo'])
643
- dst_dir = self.CreateTempDir()
644
- # Test with and without final slash on dest subdir.
645
- for i, (final_src_char, final_dst_char) in enumerate((
646
- ('', ''), ('', '/'), ('/', ''), ('/', '/') )):
647
- self.RunCommand(
648
- 'cp', ['-R', suri(src_bucket_uri, 'src_sub%d*' % i) + final_src_char,
649
- dst_dir + final_dst_char])
650
- actual = set(str(u) for u in self._test_wildcard_iterator(
651
- os.path.join(dst_dir, 'src_sub%ddir' % i, '**')).IterUris())
652
- expected = set([suri(dst_dir, 'src_sub%ddir' % i, 'foo')])
653
- self.assertEqual(expected, actual)
654
-
655
- def testCopyingBucketSubDirToDirFailsWithoutMinusR(self):
656
- """Tests for failure when attempting bucket subdir copy without -R"""
657
- src_bucket_uri = self.CreateBucket(test_objects=['src_subdir/obj'])
658
- dst_dir = self.CreateTempDir()
659
- try:
660
- self.RunCommand(
661
- 'cp', [suri(src_bucket_uri, 'src_subdir'), dst_dir])
662
- self.fail('Did not get expected CommandException')
663
- except CommandException, e:
664
- self.assertIn('does not exist', e.reason)
665
-
666
- def testCopyingBucketSubDirToBucketSubDir(self):
667
- """Tests copying a bucket subdir to another bucket subdir"""
668
- src_bucket_uri = self.CreateBucket(
669
- test_objects=['src_subdir_%d/obj' % i for i in range(4)])
670
- dst_bucket_uri = self.CreateBucket(
671
- test_objects=['dst_subdir_%d/obj2' % i for i in range(4)])
672
- # Test with and without final slash on dest subdir.
673
- for i, (final_src_char, final_dst_char) in enumerate((
674
- ('', ''), ('', '/'), ('/', ''), ('/', '/') )):
675
- self.RunCommand(
676
- 'cp', ['-R', suri(src_bucket_uri, 'src_subdir_%d' % i) + final_src_char,
677
- suri(dst_bucket_uri, 'dst_subdir_%d' % i) + final_dst_char])
678
- actual = set(str(u) for u in self._test_wildcard_iterator(
679
- suri(dst_bucket_uri, 'dst_subdir_%d' % i, '**')).IterUris())
680
- expected = set([suri(dst_bucket_uri, 'dst_subdir_%d' % i,
681
- 'src_subdir_%d' % i, 'obj'),
682
- suri(dst_bucket_uri, 'dst_subdir_%d' % i, 'obj2')])
683
- self.assertEqual(expected, actual)
684
-
685
- def testCopyingBucketSubDirToBucketSubDirWithNested(self):
686
- """Tests copying a bucket subdir to another bucket subdir with nesting."""
687
- src_bucket_uri = self.CreateBucket(
688
- test_objects=['src_subdir_%d/obj' % i for i in range(4)] +
689
- ['src_subdir_%d/nested/obj' % i for i in range(4)])
690
- dst_bucket_uri = self.CreateBucket(
691
- test_objects=['dst_subdir_%d/obj2' % i for i in range(4)])
692
- # Test with and without final slash on dest subdir.
693
- for i, (final_src_char, final_dst_char) in enumerate((
694
- ('', ''), ('', '/'), ('/', ''), ('/', '/') )):
695
- self.RunCommand(
696
- 'cp', ['-R', suri(src_bucket_uri, 'src_subdir_%d' % i) + final_src_char,
697
- suri(dst_bucket_uri, 'dst_subdir_%d' % i) + final_dst_char])
698
- actual = set(str(u) for u in self._test_wildcard_iterator(
699
- suri(dst_bucket_uri, 'dst_subdir_%d' % i, '**')).IterUris())
700
- expected = set([suri(dst_bucket_uri, 'dst_subdir_%d' % i,
701
- 'src_subdir_%d' % i, 'obj'),
702
- suri(dst_bucket_uri, 'dst_subdir_%d' % i,
703
- 'src_subdir_%d' % i, 'nested', 'obj'),
704
- suri(dst_bucket_uri, 'dst_subdir_%d' % i, 'obj2')])
705
- self.assertEqual(expected, actual)
706
-
707
- def testMovingBucketSubDirToExistingBucketSubDir(self):
708
- """Tests moving a bucket subdir to a existing bucket subdir"""
709
- src_objs = ['foo']
710
- for i in range(4):
711
- src_objs.extend(['src_subdir%d/foo2' % i, 'src_subdir%d/nested/foo3' % i])
712
- src_bucket_uri = self.CreateBucket(test_objects=src_objs)
713
- dst_bucket_uri = self.CreateBucket(
714
- test_objects=['dst_subdir%d/existing' % i for i in range(4)])
715
- # Test with and without final slash on dest subdir.
716
- for i, (final_src_char, final_dst_char) in enumerate((
717
- ('', ''), ('', '/'), ('/', ''), ('/', '/') )):
718
- self.RunCommand(
719
- 'mv', [suri(src_bucket_uri, 'src_subdir%d' % i) + final_src_char,
720
- suri(dst_bucket_uri, 'dst_subdir%d' % i) + final_dst_char])
721
-
722
- actual = set(str(u) for u in self._test_wildcard_iterator(
723
- suri(dst_bucket_uri, '**')).IterUris())
724
- expected = set()
725
- for i in range(4):
726
- expected.add(suri(dst_bucket_uri, 'dst_subdir%d' % i, 'existing'))
727
- expected.add(suri(dst_bucket_uri, 'dst_subdir%d' % i, 'src_subdir%d' %i,
728
- 'foo2'))
729
- expected.add(suri(dst_bucket_uri, 'dst_subdir%d' % i, 'src_subdir%d' %i,
730
- 'nested', 'foo3'))
731
- self.assertEqual(expected, actual)
732
-
733
- def testCopyingObjectToBucketSubDir(self):
734
- """Tests copying an object to a bucket subdir"""
735
- src_bucket_uri = self.CreateBucket(test_objects=['obj0'])
736
- dst_bucket_uri = self.CreateBucket(test_objects=['dir0/existing',
737
- 'dir1/existing'])
738
- # Test with and without final slash on dest subdir.
739
- for i, final_dst_char in enumerate(('', '/')):
740
- self.RunCommand('cp', [
741
- suri(src_bucket_uri, 'obj0'),
742
- suri(dst_bucket_uri, 'dir%d' % i) + final_dst_char])
743
- actual = set(str(u) for u in self._test_wildcard_iterator(
744
- suri(dst_bucket_uri, 'dir%d' % i, '**')).IterUris())
745
- expected = set([suri(dst_bucket_uri, 'dir%d' % i, 'obj0'),
746
- suri(dst_bucket_uri, 'dir%d' % i, 'existing')])
747
- self.assertEqual(expected, actual)
748
-
749
- def testCopyingWildcardedFilesToBucketSubDir(self):
750
- """Tests copying wildcarded files to a bucket subdir"""
751
- dst_bucket_uri = self.CreateBucket(test_objects=['subdir0/existing',
752
- 'subdir1/existing'])
753
- src_dir = self.CreateTempDir(test_files=['f0', 'f1', 'f2'])
754
- # Test with and without final slash on dest subdir.
755
- for i, final_dst_char in enumerate(('', '/')):
756
- self.RunCommand(
757
- 'cp', [os.path.join(src_dir, 'f?'),
758
- suri(dst_bucket_uri, 'subdir%d' % i) + final_dst_char])
759
- actual = set(str(u) for u in self._test_wildcard_iterator(
760
- suri(dst_bucket_uri, 'subdir%d' % i, '**')).IterUris())
761
- expected = set([suri(dst_bucket_uri, 'subdir%d' % i, 'existing'),
762
- suri(dst_bucket_uri, 'subdir%d' % i, 'f0'),
763
- suri(dst_bucket_uri, 'subdir%d' % i, 'f1'),
764
- suri(dst_bucket_uri, 'subdir%d' % i, 'f2')])
765
- self.assertEqual(expected, actual)
766
-
767
- def testCopyingOneNestedFileToBucketSubDir(self):
768
- """Tests copying one nested file to a bucket subdir"""
769
- dst_bucket_uri = self.CreateBucket(test_objects=['d0/placeholder',
770
- 'd1/placeholder'])
771
- src_dir = self.CreateTempDir(test_files=[('d3', 'd4', 'nested', 'f1')])
772
- # Test with and without final slash on dest subdir.
773
- for i, final_dst_char in enumerate(('', '/')):
774
- self.RunCommand('cp', ['-r', suri(src_dir, 'd3'),
775
- suri(dst_bucket_uri, 'd%d' % i) + final_dst_char])
776
- actual = set(str(u) for u in self._test_wildcard_iterator(
777
- suri(dst_bucket_uri, '**')).IterUris())
778
- expected = set([
779
- suri(dst_bucket_uri, 'd0', 'placeholder'),
780
- suri(dst_bucket_uri, 'd1', 'placeholder'),
781
- suri(dst_bucket_uri, 'd0', 'd3', 'd4', 'nested', 'f1'),
782
- suri(dst_bucket_uri, 'd1', 'd3', 'd4', 'nested', 'f1')])
783
- self.assertEqual(expected, actual)
784
-
785
- def testMovingWildcardedFilesToNonExistentBucketSubDir(self):
786
- """Tests moving files to a non-existent bucket subdir"""
787
- # This tests for how we allow users to do something like:
788
- # gsutil cp *.txt gs://bucket/dir
789
- # where *.txt matches more than 1 file and gs://bucket/dir
790
- # doesn't exist as a subdir.
791
- #
792
- src_bucket_uri = self.CreateBucket(test_objects=[
793
- 'f0f0', 'f0f1', 'f1f0', 'f1f1'])
794
- dst_bucket_uri = self.CreateBucket(test_objects=[
795
- 'dst_subdir0/existing_obj', 'dst_subdir1/existing_obj'])
796
- # Test with and without final slash on dest subdir.
797
- for i, final_dst_char in enumerate(('', '/')):
798
- # Copy some files into place in dst bucket.
799
- self.RunCommand(
800
- 'cp', [suri(src_bucket_uri, 'f%df?' % i),
801
- suri(dst_bucket_uri, 'dst_subdir%d' % i) + final_dst_char])
802
- # Now do the move test.
803
- self.RunCommand(
804
- 'mv', [suri(src_bucket_uri, 'f%d*' % i),
805
- suri(dst_bucket_uri, 'nonexisting%d' % i) + final_dst_char])
806
-
807
- actual = set(str(u) for u in self._test_wildcard_iterator(
808
- suri(dst_bucket_uri, '**')).IterUris())
809
- expected = set([
810
- suri(dst_bucket_uri, 'dst_subdir0', 'existing_obj'),
811
- suri(dst_bucket_uri, 'dst_subdir0', 'f0f0'),
812
- suri(dst_bucket_uri, 'dst_subdir0', 'f0f1'),
813
- suri(dst_bucket_uri, 'nonexisting0', 'f0f0'),
814
- suri(dst_bucket_uri, 'nonexisting0', 'f0f1'),
815
- suri(dst_bucket_uri, 'dst_subdir1', 'existing_obj'),
816
- suri(dst_bucket_uri, 'dst_subdir1', 'f1f0'),
817
- suri(dst_bucket_uri, 'dst_subdir1', 'f1f1'),
818
- suri(dst_bucket_uri, 'nonexisting1', 'f1f0'),
819
- suri(dst_bucket_uri, 'nonexisting1', 'f1f1')])
820
- self.assertEqual(expected, actual)
821
-
822
- def testMovingObjectToBucketSubDir(self):
823
- """Tests moving an object to a bucket subdir"""
824
- src_bucket_uri = self.CreateBucket(test_objects=['obj0', 'obj1'])
825
- dst_bucket_uri = self.CreateBucket(test_objects=[
826
- 'dst_subdir0/existing_obj', 'dst_subdir1/existing_obj'])
827
- # Test with and without final slash on dest subdir.
828
- for i, final_dst_char in enumerate(('', '/')):
829
- self.RunCommand(
830
- 'mv', [suri(src_bucket_uri, 'obj%d' % i),
831
- suri(dst_bucket_uri, 'dst_subdir%d' % i) + final_dst_char])
832
-
833
- actual = set(str(u) for u in self._test_wildcard_iterator(
834
- suri(dst_bucket_uri, '**')).IterUris())
835
- expected = set([
836
- suri(dst_bucket_uri, 'dst_subdir0', 'existing_obj'),
837
- suri(dst_bucket_uri, 'dst_subdir0', 'obj0'),
838
- suri(dst_bucket_uri, 'dst_subdir1', 'existing_obj'),
839
- suri(dst_bucket_uri, 'dst_subdir1', 'obj1')])
840
- self.assertEqual(expected, actual)
841
-
842
- actual = set(str(u) for u in self._test_wildcard_iterator(
843
- suri(src_bucket_uri, '**')).IterUris())
844
- self.assertEqual(actual, set())
845
-
846
- def testWildcardSrcSubDirMoveDisallowed(self):
847
- """Tests moving a bucket subdir specified by wildcard is disallowed"""
848
- src_bucket_uri = self.CreateBucket(test_objects=['dir/foo1'])
849
- dst_bucket_uri = self.CreateBucket(test_objects=['dir/foo2'])
850
- try:
851
- self.RunCommand(
852
- 'mv', [suri(src_bucket_uri, 'dir*'), suri(dst_bucket_uri, 'dir')])
853
- self.fail('Did not get expected CommandException')
854
- except CommandException, e:
855
- self.assertIn('mv command disallows naming', e.reason)
856
-
857
- def testMovingBucketSubDirToNonExistentBucketSubDir(self):
858
- """Tests moving a bucket subdir to a non-existent bucket subdir"""
859
- src_bucket = self.CreateBucket(test_objects=[
860
- 'foo', 'src_subdir0/foo2', 'src_subdir0/nested/foo3',
861
- 'src_subdir1/foo2', 'src_subdir1/nested/foo3'])
862
- dst_bucket = self.CreateBucket()
863
- # Test with and without final slash on dest subdir.
864
- for i, final_src_char in enumerate(('', '/')):
865
- self.RunCommand(
866
- 'mv', [suri(src_bucket, 'src_subdir%d' % i) + final_src_char,
867
- suri(dst_bucket, 'dst_subdir%d' % i)])
868
-
869
- actual = set(str(u) for u in self._test_wildcard_iterator(
870
- suri(dst_bucket, '**')).IterUris())
871
- # Unlike the case with copying, with mv we expect renaming to occur
872
- # at the level of the src subdir, vs appending that subdir beneath the
873
- # dst subdir like is done for copying.
874
- expected = set([suri(dst_bucket, 'dst_subdir0', 'foo2'),
875
- suri(dst_bucket, 'dst_subdir1', 'foo2'),
876
- suri(dst_bucket, 'dst_subdir0', 'nested', 'foo3'),
877
- suri(dst_bucket, 'dst_subdir1', 'nested', 'foo3')])
878
- self.assertEqual(expected, actual)
879
-
880
- def testRemovingBucketSubDir(self):
881
- """Tests removing a bucket subdir"""
882
- dst_bucket_uri = self.CreateBucket(test_objects=[
883
- 'f0', 'dir0/f1', 'dir0/nested/f2', 'dir1/f1', 'dir1/nested/f2'])
884
- # Test with and without final slash on dest subdir.
885
- for i, final_src_char in enumerate(('', '/')):
886
- # Test removing bucket subdir.
887
- self.RunCommand(
888
- 'rm', ['-R', suri(dst_bucket_uri, 'dir%d' % i) + final_src_char])
889
- actual = set(str(u) for u in self._test_wildcard_iterator(
890
- suri(dst_bucket_uri, '**')).IterUris())
891
- expected = set([suri(dst_bucket_uri, 'f0')])
892
- self.assertEqual(expected, actual)
893
-
894
- def testRecursiveRemoveObjsInBucket(self):
895
- """Tests removing all objects in bucket via rm -R gs://bucket"""
896
- bucket_uris = [
897
- self.CreateBucket(test_objects=['f0', 'dir/f1', 'dir/nested/f2']),
898
- self.CreateBucket(test_objects=['f0', 'dir/f1', 'dir/nested/f2'])]
899
- # Test with and without final slash on dest subdir.
900
- for i, final_src_char in enumerate(('', '/')):
901
- # Test removing all objects via rm -R.
902
- self.RunCommand('rm', ['-R', suri(bucket_uris[i]) + final_src_char])
903
- actual = set(str(u) for u in self._test_wildcard_iterator(
904
- suri(bucket_uris[i], '**')).IterUris())
905
- self.assertEqual(actual, set())
906
-
907
- def FinalObjNameComponent(self, uri):
908
- """For gs://bucket/abc/def/ghi returns ghi."""
909
- return uri.uri.rpartition('/')[-1]
910
-
911
-
912
- # TODO: These should all be moved to their own test_*.py testing files.
913
- class GsUtilCommandTests(testcase.GsUtilUnitTestCase):
914
- """Basic sanity check tests to make sure commands run."""
915
-
916
- def testDisableLoggingCommandRuns(self):
917
- """Test that the disablelogging command basically runs"""
918
- src_bucket_uri = self.CreateBucket()
919
- self.RunCommand('disablelogging', [suri(src_bucket_uri)])
920
-
921
- def testEnableLoggingCommandRuns(self):
922
- """Test that the enablelogging command basically runs"""
923
- src_bucket_uri = self.CreateBucket()
924
- self.RunCommand('enablelogging', ['-b', 'gs://log_bucket',
925
- suri(src_bucket_uri)])
926
-
927
- def testHelpCommandDoesntRaise(self):
928
- """Test that the help command doesn't raise (sanity checks all help)"""
929
- # Unset PAGER if defined, so help output paginating into $PAGER doesn't
930
- # cause test to pause.
931
- if 'PAGER' in os.environ:
932
- del os.environ['PAGER']
933
- self.RunCommand('help', [])
934
-
935
- def testCatCommandRuns(self):
936
- """Test that the cat command basically runs"""
937
- src_uri = self.CreateObject(contents='foo')
938
- stdout = self.RunCommand('cat', [suri(src_uri)], return_stdout=True)
939
- self.assertEqual(stdout, 'foo')
940
-
941
- def testGetAclCommandRuns(self):
942
- """Test that the getacl command basically runs"""
943
- src_bucket_uri = self.CreateBucket()
944
- self.RunCommand('getacl', [suri(src_bucket_uri)])
945
-
946
- def testGetDefAclCommandRuns(self):
947
- """Test that the getdefacl command basically runs"""
948
- src_bucket_uri = self.CreateBucket()
949
- self.RunCommand('getacl', [suri(src_bucket_uri)])
950
-
951
- def testGetLoggingCommandRuns(self):
952
- """Test that the getlogging command basically runs"""
953
- src_bucket_uri = self.CreateBucket()
954
- self.RunCommand('getlogging', [suri(src_bucket_uri)])
955
-
956
- def testMakeBucketsCommand(self):
957
- """Test mb on existing bucket"""
958
- dst_bucket_uri = self.CreateBucket()
959
- try:
960
- self.RunCommand('mb', [suri(dst_bucket_uri)])
961
- self.fail('Did not get expected StorageCreateError')
962
- except boto.exception.StorageCreateError, e:
963
- self.assertEqual(e.status, 409)
964
-
965
- def testRemoveBucketsCommand(self):
966
- """Test rb on non-existent bucket"""
967
- dst_bucket_uri = self.CreateBucket()
968
- try:
969
- self.RunCommand(
970
- 'rb', ['gs://non_existent_%s' % dst_bucket_uri.bucket_name])
971
- self.fail('Did not get expected StorageResponseError')
972
- except boto.exception.StorageResponseError, e:
973
- self.assertEqual(e.status, 404)
974
-
975
- def testRemoveObjsCommand(self):
976
- """Test rm command on non-existent object"""
977
- dst_bucket_uri = self.CreateBucket()
978
- try:
979
- self.RunCommand('rm', [suri(dst_bucket_uri, 'non_existent')])
980
- self.fail('Did not get expected WildcardException')
981
- except StorageResponseError, e:
982
- self.assertIn('Not Found', e.reason)
983
-
984
- # Now that gsutil ver computes a checksum it adds 1-3 seconds to test run
985
- # time (for in memory mocked tests that otherwise take ~ 0.1 seconds). Since
986
- # it provides very little test value, we're leaving this test commented out.
987
- #def testVerCommmandRuns(self):
988
- # """Test that the Ver command basically runs"""
989
- # self.RunCommand('ver', [])