backup_checksum 3.0.23

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of backup_checksum might be problematic. Click here for more details.

Files changed (244) hide show
  1. data/.gitignore +7 -0
  2. data/.travis.yml +10 -0
  3. data/Gemfile +28 -0
  4. data/Gemfile.lock +130 -0
  5. data/Guardfile +21 -0
  6. data/LICENSE.md +24 -0
  7. data/README.md +476 -0
  8. data/backup_checksum.gemspec +32 -0
  9. data/bin/backup +11 -0
  10. data/lib/backup.rb +217 -0
  11. data/lib/backup/archive.rb +117 -0
  12. data/lib/backup/binder.rb +22 -0
  13. data/lib/backup/checksum/base.rb +44 -0
  14. data/lib/backup/checksum/shasum.rb +16 -0
  15. data/lib/backup/cleaner.rb +121 -0
  16. data/lib/backup/cli/helpers.rb +88 -0
  17. data/lib/backup/cli/utility.rb +247 -0
  18. data/lib/backup/compressor/base.rb +29 -0
  19. data/lib/backup/compressor/bzip2.rb +50 -0
  20. data/lib/backup/compressor/gzip.rb +47 -0
  21. data/lib/backup/compressor/lzma.rb +50 -0
  22. data/lib/backup/compressor/pbzip2.rb +56 -0
  23. data/lib/backup/config.rb +173 -0
  24. data/lib/backup/configuration/base.rb +15 -0
  25. data/lib/backup/configuration/checksum/base.rb +9 -0
  26. data/lib/backup/configuration/checksum/shasum.rb +9 -0
  27. data/lib/backup/configuration/compressor/base.rb +9 -0
  28. data/lib/backup/configuration/compressor/bzip2.rb +23 -0
  29. data/lib/backup/configuration/compressor/gzip.rb +23 -0
  30. data/lib/backup/configuration/compressor/lzma.rb +23 -0
  31. data/lib/backup/configuration/compressor/pbzip2.rb +28 -0
  32. data/lib/backup/configuration/database/base.rb +19 -0
  33. data/lib/backup/configuration/database/mongodb.rb +49 -0
  34. data/lib/backup/configuration/database/mysql.rb +42 -0
  35. data/lib/backup/configuration/database/postgresql.rb +41 -0
  36. data/lib/backup/configuration/database/redis.rb +39 -0
  37. data/lib/backup/configuration/database/riak.rb +29 -0
  38. data/lib/backup/configuration/encryptor/base.rb +9 -0
  39. data/lib/backup/configuration/encryptor/gpg.rb +17 -0
  40. data/lib/backup/configuration/encryptor/open_ssl.rb +32 -0
  41. data/lib/backup/configuration/helpers.rb +52 -0
  42. data/lib/backup/configuration/notifier/base.rb +28 -0
  43. data/lib/backup/configuration/notifier/campfire.rb +25 -0
  44. data/lib/backup/configuration/notifier/hipchat.rb +41 -0
  45. data/lib/backup/configuration/notifier/mail.rb +112 -0
  46. data/lib/backup/configuration/notifier/presently.rb +25 -0
  47. data/lib/backup/configuration/notifier/prowl.rb +23 -0
  48. data/lib/backup/configuration/notifier/twitter.rb +21 -0
  49. data/lib/backup/configuration/storage/base.rb +18 -0
  50. data/lib/backup/configuration/storage/cloudfiles.rb +25 -0
  51. data/lib/backup/configuration/storage/dropbox.rb +58 -0
  52. data/lib/backup/configuration/storage/ftp.rb +29 -0
  53. data/lib/backup/configuration/storage/local.rb +17 -0
  54. data/lib/backup/configuration/storage/ninefold.rb +20 -0
  55. data/lib/backup/configuration/storage/rsync.rb +29 -0
  56. data/lib/backup/configuration/storage/s3.rb +25 -0
  57. data/lib/backup/configuration/storage/scp.rb +25 -0
  58. data/lib/backup/configuration/storage/sftp.rb +25 -0
  59. data/lib/backup/configuration/syncer/base.rb +10 -0
  60. data/lib/backup/configuration/syncer/cloud.rb +23 -0
  61. data/lib/backup/configuration/syncer/cloud_files.rb +30 -0
  62. data/lib/backup/configuration/syncer/rsync/base.rb +28 -0
  63. data/lib/backup/configuration/syncer/rsync/local.rb +11 -0
  64. data/lib/backup/configuration/syncer/rsync/pull.rb +11 -0
  65. data/lib/backup/configuration/syncer/rsync/push.rb +31 -0
  66. data/lib/backup/configuration/syncer/s3.rb +23 -0
  67. data/lib/backup/database/base.rb +59 -0
  68. data/lib/backup/database/mongodb.rb +232 -0
  69. data/lib/backup/database/mysql.rb +163 -0
  70. data/lib/backup/database/postgresql.rb +146 -0
  71. data/lib/backup/database/redis.rb +139 -0
  72. data/lib/backup/database/riak.rb +69 -0
  73. data/lib/backup/dependency.rb +114 -0
  74. data/lib/backup/encryptor/base.rb +29 -0
  75. data/lib/backup/encryptor/gpg.rb +80 -0
  76. data/lib/backup/encryptor/open_ssl.rb +72 -0
  77. data/lib/backup/errors.rb +124 -0
  78. data/lib/backup/logger.rb +152 -0
  79. data/lib/backup/model.rb +386 -0
  80. data/lib/backup/notifier/base.rb +81 -0
  81. data/lib/backup/notifier/campfire.rb +168 -0
  82. data/lib/backup/notifier/hipchat.rb +99 -0
  83. data/lib/backup/notifier/mail.rb +206 -0
  84. data/lib/backup/notifier/presently.rb +88 -0
  85. data/lib/backup/notifier/prowl.rb +65 -0
  86. data/lib/backup/notifier/twitter.rb +70 -0
  87. data/lib/backup/package.rb +51 -0
  88. data/lib/backup/packager.rb +108 -0
  89. data/lib/backup/pipeline.rb +107 -0
  90. data/lib/backup/splitter.rb +75 -0
  91. data/lib/backup/storage/base.rb +119 -0
  92. data/lib/backup/storage/cloudfiles.rb +87 -0
  93. data/lib/backup/storage/cycler.rb +117 -0
  94. data/lib/backup/storage/dropbox.rb +181 -0
  95. data/lib/backup/storage/ftp.rb +119 -0
  96. data/lib/backup/storage/local.rb +82 -0
  97. data/lib/backup/storage/ninefold.rb +116 -0
  98. data/lib/backup/storage/rsync.rb +149 -0
  99. data/lib/backup/storage/s3.rb +94 -0
  100. data/lib/backup/storage/scp.rb +99 -0
  101. data/lib/backup/storage/sftp.rb +108 -0
  102. data/lib/backup/syncer/base.rb +42 -0
  103. data/lib/backup/syncer/cloud.rb +190 -0
  104. data/lib/backup/syncer/cloud_files.rb +56 -0
  105. data/lib/backup/syncer/rsync/base.rb +52 -0
  106. data/lib/backup/syncer/rsync/local.rb +53 -0
  107. data/lib/backup/syncer/rsync/pull.rb +38 -0
  108. data/lib/backup/syncer/rsync/push.rb +113 -0
  109. data/lib/backup/syncer/s3.rb +47 -0
  110. data/lib/backup/template.rb +46 -0
  111. data/lib/backup/version.rb +43 -0
  112. data/spec/archive_spec.rb +335 -0
  113. data/spec/cleaner_spec.rb +304 -0
  114. data/spec/cli/helpers_spec.rb +176 -0
  115. data/spec/cli/utility_spec.rb +363 -0
  116. data/spec/compressor/base_spec.rb +31 -0
  117. data/spec/compressor/bzip2_spec.rb +83 -0
  118. data/spec/compressor/gzip_spec.rb +83 -0
  119. data/spec/compressor/lzma_spec.rb +83 -0
  120. data/spec/compressor/pbzip2_spec.rb +124 -0
  121. data/spec/config_spec.rb +321 -0
  122. data/spec/configuration/base_spec.rb +35 -0
  123. data/spec/configuration/compressor/bzip2_spec.rb +29 -0
  124. data/spec/configuration/compressor/gzip_spec.rb +29 -0
  125. data/spec/configuration/compressor/lzma_spec.rb +29 -0
  126. data/spec/configuration/compressor/pbzip2_spec.rb +32 -0
  127. data/spec/configuration/database/base_spec.rb +17 -0
  128. data/spec/configuration/database/mongodb_spec.rb +56 -0
  129. data/spec/configuration/database/mysql_spec.rb +53 -0
  130. data/spec/configuration/database/postgresql_spec.rb +53 -0
  131. data/spec/configuration/database/redis_spec.rb +50 -0
  132. data/spec/configuration/database/riak_spec.rb +35 -0
  133. data/spec/configuration/encryptor/gpg_spec.rb +26 -0
  134. data/spec/configuration/encryptor/open_ssl_spec.rb +35 -0
  135. data/spec/configuration/notifier/base_spec.rb +32 -0
  136. data/spec/configuration/notifier/campfire_spec.rb +32 -0
  137. data/spec/configuration/notifier/hipchat_spec.rb +44 -0
  138. data/spec/configuration/notifier/mail_spec.rb +71 -0
  139. data/spec/configuration/notifier/presently_spec.rb +35 -0
  140. data/spec/configuration/notifier/prowl_spec.rb +29 -0
  141. data/spec/configuration/notifier/twitter_spec.rb +35 -0
  142. data/spec/configuration/storage/cloudfiles_spec.rb +41 -0
  143. data/spec/configuration/storage/dropbox_spec.rb +38 -0
  144. data/spec/configuration/storage/ftp_spec.rb +44 -0
  145. data/spec/configuration/storage/local_spec.rb +29 -0
  146. data/spec/configuration/storage/ninefold_spec.rb +32 -0
  147. data/spec/configuration/storage/rsync_spec.rb +41 -0
  148. data/spec/configuration/storage/s3_spec.rb +38 -0
  149. data/spec/configuration/storage/scp_spec.rb +41 -0
  150. data/spec/configuration/storage/sftp_spec.rb +41 -0
  151. data/spec/configuration/syncer/cloud_files_spec.rb +44 -0
  152. data/spec/configuration/syncer/rsync/base_spec.rb +33 -0
  153. data/spec/configuration/syncer/rsync/local_spec.rb +10 -0
  154. data/spec/configuration/syncer/rsync/pull_spec.rb +10 -0
  155. data/spec/configuration/syncer/rsync/push_spec.rb +43 -0
  156. data/spec/configuration/syncer/s3_spec.rb +38 -0
  157. data/spec/database/base_spec.rb +54 -0
  158. data/spec/database/mongodb_spec.rb +428 -0
  159. data/spec/database/mysql_spec.rb +335 -0
  160. data/spec/database/postgresql_spec.rb +278 -0
  161. data/spec/database/redis_spec.rb +260 -0
  162. data/spec/database/riak_spec.rb +108 -0
  163. data/spec/dependency_spec.rb +49 -0
  164. data/spec/encryptor/base_spec.rb +30 -0
  165. data/spec/encryptor/gpg_spec.rb +134 -0
  166. data/spec/encryptor/open_ssl_spec.rb +129 -0
  167. data/spec/errors_spec.rb +306 -0
  168. data/spec/logger_spec.rb +363 -0
  169. data/spec/model_spec.rb +649 -0
  170. data/spec/notifier/base_spec.rb +89 -0
  171. data/spec/notifier/campfire_spec.rb +199 -0
  172. data/spec/notifier/hipchat_spec.rb +188 -0
  173. data/spec/notifier/mail_spec.rb +280 -0
  174. data/spec/notifier/presently_spec.rb +181 -0
  175. data/spec/notifier/prowl_spec.rb +117 -0
  176. data/spec/notifier/twitter_spec.rb +132 -0
  177. data/spec/package_spec.rb +61 -0
  178. data/spec/packager_spec.rb +225 -0
  179. data/spec/pipeline_spec.rb +257 -0
  180. data/spec/spec_helper.rb +59 -0
  181. data/spec/splitter_spec.rb +120 -0
  182. data/spec/storage/base_spec.rb +160 -0
  183. data/spec/storage/cloudfiles_spec.rb +230 -0
  184. data/spec/storage/cycler_spec.rb +239 -0
  185. data/spec/storage/dropbox_spec.rb +370 -0
  186. data/spec/storage/ftp_spec.rb +247 -0
  187. data/spec/storage/local_spec.rb +235 -0
  188. data/spec/storage/ninefold_spec.rb +319 -0
  189. data/spec/storage/rsync_spec.rb +345 -0
  190. data/spec/storage/s3_spec.rb +221 -0
  191. data/spec/storage/scp_spec.rb +209 -0
  192. data/spec/storage/sftp_spec.rb +220 -0
  193. data/spec/syncer/base_spec.rb +22 -0
  194. data/spec/syncer/cloud_files_spec.rb +192 -0
  195. data/spec/syncer/rsync/base_spec.rb +118 -0
  196. data/spec/syncer/rsync/local_spec.rb +121 -0
  197. data/spec/syncer/rsync/pull_spec.rb +90 -0
  198. data/spec/syncer/rsync/push_spec.rb +327 -0
  199. data/spec/syncer/s3_spec.rb +192 -0
  200. data/spec/version_spec.rb +21 -0
  201. data/templates/cli/utility/archive +25 -0
  202. data/templates/cli/utility/compressor/bzip2 +7 -0
  203. data/templates/cli/utility/compressor/gzip +7 -0
  204. data/templates/cli/utility/compressor/lzma +7 -0
  205. data/templates/cli/utility/compressor/pbzip2 +7 -0
  206. data/templates/cli/utility/config +31 -0
  207. data/templates/cli/utility/database/mongodb +18 -0
  208. data/templates/cli/utility/database/mysql +21 -0
  209. data/templates/cli/utility/database/postgresql +17 -0
  210. data/templates/cli/utility/database/redis +16 -0
  211. data/templates/cli/utility/database/riak +11 -0
  212. data/templates/cli/utility/encryptor/gpg +12 -0
  213. data/templates/cli/utility/encryptor/openssl +9 -0
  214. data/templates/cli/utility/model.erb +23 -0
  215. data/templates/cli/utility/notifier/campfire +12 -0
  216. data/templates/cli/utility/notifier/hipchat +15 -0
  217. data/templates/cli/utility/notifier/mail +22 -0
  218. data/templates/cli/utility/notifier/presently +13 -0
  219. data/templates/cli/utility/notifier/prowl +11 -0
  220. data/templates/cli/utility/notifier/twitter +13 -0
  221. data/templates/cli/utility/splitter +7 -0
  222. data/templates/cli/utility/storage/cloud_files +22 -0
  223. data/templates/cli/utility/storage/dropbox +20 -0
  224. data/templates/cli/utility/storage/ftp +12 -0
  225. data/templates/cli/utility/storage/local +7 -0
  226. data/templates/cli/utility/storage/ninefold +9 -0
  227. data/templates/cli/utility/storage/rsync +11 -0
  228. data/templates/cli/utility/storage/s3 +19 -0
  229. data/templates/cli/utility/storage/scp +11 -0
  230. data/templates/cli/utility/storage/sftp +11 -0
  231. data/templates/cli/utility/syncer/cloud_files +48 -0
  232. data/templates/cli/utility/syncer/rsync_local +12 -0
  233. data/templates/cli/utility/syncer/rsync_pull +17 -0
  234. data/templates/cli/utility/syncer/rsync_push +17 -0
  235. data/templates/cli/utility/syncer/s3 +45 -0
  236. data/templates/general/links +11 -0
  237. data/templates/general/version.erb +2 -0
  238. data/templates/notifier/mail/failure.erb +9 -0
  239. data/templates/notifier/mail/success.erb +7 -0
  240. data/templates/notifier/mail/warning.erb +9 -0
  241. data/templates/storage/dropbox/authorization_url.erb +6 -0
  242. data/templates/storage/dropbox/authorized.erb +4 -0
  243. data/templates/storage/dropbox/cache_file_written.erb +10 -0
  244. metadata +311 -0
@@ -0,0 +1,230 @@
1
+ # encoding: utf-8
2
+
3
+ require File.expand_path('../../spec_helper.rb', __FILE__)
4
+
5
+ describe Backup::Storage::CloudFiles do
6
+ let(:model) { Backup::Model.new(:test_trigger, 'test label') }
7
+ let(:storage) do
8
+ Backup::Storage::CloudFiles.new(model) do |cf|
9
+ cf.username = 'my_username'
10
+ cf.api_key = 'my_api_key'
11
+ cf.auth_url = 'lon.auth.api.rackspacecloud.com'
12
+ cf.container = 'my_container'
13
+ cf.keep = 5
14
+ end
15
+ end
16
+
17
+ describe '#initialize' do
18
+ it 'should set the correct values' do
19
+ storage.username.should == 'my_username'
20
+ storage.api_key.should == 'my_api_key'
21
+ storage.auth_url.should == 'lon.auth.api.rackspacecloud.com'
22
+ storage.container.should == 'my_container'
23
+ storage.servicenet.should == false
24
+ storage.path.should == 'backups'
25
+
26
+ storage.storage_id.should be_nil
27
+ storage.keep.should == 5
28
+ end
29
+
30
+ it 'should set a storage_id if given' do
31
+ cf = Backup::Storage::CloudFiles.new(model, 'my storage_id')
32
+ cf.storage_id.should == 'my storage_id'
33
+ end
34
+
35
+ context 'when setting configuration defaults' do
36
+ after { Backup::Configuration::Storage::CloudFiles.clear_defaults! }
37
+
38
+ it 'should use the configured defaults' do
39
+ Backup::Configuration::Storage::CloudFiles.defaults do |cf|
40
+ cf.username = 'some_username'
41
+ cf.api_key = 'some_api_key'
42
+ cf.auth_url = 'some_auth_url'
43
+ cf.container = 'some_container'
44
+ cf.servicenet = true
45
+ cf.path = 'some_path'
46
+ cf.keep = 15
47
+ end
48
+ storage = Backup::Storage::CloudFiles.new(model)
49
+ storage.username.should == 'some_username'
50
+ storage.api_key.should == 'some_api_key'
51
+ storage.auth_url.should == 'some_auth_url'
52
+ storage.container.should == 'some_container'
53
+ storage.servicenet.should == true
54
+ storage.path.should == 'some_path'
55
+
56
+ storage.storage_id.should be_nil
57
+ storage.keep.should == 15
58
+ end
59
+
60
+ it 'should override the configured defaults' do
61
+ Backup::Configuration::Storage::CloudFiles.defaults do |cf|
62
+ cf.username = 'old_username'
63
+ cf.api_key = 'old_api_key'
64
+ cf.auth_url = 'old_auth_url'
65
+ cf.container = 'old_container'
66
+ cf.servicenet = true
67
+ cf.path = 'old_path'
68
+ cf.keep = 15
69
+ end
70
+ storage = Backup::Storage::CloudFiles.new(model) do |cf|
71
+ cf.username = 'new_username'
72
+ cf.api_key = 'new_api_key'
73
+ cf.auth_url = 'new_auth_url'
74
+ cf.container = 'new_container'
75
+ cf.servicenet = false
76
+ cf.path = 'new_path'
77
+ cf.keep = 10
78
+ end
79
+
80
+ storage.username.should == 'new_username'
81
+ storage.api_key.should == 'new_api_key'
82
+ storage.auth_url.should == 'new_auth_url'
83
+ storage.container.should == 'new_container'
84
+ storage.servicenet.should == false
85
+ storage.path.should == 'new_path'
86
+
87
+ storage.storage_id.should be_nil
88
+ storage.keep.should == 10
89
+ end
90
+ end # context 'when setting configuration defaults'
91
+
92
+ end # describe '#initialize'
93
+
94
+ describe '#provider' do
95
+ it 'should set the Fog provider' do
96
+ storage.send(:provider).should == 'Rackspace'
97
+ end
98
+ end
99
+
100
+ describe '#connection' do
101
+ let(:connection) { mock }
102
+
103
+ context 'when @servicenet is set to false' do
104
+ it 'should create a new standard connection' do
105
+ Fog::Storage.expects(:new).once.with(
106
+ :provider => 'Rackspace',
107
+ :rackspace_username => 'my_username',
108
+ :rackspace_api_key => 'my_api_key',
109
+ :rackspace_auth_url => 'lon.auth.api.rackspacecloud.com',
110
+ :rackspace_servicenet => false
111
+ ).returns(connection)
112
+ storage.send(:connection).should == connection
113
+ end
114
+ end
115
+
116
+ context 'when @servicenet is set to true' do
117
+ before do
118
+ storage.servicenet = true
119
+ end
120
+
121
+ it 'should create a new servicenet connection' do
122
+ Fog::Storage.expects(:new).once.with(
123
+ :provider => 'Rackspace',
124
+ :rackspace_username => 'my_username',
125
+ :rackspace_api_key => 'my_api_key',
126
+ :rackspace_auth_url => 'lon.auth.api.rackspacecloud.com',
127
+ :rackspace_servicenet => true
128
+ ).returns(connection)
129
+ storage.send(:connection).should == connection
130
+ end
131
+ end
132
+
133
+ it 'should return an existing connection' do
134
+ Fog::Storage.expects(:new).once.returns(connection)
135
+ storage.send(:connection).should == connection
136
+ storage.send(:connection).should == connection
137
+ end
138
+
139
+ end # describe '#connection'
140
+
141
+ describe '#transfer!' do
142
+ let(:connection) { mock }
143
+ let(:package) { mock }
144
+ let(:file) { mock }
145
+ let(:s) { sequence '' }
146
+
147
+ before do
148
+ storage.instance_variable_set(:@package, package)
149
+ storage.stubs(:storage_name).returns('Storage::CloudFiles')
150
+ storage.stubs(:local_path).returns('/local/path')
151
+ storage.stubs(:connection).returns(connection)
152
+ end
153
+
154
+ it 'should transfer the package files' do
155
+ storage.expects(:remote_path_for).in_sequence(s).with(package).
156
+ returns('remote/path')
157
+ storage.expects(:files_to_transfer_for).in_sequence(s).with(package).
158
+ multiple_yields(
159
+ ['2011.12.31.11.00.02.backup.tar.enc-aa', 'backup.tar.enc-aa'],
160
+ ['2011.12.31.11.00.02.backup.tar.enc-ab', 'backup.tar.enc-ab']
161
+ )
162
+ # first yield
163
+ Backup::Logger.expects(:message).in_sequence(s).with(
164
+ "Storage::CloudFiles started transferring " +
165
+ "'2011.12.31.11.00.02.backup.tar.enc-aa'."
166
+ )
167
+ File.expects(:open).in_sequence(s).with(
168
+ File.join('/local/path', '2011.12.31.11.00.02.backup.tar.enc-aa'), 'r'
169
+ ).yields(file)
170
+ connection.expects(:put_object).in_sequence(s).with(
171
+ 'my_container', File.join('remote/path', 'backup.tar.enc-aa'), file
172
+ )
173
+ # second yield
174
+ Backup::Logger.expects(:message).in_sequence(s).with(
175
+ "Storage::CloudFiles started transferring " +
176
+ "'2011.12.31.11.00.02.backup.tar.enc-ab'."
177
+ )
178
+ File.expects(:open).in_sequence(s).with(
179
+ File.join('/local/path', '2011.12.31.11.00.02.backup.tar.enc-ab'), 'r'
180
+ ).yields(file)
181
+ connection.expects(:put_object).in_sequence(s).with(
182
+ 'my_container', File.join('remote/path', 'backup.tar.enc-ab'), file
183
+ )
184
+
185
+ storage.send(:transfer!)
186
+ end
187
+ end # describe '#transfer!'
188
+
189
+ describe '#remove!' do
190
+ let(:package) { mock }
191
+ let(:connection) { mock }
192
+ let(:s) { sequence '' }
193
+
194
+ before do
195
+ storage.stubs(:storage_name).returns('Storage::CloudFiles')
196
+ storage.stubs(:connection).returns(connection)
197
+ end
198
+
199
+ it 'should remove the package files' do
200
+ storage.expects(:remote_path_for).in_sequence(s).with(package).
201
+ returns('remote/path')
202
+ storage.expects(:transferred_files_for).in_sequence(s).with(package).
203
+ multiple_yields(
204
+ ['2011.12.31.11.00.02.backup.tar.enc-aa', 'backup.tar.enc-aa'],
205
+ ['2011.12.31.11.00.02.backup.tar.enc-ab', 'backup.tar.enc-ab']
206
+ )
207
+ # first yield
208
+ Backup::Logger.expects(:message).in_sequence(s).with(
209
+ "Storage::CloudFiles started removing " +
210
+ "'2011.12.31.11.00.02.backup.tar.enc-aa' " +
211
+ "from container 'my_container'."
212
+ )
213
+ connection.expects(:delete_object).in_sequence(s).with(
214
+ 'my_container', File.join('remote/path', 'backup.tar.enc-aa')
215
+ )
216
+ # second yield
217
+ Backup::Logger.expects(:message).in_sequence(s).with(
218
+ "Storage::CloudFiles started removing " +
219
+ "'2011.12.31.11.00.02.backup.tar.enc-ab' " +
220
+ "from container 'my_container'."
221
+ )
222
+ connection.expects(:delete_object).in_sequence(s).with(
223
+ 'my_container', File.join('remote/path', 'backup.tar.enc-ab')
224
+ )
225
+
226
+ storage.send(:remove!, package)
227
+ end
228
+ end # describe '#remove!'
229
+
230
+ end
@@ -0,0 +1,239 @@
1
+ # encoding: utf-8
2
+
3
+ require File.expand_path('../../spec_helper.rb', __FILE__)
4
+
5
+ describe 'Backup::Storage::Cycler' do
6
+ let(:cycler) { Backup::Storage::Cycler }
7
+ let(:storage) { mock }
8
+ let(:package) { mock }
9
+ let(:storage_file) { mock }
10
+ let(:pkg_a) { mock }
11
+ let(:pkg_b) { mock }
12
+ let(:pkg_c) { mock }
13
+ let(:s) { sequence '' }
14
+
15
+ describe '#cycle!' do
16
+ it 'should setup variables and initiate cycling' do
17
+ cycler.expects(:storage_file).in_sequence(s).returns(storage_file)
18
+ cycler.expects(:update_storage_file!).in_sequence(s)
19
+ cycler.expects(:remove_packages!).in_sequence(s)
20
+ cycler.cycle!(storage, package)
21
+ cycler.instance_variable_get(:@storage).should be(storage)
22
+ cycler.instance_variable_get(:@package).should be(package)
23
+ cycler.instance_variable_get(:@storage_file).should be(storage_file)
24
+ end
25
+ end
26
+
27
+ describe 'update_storage_file!' do
28
+ before do
29
+ storage.stubs(:keep).returns(2)
30
+ cycler.instance_variable_set(:@storage, storage)
31
+ cycler.instance_variable_set(:@package, package)
32
+ cycler.instance_variable_set(:@storage_file, storage_file)
33
+ end
34
+
35
+ it 'should remove entries and set @packages_to_remove' do
36
+ cycler.expects(:yaml_load).in_sequence(s).returns([pkg_a, pkg_b, pkg_c])
37
+ cycler.expects(:yaml_save).in_sequence(s).with([package, pkg_a])
38
+ cycler.send(:update_storage_file!)
39
+ cycler.instance_variable_get(:@packages_to_remove).should == [pkg_b, pkg_c]
40
+ end
41
+ end
42
+
43
+ describe '#remove_packages!' do
44
+ before do
45
+ cycler.instance_variable_set(:@storage, storage)
46
+ cycler.instance_variable_set(:@packages_to_remove, [pkg_a, pkg_b, pkg_c])
47
+ end
48
+
49
+ it 'should call the @storage to remove the old packages' do
50
+ storage.expects(:remove!).in_sequence(s).with(pkg_a)
51
+ storage.expects(:remove!).in_sequence(s).with(pkg_b)
52
+ storage.expects(:remove!).in_sequence(s).with(pkg_c)
53
+ cycler.send(:remove_packages!)
54
+ end
55
+
56
+ context 'when errors occur removing packages' do
57
+ before do
58
+ pkg_b.stubs(:trigger).returns('pkg_trigger')
59
+ pkg_b.stubs(:time).returns('pkg_time')
60
+ pkg_b.stubs(:filenames).returns(['file1', 'file2'])
61
+ end
62
+
63
+ it 'should warn and continue' do
64
+ storage.expects(:remove!).in_sequence(s).with(pkg_a)
65
+ storage.expects(:remove!).in_sequence(s).with(pkg_b).raises('error message')
66
+ Backup::Logger.expects(:warn).with do |err|
67
+ err.should be_an_instance_of Backup::Errors::Storage::CyclerError
68
+ err.message.should == 'Storage::CyclerError: ' +
69
+ "There was a problem removing the following package:\n" +
70
+ " Trigger: pkg_trigger :: Dated: pkg_time\n" +
71
+ " Package included the following 2 file(s):\n" +
72
+ " file1\n" +
73
+ " file2\n" +
74
+ " Reason: RuntimeError\n" +
75
+ " error message"
76
+ end
77
+ storage.expects(:remove!).in_sequence(s).with(pkg_c)
78
+
79
+ expect do
80
+ cycler.send(:remove_packages!)
81
+ end.not_to raise_error
82
+ end
83
+ end
84
+
85
+ end # describe '#remove_packages!'
86
+
87
+ describe '#storage_file' do
88
+ before do
89
+ cycler.instance_variable_set(:@storage, storage)
90
+ storage.stubs(:class).returns('Backup::Storage::S3')
91
+ cycler.instance_variable_set(:@package, package)
92
+ package.stubs(:trigger).returns('pkg_trigger')
93
+ end
94
+
95
+ context 'when the @storage.storage_id is not set' do
96
+ before { storage.stubs(:storage_id).returns(nil) }
97
+ it 'should return the path to the YAML storage file with no suffix' do
98
+ cycler.send(:storage_file).should ==
99
+ File.join(Backup::Config.data_path, 'pkg_trigger', 'S3.yml')
100
+ end
101
+ end
102
+
103
+ context 'when the @storage.storage_id is set' do
104
+ before { storage.stubs(:storage_id).returns('Storage #1') }
105
+ it 'should sanitize the storage_id to use as a filename suffix' do
106
+ cycler.send(:storage_file).should ==
107
+ File.join(Backup::Config.data_path, 'pkg_trigger', 'S3-Storage__1.yml')
108
+ end
109
+ end
110
+
111
+ end # describe '#storage_file'
112
+
113
+ describe '#yaml_load' do
114
+ let(:obj_a) { mock }
115
+ let(:obj_b) { mock }
116
+ let(:obj_c) { mock }
117
+ let(:unsorted_objects) { [obj_a, obj_c, obj_b] }
118
+ let(:sorted_objects) { [obj_c, obj_b, obj_a] }
119
+
120
+ before do
121
+ cycler.instance_variable_set(:@storage_file, storage_file)
122
+ obj_a.instance_variable_set(:@time, '2012.01.01.07.00.00')
123
+ obj_b.instance_variable_set(:@time, '2012.01.01.08.00.00')
124
+ obj_c.instance_variable_set(:@time, '2012.01.01.09.00.00')
125
+ end
126
+
127
+ context 'when the storage file exists' do
128
+ before { File.expects(:exist?).with(storage_file).returns(true) }
129
+ context 'when the file is not empty' do
130
+ before { File.expects(:zero?).with(storage_file).returns(false) }
131
+ it 'should return YAML deserialized objects in an array, sorted by time DESC' do
132
+ YAML.expects(:load_file).with(storage_file).returns(unsorted_objects)
133
+ cycler.expects(:check_upgrade).with(sorted_objects).returns(sorted_objects)
134
+ cycler.send(:yaml_load).should be(sorted_objects)
135
+ end
136
+ end
137
+ context 'when the file is empty' do
138
+ before { File.expects(:zero?).with(storage_file).returns(true) }
139
+ it 'should return an empty array' do
140
+ cycler.send(:yaml_load).should == []
141
+ end
142
+ end
143
+ end
144
+
145
+ context 'when the storage file does not exist' do
146
+ before { File.expects(:exist?).with(storage_file).returns(false) }
147
+ it 'should return an empty array' do
148
+ cycler.send(:yaml_load).should == []
149
+ end
150
+ end
151
+ end # describe '#yaml_load'
152
+
153
+ describe '#yaml_save' do
154
+ let(:file) { mock }
155
+ let(:pkgs) { [ [1, 2, 3], [4, 5, 6] ] }
156
+ let(:pkgs_to_yaml) { pkgs.to_yaml }
157
+
158
+ it 'should save the given packages to the storage file in YAML format' do
159
+ cycler.instance_variable_set(:@storage_file, storage_file)
160
+ File.expects(:open).with(storage_file, 'w').yields(file)
161
+ file.expects(:write).with(pkgs_to_yaml)
162
+ cycler.send(:yaml_save, pkgs)
163
+ end
164
+ end # describe '#yaml_save'
165
+
166
+ describe '#check_upgrade' do
167
+ let(:yaml_v3_0_19) do
168
+ <<-EOF.gsub(/^ +/,' ').gsub(/^ (-\W\W)/, "\\1")
169
+ ---
170
+ - !ruby/object:Backup::Storage::Local
171
+ time: 2011.11.01.12.01.00
172
+ remote_file: 2011.11.01.12.01.00.backup.tar.gz
173
+ - !ruby/object:Backup::Storage::Local
174
+ time: 2011.11.01.12.02.00
175
+ remote_file: 2011.11.01.12.02.00.backup.tar.gz
176
+ - !ruby/object:Backup::Storage::Local
177
+ time: 2011.11.01.12.03.00
178
+ remote_file: 2011.11.01.12.03.00.backup.tar.gz
179
+ EOF
180
+ end
181
+ let(:yaml_v3_0_20) do
182
+ <<-EOF.gsub(/^ +/,' ').gsub(/^ (-\W\W)/, "\\1")
183
+ ---
184
+ - !ruby/object:Backup::Storage::Local
185
+ time: 2011.12.01.12.01.00
186
+ chunk_suffixes: []
187
+ filename: 2011.12.01.12.01.00.backup.tar.gz
188
+ version: 3.0.20
189
+ - !ruby/object:Backup::Storage::Local
190
+ time: 2011.12.01.12.02.00
191
+ chunk_suffixes: []
192
+ filename: 2011.12.01.12.02.00.backup.tar.gz
193
+ version: 3.0.20
194
+ - !ruby/object:Backup::Storage::Local
195
+ time: 2011.12.01.12.03.00
196
+ chunk_suffixes:
197
+ - aa
198
+ - ab
199
+ filename: 2011.12.01.12.03.00.backup.tar.gz
200
+ version: 3.0.20
201
+ EOF
202
+ end
203
+
204
+ before do
205
+ model = Backup::Model.new('foo', 'foo')
206
+ cycler.instance_variable_set(:@storage, storage)
207
+ storage.instance_variable_set(:@model, model)
208
+ end
209
+
210
+ it 'should upgrade v3.0.20 objects' do
211
+ objects = YAML.load(yaml_v3_0_20)
212
+ packages = cycler.send(:check_upgrade, objects)
213
+
214
+ packages.all? {|pkg| pkg.is_a? Backup::Package }.should be_true
215
+ packages.all? {|pkg| pkg.extension == 'tar.gz' }.should be_true
216
+
217
+ packages[0].time.should == '2011.12.01.12.01.00'
218
+ packages[0].chunk_suffixes.should == []
219
+ packages[1].time.should == '2011.12.01.12.02.00'
220
+ packages[1].chunk_suffixes.should == []
221
+ packages[2].time.should == '2011.12.01.12.03.00'
222
+ packages[2].chunk_suffixes.should == ['aa', 'ab']
223
+ end
224
+
225
+ it 'should upgrade v3.0.19 objects' do
226
+ objects = YAML.load(yaml_v3_0_19)
227
+ packages = cycler.send(:check_upgrade, objects)
228
+
229
+ packages.all? {|pkg| pkg.is_a? Backup::Package }.should be_true
230
+ packages.all? {|pkg| pkg.extension == 'tar.gz' }.should be_true
231
+ packages.all? {|pkg| pkg.chunk_suffixes == [] }.should be_true
232
+
233
+ packages[0].time.should == '2011.11.01.12.01.00'
234
+ packages[1].time.should == '2011.11.01.12.02.00'
235
+ packages[2].time.should == '2011.11.01.12.03.00'
236
+ end
237
+ end # describe '#check_upgrade'
238
+
239
+ end