diff options
author | Silvio Rhatto <rhatto@riseup.net> | 2016-03-19 10:17:30 -0300 |
---|---|---|
committer | Silvio Rhatto <rhatto@riseup.net> | 2016-03-19 10:17:30 -0300 |
commit | ff79bc6295e9f089285ccc26c04cc72893a8384f (patch) | |
tree | 1a84dad2d03bc3814305eeaedb4cfd8d8dc09f36 /spec/unit/parser | |
parent | 9b1d0f06fee4b0c457d0154c4153415758c10425 (diff) | |
parent | 672b0985d1c2acfde58fecc4c635517522c86268 (diff) | |
download | puppet-sshd-ff79bc6295e9f089285ccc26c04cc72893a8384f.tar.gz puppet-sshd-ff79bc6295e9f089285ccc26c04cc72893a8384f.tar.bz2 |
Merge branch 'master' of https://gitlab.com/shared-puppet-modules-group/sshd
Conflicts:
README
templates/sshd_config/CentOS.erb
templates/sshd_config/CentOS_Final.erb
templates/sshd_config/Debian_etch.erb
templates/sshd_config/Debian_jessie.erb
templates/sshd_config/Debian_sid.erb
templates/sshd_config/Debian_squeeze.erb
templates/sshd_config/Debian_wheezy.erb
templates/sshd_config/Ubuntu_trusty.erb
Diffstat (limited to 'spec/unit/parser')
-rw-r--r-- | spec/unit/parser/functions/ssh_keygen.rb | 104 |
1 files changed, 0 insertions, 104 deletions
diff --git a/spec/unit/parser/functions/ssh_keygen.rb b/spec/unit/parser/functions/ssh_keygen.rb deleted file mode 100644 index da45779..0000000 --- a/spec/unit/parser/functions/ssh_keygen.rb +++ /dev/null @@ -1,104 +0,0 @@ -#! /usr/bin/env ruby - - -require File.dirname(__FILE__) + '/../../../spec_helper' - -require 'mocha' -require 'fileutils' - -describe "the ssh_keygen function" do - - before :each do - @scope = Puppet::Parser::Scope.new - end - - it "should exist" do - Puppet::Parser::Functions.function("ssh_keygen").should == "function_ssh_keygen" - end - - it "should raise a ParseError if no argument is passed" do - lambda { @scope.function_ssh_keygen }.should( raise_error(Puppet::ParseError)) - end - - it "should raise a ParseError if there is more than 1 arguments" do - lambda { @scope.function_ssh_keygen("foo", "bar") }.should( raise_error(Puppet::ParseError)) - end - - it "should raise a ParseError if the argument is not fully qualified" do - lambda { @scope.function_ssh_keygen("foo") }.should( raise_error(Puppet::ParseError)) - end - - it "should raise a ParseError if the private key path is a directory" do - File.stubs(:directory?).with("/some_dir").returns(true) - lambda { @scope.function_ssh_keygen("/some_dir") }.should( raise_error(Puppet::ParseError)) - end - - it "should raise a ParseError if the public key path is a directory" do - File.stubs(:directory?).with("/some_dir.pub").returns(true) - lambda { @scope.function_ssh_keygen("/some_dir") }.should( raise_error(Puppet::ParseError)) - end - - describe "when executing properly" do - before do - File.stubs(:directory?).with('/tmp/a/b/c').returns(false) - File.stubs(:directory?).with('/tmp/a/b/c.pub').returns(false) - File.stubs(:read).with('/tmp/a/b/c').returns('privatekey') - File.stubs(:read).with('/tmp/a/b/c.pub').returns('publickey') - end - - it "should fail if the public but not the private key exists" do - File.stubs(:exists?).with("/tmp/a/b/c").returns(true) - File.stubs(:exists?).with("/tmp/a/b/c.pub").returns(false) - lambda { @scope.function_ssh_keygen("/tmp/a/b/c") }.should( raise_error(Puppet::ParseError)) - end - - it "should fail if the private but not the public key exists" do - File.stubs(:exists?).with("/tmp/a/b/c").returns(false) - File.stubs(:exists?).with("/tmp/a/b/c.pub").returns(true) - lambda { @scope.function_ssh_keygen("/tmp/a/b/c") }.should( raise_error(Puppet::ParseError)) - end - - - it "should return an array of size 2 with the right conent if the keyfiles exists" do - File.stubs(:exists?).with("/tmp/a/b/c").returns(true) - File.stubs(:exists?).with("/tmp/a/b/c.pub").returns(true) - File.stubs(:directory?).with('/tmp/a/b').returns(true) - Puppet::Util.expects(:execute).never - result = @scope.function_ssh_keygen('/tmp/a/b/c') - result.length.should == 2 - result[0].should == 'privatekey' - result[1].should == 'publickey' - end - - it "should create the directory path if it does not exist" do - File.stubs(:exists?).with("/tmp/a/b/c").returns(false) - File.stubs(:exists?).with("/tmp/a/b/c.pub").returns(false) - File.stubs(:directory?).with("/tmp/a/b").returns(false) - FileUtils.expects(:mkdir_p).with("/tmp/a/b", :mode => 0700) - Puppet::Util.expects(:execute).returns("") - result = @scope.function_ssh_keygen('/tmp/a/b/c') - result.length.should == 2 - result[0].should == 'privatekey' - result[1].should == 'publickey' - end - - it "should generate the key if the keyfiles do not exist" do - File.stubs(:exists?).with("/tmp/a/b/c").returns(false) - File.stubs(:exists?).with("/tmp/a/b/c.pub").returns(false) - File.stubs(:directory?).with("/tmp/a/b").returns(true) - Puppet::Util.expects(:execute).with(['/usr/bin/ssh-keygen','-t', 'rsa', '-b', '4096', '-f', '/tmp/a/b/c', '-P', '', '-q']).returns("") - result = @scope.function_ssh_keygen('/tmp/a/b/c') - result.length.should == 2 - result[0].should == 'privatekey' - result[1].should == 'publickey' - end - - it "should fail if something goes wrong during generation" do - File.stubs(:exists?).with("/tmp/a/b/c").returns(false) - File.stubs(:exists?).with("/tmp/a/b/c.pub").returns(false) - File.stubs(:directory?).with("/tmp/a/b").returns(true) - Puppet::Util.expects(:execute).with(['/usr/bin/ssh-keygen','-t', 'rsa', '-b', '4096', '-f', '/tmp/a/b/c', '-P', '', '-q']).returns("something is wrong") - lambda { @scope.function_ssh_keygen("/tmp/a/b/c") }.should( raise_error(Puppet::ParseError)) - end - end -end |