summaryrefslogtreecommitdiff
path: root/spec/unit/knife/cookbook_delete_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/unit/knife/cookbook_delete_spec.rb')
-rw-r--r--spec/unit/knife/cookbook_delete_spec.rb239
1 files changed, 239 insertions, 0 deletions
diff --git a/spec/unit/knife/cookbook_delete_spec.rb b/spec/unit/knife/cookbook_delete_spec.rb
new file mode 100644
index 0000000000..afaa3b69a5
--- /dev/null
+++ b/spec/unit/knife/cookbook_delete_spec.rb
@@ -0,0 +1,239 @@
+#
+# Author:: Thomas Bishop (<bishop.thomas@gmail.com>)
+# Copyright:: Copyright (c) 2011 Thomas Bishop
+# License:: Apache License, Version 2.0
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+require 'spec_helper'
+
+describe Chef::Knife::CookbookDelete do
+ before(:each) do
+ @knife = Chef::Knife::CookbookDelete.new
+ @knife.name_args = ['foobar']
+ @knife.cookbook_name = 'foobar'
+ @stdout = StringIO.new
+ @knife.ui.stub!(:stdout).and_return(@stdout)
+ @stderr = StringIO.new
+ @knife.ui.stub!(:stderr).and_return(@stderr)
+ end
+
+ describe 'run' do
+ it 'should print usage and exit when a cookbook name is not provided' do
+ @knife.name_args = []
+ @knife.should_receive(:show_usage)
+ @knife.ui.should_receive(:fatal)
+ lambda { @knife.run }.should raise_error(SystemExit)
+ end
+
+ describe 'when specifying a cookbook name' do
+ it 'should delete the cookbook without a specific version' do
+ @knife.should_receive(:delete_without_explicit_version)
+ @knife.run
+ end
+
+ describe 'and a version' do
+ it 'should delete the specific version of the cookbook' do
+ @knife.name_args << '1.0.0'
+ @knife.should_receive(:delete_explicit_version)
+ @knife.run
+ end
+ end
+
+ describe 'with -a or --all' do
+ it 'should delete all versions of the cookbook' do
+ @knife.config[:all] = true
+ @knife.should_receive(:delete_all_versions)
+ @knife.run
+ end
+ end
+
+ describe 'with -p or --purge' do
+ it 'should prompt to purge the files' do
+ @knife.config[:purge] = true
+ @knife.should_receive(:confirm).
+ with(/.+Are you sure you want to purge files.+/)
+ @knife.should_receive(:delete_without_explicit_version)
+ @knife.run
+ end
+ end
+ end
+ end
+
+ describe 'delete_explicit_version' do
+ it 'should delete the specific cookbook version' do
+ @knife.cookbook_name = 'foobar'
+ @knife.version = '1.0.0'
+ @knife.should_receive(:delete_object).with(Chef::CookbookVersion,
+ 'foobar version 1.0.0',
+ 'cookbook').and_yield()
+ @knife.should_receive(:delete_request).with('cookbooks/foobar/1.0.0')
+ @knife.delete_explicit_version
+ end
+ end
+
+ describe 'delete_all_versions' do
+ it 'should prompt to delete all versions of the cookbook' do
+ @knife.cookbook_name = 'foobar'
+ @knife.should_receive(:confirm).with('Do you really want to delete all versions of foobar')
+ @knife.should_receive(:delete_all_without_confirmation)
+ @knife.delete_all_versions
+ end
+ end
+
+ describe 'delete_all_without_confirmation' do
+ it 'should delete all versions without confirmation' do
+ versions = ['1.0.0', '1.1.0']
+ @knife.should_receive(:available_versions).and_return(versions)
+ versions.each do |v|
+ @knife.should_receive(:delete_version_without_confirmation).with(v)
+ end
+ @knife.delete_all_without_confirmation
+ end
+ end
+
+ describe 'delete_without_explicit_version' do
+ it 'should exit if there are no available versions' do
+ @knife.should_receive(:available_versions).and_return(nil)
+ lambda { @knife.delete_without_explicit_version }.should raise_error(SystemExit)
+ end
+
+ it 'should delete the version if only one is found' do
+ @knife.should_receive(:available_versions).at_least(:once).and_return(['1.0.0'])
+ @knife.should_receive(:delete_explicit_version)
+ @knife.delete_without_explicit_version
+ end
+
+ it 'should ask which version(s) to delete if multiple are found' do
+ @knife.should_receive(:available_versions).at_least(:once).and_return(['1.0.0', '1.1.0'])
+ @knife.should_receive(:ask_which_versions_to_delete).and_return(['1.0.0', '1.1.0'])
+ @knife.should_receive(:delete_versions_without_confirmation).with(['1.0.0', '1.1.0'])
+ @knife.delete_without_explicit_version
+ end
+ end
+
+ describe 'available_versions' do
+ before(:each) do
+ @rest_mock = mock('rest')
+ @knife.should_receive(:rest).and_return(@rest_mock)
+ @cookbook_data = { 'foobar' => { 'versions' => [{'version' => '1.0.0'},
+ {'version' => '1.1.0'},
+ {'version' => '2.0.0'} ]}
+ }
+ end
+
+ it 'should return the list of versions of the cookbook' do
+ @rest_mock.should_receive(:get_rest).with('cookbooks/foobar').and_return(@cookbook_data)
+ @knife.available_versions.should == ['1.0.0', '1.1.0', '2.0.0']
+ end
+
+ it 'should raise if an error other than HTTP 404 is returned' do
+ exception = Net::HTTPServerException.new('500 Internal Server Error', '500')
+ @rest_mock.should_receive(:get_rest).and_raise(exception)
+ lambda { @knife.available_versions }.should raise_error Net::HTTPServerException
+ end
+
+ describe "if the cookbook can't be found" do
+ before(:each) do
+ @rest_mock.should_receive(:get_rest).
+ and_raise(Net::HTTPServerException.new('404 Not Found', '404'))
+ end
+
+ it 'should print an error' do
+ @knife.available_versions
+ @stderr.string.should match /error.+cannot find a cookbook named foobar/i
+ end
+
+ it 'should return nil' do
+ @knife.available_versions.should == nil
+ end
+ end
+ end
+
+ describe 'ask_which_version_to_delete' do
+ before(:each) do
+ @knife.stub!(:available_versions).and_return(['1.0.0', '1.1.0', '2.0.0'])
+ end
+
+ it 'should prompt the user to select a version' do
+ prompt = /Which version\(s\) do you want to delete\?.+1\. foobar 1\.0\.0.+2\. foobar 1\.1\.0.+3\. foobar 2\.0\.0.+4\. All versions.+/m
+ @knife.should_receive(:ask_question).with(prompt).and_return('1')
+ @knife.ask_which_versions_to_delete
+ end
+
+ it "should print an error and exit if a version wasn't specified" do
+ @knife.should_receive(:ask_question).and_return('')
+ @knife.ui.should_receive(:error).with(/no versions specified/i)
+ lambda { @knife.ask_which_versions_to_delete }.should raise_error(SystemExit)
+ end
+
+ it 'should print an error if an invalid choice was selected' do
+ @knife.should_receive(:ask_question).and_return('100')
+ @knife.ui.should_receive(:error).with(/100 is not a valid choice/i)
+ @knife.ask_which_versions_to_delete
+ end
+
+ it 'should return the selected versions' do
+ @knife.should_receive(:ask_question).and_return('1, 3')
+ @knife.ask_which_versions_to_delete.should == ['1.0.0', '2.0.0']
+ end
+
+ it "should return all of the versions if 'all' was selected" do
+ @knife.should_receive(:ask_question).and_return('4')
+ @knife.ask_which_versions_to_delete.should == [:all]
+ end
+ end
+
+ describe 'delete_version_without_confirmation' do
+ it 'should delete the cookbook version' do
+ @knife.should_receive(:delete_request).with('cookbooks/foobar/1.0.0')
+ @knife.delete_version_without_confirmation('1.0.0')
+ end
+
+ it 'should output that the cookbook was deleted' do
+ @knife.stub!(:delete_request)
+ @knife.delete_version_without_confirmation('1.0.0')
+ @stdout.string.should match /deleted cookbook\[foobar\]\[1.0.0\]/im
+ end
+
+ describe 'with --print-after' do
+ it 'should display the cookbook data' do
+ object = ''
+ @knife.config[:print_after] = true
+ @knife.stub!(:delete_request).and_return(object)
+ @knife.should_receive(:format_for_display).with(object)
+ @knife.delete_version_without_confirmation('1.0.0')
+ end
+ end
+ end
+
+ describe 'delete_versions_without_confirmation' do
+ it 'should delete each version without confirmation' do
+ versions = ['1.0.0', '1.1.0']
+ versions.each do |v|
+ @knife.should_receive(:delete_version_without_confirmation).with(v)
+ end
+ @knife.delete_versions_without_confirmation(versions)
+ end
+
+ describe 'with -a or --all' do
+ it 'should delete all versions without confirmation' do
+ versions = [:all]
+ @knife.should_receive(:delete_all_without_confirmation)
+ @knife.delete_versions_without_confirmation(versions)
+ end
+ end
+ end
+
+end