diff options
author | Nigel Kersten <nigelk@google.com> | 2009-08-14 13:35:24 -0700 |
---|---|---|
committer | James Turnbull <james@lovedthanlost.net> | 2009-08-18 08:31:01 +1000 |
commit | c1967bb8d2e98d53182ea15fb13ac68d7bff7d84 (patch) | |
tree | 8237a8dad9b31df5efb50ef521293296f332ebd6 | |
parent | 7e0924737d817644402b1c3d2d5abb2cf006e76b (diff) | |
download | puppet-c1967bb8d2e98d53182ea15fb13ac68d7bff7d84.tar.gz puppet-c1967bb8d2e98d53182ea15fb13ac68d7bff7d84.tar.xz puppet-c1967bb8d2e98d53182ea15fb13ac68d7bff7d84.zip |
Fixes #2513. debian service provider now uses invoke-rc.d to determine enabled? status
-rwxr-xr-x | lib/puppet/provider/service/debian.rb | 30 | ||||
-rwxr-xr-x | spec/unit/provider/service/debian.rb | 89 |
2 files changed, 108 insertions, 11 deletions
diff --git a/lib/puppet/provider/service/debian.rb b/lib/puppet/provider/service/debian.rb index 8527ae036..7ddbd288b 100755 --- a/lib/puppet/provider/service/debian.rb +++ b/lib/puppet/provider/service/debian.rb @@ -4,11 +4,16 @@ Puppet::Type.type(:service).provide :debian, :parent => :init do desc "Debian's form of ``init``-style management. The only difference is that this supports service enabling and disabling - via ``update-rc.d``. + via ``update-rc.d`` and determines enabled status via ``invoke-rc.d``. " - commands :update => "/usr/sbin/update-rc.d" + commands :update_rc => "/usr/sbin/update-rc.d" + # note this isn't being used as a command until + # http://projects.reductivelabs.com/issues/2538 + # is resolved. + commands :invoke_rc => "/usr/sbin/invoke-rc.d" + defaultfor :operatingsystem => [:debian, :ubuntu] def self.defpath @@ -17,16 +22,19 @@ Puppet::Type.type(:service).provide :debian, :parent => :init do # Remove the symlinks def disable - update "-f", @resource[:name], "remove" - update @resource[:name], "stop", "00", "1", "2", "3", "4", "5", "6", "." + update_rc "-f", @resource[:name], "remove" + update_rc @resource[:name], "stop", "00", "1", "2", "3", "4", "5", "6", "." end def enabled? - output = update "-n", "-f", @resource[:name], "remove" - - # If it's enabled, then it will print output showing removal of - # links. - if output =~ /etc\/rc[\dS].d\/S|not installed/ + # TODO: Replace system() call when Puppet::Util.execute gives us a way + # to determine exit status. http://projects.reductivelabs.com/issues/2538 + system("/usr/sbin/invoke-rc.d", "--query", @resource[:name], "start") + + # 104 is the exit status when you query start an enabled service. + # 106 is the exit status when the policy layer supplies a fallback action + # See x-man-page://invoke-rc.d + if [104, 106].include?($?.exitstatus) return :true else return :false @@ -34,7 +42,7 @@ Puppet::Type.type(:service).provide :debian, :parent => :init do end def enable - update "-f", @resource[:name], "remove" - update @resource[:name], "defaults" + update_rc "-f", @resource[:name], "remove" + update_rc @resource[:name], "defaults" end end diff --git a/spec/unit/provider/service/debian.rb b/spec/unit/provider/service/debian.rb new file mode 100755 index 000000000..87d627452 --- /dev/null +++ b/spec/unit/provider/service/debian.rb @@ -0,0 +1,89 @@ +#!/usr/bin/env ruby +# +# Unit testing for the debian service provider +# + +require File.dirname(__FILE__) + '/../../../spec_helper' + +provider_class = Puppet::Type.type(:service).provider(:debian) + +describe provider_class do + + before(:each) do + # Create a mock resource + @resource = stub 'resource' + + @provider = provider_class.new + + # A catch all; no parameters set + @resource.stubs(:[]).returns(nil) + + # But set name, source and path + @resource.stubs(:[]).with(:name).returns "myservice" + @resource.stubs(:[]).with(:ensure).returns :enabled + @resource.stubs(:ref).returns "Service[myservice]" + + @provider.resource = @resource + + @provider.stubs(:command).with(:update_rc).returns "update_rc" + @provider.stubs(:command).with(:invoke_rc).returns "invoke_rc" + + @provider.stubs(:update_rc) + @provider.stubs(:invoke_rc) + end + + it "should have an enabled? method" do + @provider.should respond_to(:enabled?) + end + + it "should have an enable method" do + @provider.should respond_to(:enable) + end + + it "should have a disable method" do + @provider.should respond_to(:disable) + end + + describe "when enabling" do + it "should call update-rc.d twice" do + @provider.expects(:update_rc).twice + @provider.enable + end + end + + describe "when disabling" do + it "should call update-rc.d twice" do + @provider.expects(:update_rc).twice + @provider.disable + end + end + + describe "when checking whether it is enabled" do + it "should call Kernel.system() with the appropriate parameters" do + @provider.expects(:system).with("/usr/sbin/invoke-rc.d", "--query", @resource[:name], "start").once + @provider.enabled? + end + + it "should return true when invoke-rc.d exits with 104 status" do + @provider.stubs(:system) + $?.stubs(:exitstatus).returns(104) + @provider.enabled?.should == :true + end + + it "should return true when invoke-rc.d exits with 106 status" do + @provider.stubs(:system) + $?.stubs(:exitstatus).returns(106) + @provider.enabled?.should == :true + end + + # pick a range of non-[104.106] numbers, strings and booleans to test with. + [-100, -1, 0, 1, 100, "foo", "", :true, :false].each do |exitstatus| + it "should return false when invoke-rc.d exits with #{exitstatus} status" do + @provider.stubs(:system) + $?.stubs(:exitstatus).returns(exitstatus) + @provider.enabled?.should == :false + end + end + end + + end |