1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163
|
require 'spec_helper'
describe Puppet::Type.type(:service).provider(:daemontools) do
before(:each) do
# Create a mock resource
@resource = stub 'resource'
@provider = subject()
@servicedir = "/etc/service"
@provider.servicedir=@servicedir
@daemondir = "/var/lib/service"
@provider.class.defpath=@daemondir
# A catch all; no parameters set
@resource.stubs(:[]).returns(nil)
# But set name, source and path (because we won't run
# the thing that will fetch the resource path from the provider)
@resource.stubs(:[]).with(:name).returns "myservice"
@resource.stubs(:[]).with(:ensure).returns :enabled
@resource.stubs(:[]).with(:path).returns @daemondir
@resource.stubs(:ref).returns "Service[myservice]"
@provider.resource = @resource
@provider.stubs(:command).with(:svc).returns "svc"
@provider.stubs(:command).with(:svstat).returns "svstat"
@provider.stubs(:svc)
@provider.stubs(:svstat)
end
it "should have a restart method" do
expect(@provider).to respond_to(:restart)
end
it "should have a start method" do
expect(@provider).to respond_to(:start)
end
it "should have a stop method" do
expect(@provider).to respond_to(:stop)
end
it "should have an enabled? method" do
expect(@provider).to respond_to(:enabled?)
end
it "should have an enable method" do
expect(@provider).to respond_to(:enable)
end
it "should have a disable method" do
expect(@provider).to respond_to(:disable)
end
context "when starting" do
it "should use 'svc' to start the service" do
@provider.stubs(:enabled?).returns :true
@provider.expects(:svc).with("-u", "/etc/service/myservice")
@provider.start
end
it "should enable the service if it is not enabled" do
@provider.stubs(:svc)
@provider.expects(:enabled?).returns :false
@provider.expects(:enable)
@provider.start
end
end
context "when stopping" do
it "should use 'svc' to stop the service" do
@provider.stubs(:disable)
@provider.expects(:svc).with("-d", "/etc/service/myservice")
@provider.stop
end
end
context "when restarting" do
it "should use 'svc' to restart the service" do
@provider.expects(:svc).with("-t", "/etc/service/myservice")
@provider.restart
end
end
context "when enabling" do
it "should create a symlink between daemon dir and service dir", :if => Puppet.features.manages_symlinks? do
daemon_path = File.join(@daemondir, "myservice")
service_path = File.join(@servicedir, "myservice")
Puppet::FileSystem.expects(:symlink?).with(service_path).returns(false)
Puppet::FileSystem.expects(:symlink).with(daemon_path, service_path).returns(0)
@provider.enable
end
end
context "when disabling" do
it "should remove the symlink between daemon dir and service dir" do
FileTest.stubs(:directory?).returns(false)
path = File.join(@servicedir,"myservice")
Puppet::FileSystem.expects(:symlink?).with(path).returns(true)
Puppet::FileSystem.expects(:unlink).with(path)
@provider.stubs(:texecute).returns("")
@provider.disable
end
it "should stop the service" do
FileTest.stubs(:directory?).returns(false)
Puppet::FileSystem.expects(:symlink?).returns(true)
Puppet::FileSystem.stubs(:unlink)
@provider.expects(:stop)
@provider.disable
end
end
context "when checking if the service is enabled?" do
it "should return true if it is running" do
@provider.stubs(:status).returns(:running)
expect(@provider.enabled?).to eq(:true)
end
[true, false].each do |t|
it "should return #{t} if the symlink exists" do
@provider.stubs(:status).returns(:stopped)
path = File.join(@servicedir,"myservice")
Puppet::FileSystem.expects(:symlink?).with(path).returns(t)
expect(@provider.enabled?).to eq("#{t}".to_sym)
end
end
end
context "when checking status" do
it "should call the external command 'svstat /etc/service/myservice'" do
@provider.expects(:svstat).with(File.join(@servicedir,"myservice"))
@provider.status
end
end
context "when checking status" do
it "and svstat fails, properly raise a Puppet::Error" do
@provider.expects(:svstat).with(File.join(@servicedir,"myservice")).raises(Puppet::ExecutionFailure, "failure")
expect { @provider.status }.to raise_error(Puppet::Error, 'Could not get status for service Service[myservice]: failure')
end
it "and svstat returns up, then return :running" do
@provider.expects(:svstat).with(File.join(@servicedir,"myservice")).returns("/etc/service/myservice: up (pid 454) 954326 seconds")
expect(@provider.status).to eq(:running)
end
it "and svstat returns not running, then return :stopped" do
@provider.expects(:svstat).with(File.join(@servicedir,"myservice")).returns("/etc/service/myservice: supervise not running")
expect(@provider.status).to eq(:stopped)
end
end
end
|