diff options
Diffstat (limited to 'spec/unit/handler/json_file_spec.rb')
-rw-r--r-- | spec/unit/handler/json_file_spec.rb | 64 |
1 files changed, 0 insertions, 64 deletions
diff --git a/spec/unit/handler/json_file_spec.rb b/spec/unit/handler/json_file_spec.rb deleted file mode 100644 index 05270e4731..0000000000 --- a/spec/unit/handler/json_file_spec.rb +++ /dev/null @@ -1,64 +0,0 @@ -# -# Author:: Adam Jacob (<adam@opscode.com>) -# Copyright:: Copyright (c) 2010 Opscode, Inc. -# 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::Handler::JsonFile do - before(:each) do - @handler = Chef::Handler::JsonFile.new(:the_sun => "will rise", :path => '/tmp/foobarbazqux') - end - - it "accepts arbitrary config options" do - @handler.config[:the_sun].should == "will rise" - end - - it "creates the directory where the reports will be saved" do - FileUtils.should_receive(:mkdir_p).with('/tmp/foobarbazqux') - File.should_receive(:chmod).with(00700, '/tmp/foobarbazqux') - @handler.build_report_dir - end - - describe "when reporting success" do - before(:each) do - @node = Chef::Node.new - @events = Chef::EventDispatch::Dispatcher.new - @run_status = Chef::RunStatus.new(@node, @events) - @expected_time = Time.now - Time.stub(:now).and_return(@expected_time, @expected_time + 5) - @run_status.start_clock - @run_status.stop_clock - @run_context = Chef::RunContext.new(@node, {}, @events) - @run_status.run_context = @run_context - @run_status.exception = Exception.new("Boy howdy!") - @file_mock = StringIO.new - File.stub(:open).and_yield(@file_mock) - end - - - it "saves run status data to a file as JSON" do - @handler.should_receive(:build_report_dir) - @handler.run_report_unsafe(@run_status) - reported_data = Chef::JSONCompat.from_json(@file_mock.string) - reported_data['exception'].should == "Exception: Boy howdy!" - reported_data['start_time'].should == @expected_time.to_s - reported_data['end_time'].should == (@expected_time + 5).to_s - reported_data['elapsed_time'].should == 5 - end - - end -end |