| 
									
										
										
										
											2017-03-05 19:26:56 +01:00
										 |  |  | describe Hbc::CLI::Cleanup, :cask do | 
					
						
							| 
									
										
										
										
											2016-08-18 22:11:42 +03:00
										 |  |  |   let(:cache_location) { Pathname.new(Dir.mktmpdir).realpath } | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |   let(:outdated_only) { false } | 
					
						
							| 
									
										
										
										
											2016-08-18 22:11:42 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-21 02:32:46 +02:00
										 |  |  |   subject { described_class.new(*cask_tokens, cache_location: cache_location) } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   before(:each) do | 
					
						
							|  |  |  |     allow_any_instance_of(described_class).to receive(:outdated_only?).and_return(outdated_only) | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2016-08-18 22:11:42 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |   after do | 
					
						
							|  |  |  |     cache_location.rmtree | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-23 06:13:03 +02:00
										 |  |  |   describe "cleanup" do | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |     let(:cask_token) { "caffeine" } | 
					
						
							|  |  |  |     let(:cask_tokens) { [cask_token] } | 
					
						
							| 
									
										
										
										
											2016-08-23 06:13:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |     it "removes cached downloads of given casks" do | 
					
						
							| 
									
										
										
										
											2016-08-23 06:13:03 +02:00
										 |  |  |       cached_downloads = [ | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |         cache_location.join("#{cask_token}--latest.zip"), | 
					
						
							| 
									
										
										
										
											2016-10-14 20:33:16 +02:00
										 |  |  |         cache_location.join("transmission--2.61.dmg"), | 
					
						
							|  |  |  |       ] | 
					
						
							| 
									
										
										
										
											2016-08-23 06:13:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |       cached_downloads.each(&FileUtils.method(:touch)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-07 18:02:31 +01:00
										 |  |  |       cleanup_size = cached_downloads[0].disk_usage | 
					
						
							| 
									
										
										
										
											2016-08-23 06:13:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |       expect { | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |         subject.run | 
					
						
							| 
									
										
										
										
											2016-08-23 06:13:03 +02:00
										 |  |  |       }.to output(<<-EOS.undent).to_stdout
 | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |         ==> Removing cached downloads for #{cask_token} | 
					
						
							| 
									
										
										
										
											2016-08-23 06:13:03 +02:00
										 |  |  |         #{cached_downloads[0]} | 
					
						
							|  |  |  |         ==> This operation has freed approximately #{disk_usage_readable(cleanup_size)} of disk space. | 
					
						
							|  |  |  |       EOS | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       expect(cached_downloads[0].exist?).to eq(false) | 
					
						
							|  |  |  |       expect(cached_downloads[1].exist?).to eq(true) | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2016-08-18 22:11:42 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |     context "when no argument is given" do | 
					
						
							|  |  |  |       let(:cask_tokens) { [] } | 
					
						
							| 
									
										
										
										
											2016-08-18 22:11:42 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |       it "removes all cached downloads" do | 
					
						
							|  |  |  |         cached_download = cache_location.join("SomeDownload.dmg") | 
					
						
							| 
									
										
										
										
											2016-08-18 22:11:42 +03:00
										 |  |  |         FileUtils.touch(cached_download) | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |         cleanup_size = subject.disk_cleanup_size | 
					
						
							| 
									
										
										
										
											2016-08-18 22:11:42 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |         expect { | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |           subject.run | 
					
						
							| 
									
										
										
										
											2016-08-23 06:13:03 +02:00
										 |  |  |         }.to output(<<-EOS.undent).to_stdout
 | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |           ==> Removing cached downloads | 
					
						
							|  |  |  |           #{cached_download} | 
					
						
							|  |  |  |           ==> This operation has freed approximately #{disk_usage_readable(cleanup_size)} of disk space. | 
					
						
							| 
									
										
										
										
											2016-08-23 06:13:03 +02:00
										 |  |  |         EOS | 
					
						
							| 
									
										
										
										
											2016-08-18 22:11:42 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-19 20:27:25 +02:00
										 |  |  |         expect(cached_download.exist?).to eq(false) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       context "and :outdated_only is specified" do | 
					
						
							|  |  |  |         let(:outdated_only) { true } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         it "does not remove cache files newer than 10 days old" do | 
					
						
							|  |  |  |           cached_download = cache_location.join("SomeNewDownload.dmg") | 
					
						
							|  |  |  |           FileUtils.touch(cached_download) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           expect { | 
					
						
							|  |  |  |             subject.run | 
					
						
							|  |  |  |           }.to output(<<-EOS.undent).to_stdout
 | 
					
						
							|  |  |  |             ==> Removing cached downloads older than 10 days old | 
					
						
							|  |  |  |             Nothing to do | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           expect(cached_download.exist?).to eq(true) | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2016-08-18 22:11:42 +03:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end |