diff options
author | Melissa Stone <melissa@puppet.com> | 2018-04-13 13:32:32 -0700 |
---|---|---|
committer | Melissa Stone <melissa@puppet.com> | 2018-04-16 16:19:30 -0700 |
commit | 759ad74f328af3e0ff16cfb9f341ea7fdca31313 (patch) | |
tree | 921c4d63668ec120e2fb722322cd0474b357684f /spec/unit | |
parent | e7978ebb8e36bea5b90c21cdb4c0b9e7f4e5c8d4 (diff) | |
download | puppet-mailalias_core-759ad74f328af3e0ff16cfb9f341ea7fdca31313.tar.gz puppet-mailalias_core-759ad74f328af3e0ff16cfb9f341ea7fdca31313.tar.bz2 |
Initial mailalias import from bc8e56000fcd585d2197e1ad9e6f741bec56c174
Diffstat (limited to 'spec/unit')
-rw-r--r-- | spec/unit/type/mailalias_spec.rb | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/spec/unit/type/mailalias_spec.rb b/spec/unit/type/mailalias_spec.rb new file mode 100644 index 0000000..eb701c6 --- /dev/null +++ b/spec/unit/type/mailalias_spec.rb @@ -0,0 +1,49 @@ +#! /usr/bin/env ruby +require 'spec_helper' + +describe Puppet::Type.type(:mailalias) do + include PuppetSpec::Files + + let :tmpfile_path do tmpfile('afile') end + let :target do tmpfile('mailalias') end + let :recipient_resource do + described_class.new(:name => "luke", :recipient => "yay", :target => target) + end + + let :file_resource do + described_class.new(:name => "lukefile", :file => tmpfile_path, :target => target) + end + + it "should be initially absent as a recipient" do + expect(recipient_resource.retrieve_resource[:recipient]).to eq(:absent) + end + + it "should be initially absent as an included file" do + expect(file_resource.retrieve_resource[:file]).to eq(:absent) + end + + it "should try and set the recipient when it does the sync" do + expect(recipient_resource.retrieve_resource[:recipient]).to eq(:absent) + recipient_resource.property(:recipient).expects(:set).with(["yay"]) + recipient_resource.property(:recipient).sync + end + + it "should try and set the included file when it does the sync" do + expect(file_resource.retrieve_resource[:file]).to eq(:absent) + file_resource.property(:file).expects(:set).with(tmpfile_path) + file_resource.property(:file).sync + end + + it "should fail when file is not an absolute path" do + expect { + Puppet::Type.type(:mailalias).new(:name => 'x', :file => 'afile') + }.to raise_error Puppet::Error, /File paths must be fully qualified/ + end + + it "should fail when both file and recipient are specified" do + expect { + Puppet::Type.type(:mailalias).new(:name => 'x', :file => tmpfile_path, + :recipient => 'foo@example.com') + }.to raise_error Puppet::Error, /cannot specify both a recipient and a file/ + end +end |