summaryrefslogtreecommitdiffstats
path: root/spec/unit/type/sshkey_spec.rb
blob: d476e19083581ed8b846e14fea3e8c7b1f447a0e (plain)
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
#!/usr/bin/env ruby

require 'spec_helper'

sshkey = Puppet::Type.type(:sshkey)

describe sshkey do
  before do
    @class = sshkey
  end

  it "should have :name its namevar" do
    @class.key_attributes.should == [:name]
  end

  describe "when validating attributes" do
    [:name, :provider].each do |param|
      it "should have a #{param} parameter" do
        @class.attrtype(param).should == :param
      end
    end

    [:host_aliases, :ensure, :key, :type].each do |property|
      it "should have a #{property} property" do
        @class.attrtype(property).should == :property
      end
    end
  end

  describe "when validating values" do

    it "should support ssh-dss as a type value" do
      proc { @class.new(:name => "foo", :type => "ssh-dss") }.should_not raise_error
    end

    it "should support ssh-rsa as a type value" do
      proc { @class.new(:name => "whev", :type => "ssh-rsa") }.should_not raise_error
    end

    it "should alias :dsa to ssh-dss as a value for type" do
      key = @class.new(:name => "whev", :type => :dsa)
      key.should(:type).should == :'ssh-dss'
    end

    it "should alias :rsa to ssh-rsa as a value for type" do
      key = @class.new(:name => "whev", :type => :rsa)
      key.should(:type).should == :'ssh-rsa'
    end

    it "should not support values other than ssh-dss, ssh-rsa, dsa, rsa for type" do
      proc { @class.new(:name => "whev", :type => :'ssh-dsa') }.should raise_error(Puppet::Error)
    end

    it "should accept one host_alias" do
      proc { @class.new(:name => "foo", :host_aliases => 'foo.bar.tld') }.should_not raise_error
    end

    it "should accept multiple host_aliases as an array" do
      proc { @class.new(:name => "foo", :host_aliases => ['foo.bar.tld','10.0.9.9']) }.should_not raise_error
    end

    it "should not accept spaces in any host_alias" do
      proc { @class.new(:name => "foo", :host_aliases => ['foo.bar.tld','foo bar']) }.should raise_error(Puppet::Error)
    end

    it "should not accept aliases in the resourcename" do
      proc { @class.new(:name => 'host,host.domain,ip') }.should raise_error(Puppet::Error)
    end

  end
end