newer pg module
[mirror/dsa-puppet.git] / 3rdparty / modules / postgresql / spec / unit / type / postgresql_conf_spec.rb
1 #! /usr/bin/env ruby
2 require 'spec_helper'
3
4 describe Puppet::Type.type(:postgresql_conf) do
5   before do
6     @provider_class = described_class.provide(:simple) { mk_resource_methods }
7     @provider_class.stub(:suitable?).and_return true
8     described_class.stub(:defaultprovider).and_return @provider_class
9   end
10
11   describe "namevar validation" do
12     it "should have :name as its namevar" do
13       expect(described_class.key_attributes).to eq([:name])
14     end
15     it "should not invalid names" do
16       expect { described_class.new(:name => 'foo bar') }.to raise_error(Puppet::Error, /Invalid value/)
17     end
18     it "should allow dots in names" do
19       expect { described_class.new(:name => 'foo.bar') }.to_not raise_error
20     end
21   end
22
23   describe "when validating attributes" do
24     [:name, :provider].each do |param|
25       it "should have a #{param} parameter" do
26         expect(described_class.attrtype(param)).to eq(:param)
27       end
28     end
29
30     [:value, :target].each do |property|
31       it "should have a #{property} property" do
32         expect(described_class.attrtype(property)).to eq(:property)
33       end
34     end
35   end
36
37   describe "when validating values" do
38     describe "ensure" do
39       it "should support present as a value for ensure" do
40         expect { described_class.new(:name => 'foo', :ensure => :present) }.to_not raise_error
41       end
42       it "should support absent as a value for ensure" do
43         expect { described_class.new(:name => 'foo', :ensure => :absent) }.to_not raise_error
44       end
45       it "should not support other values" do
46         expect { described_class.new(:name => 'foo', :ensure => :foo) }.to raise_error(Puppet::Error, /Invalid value/)
47       end
48     end
49   end
50 end