65116dafd5
This fixes the acceptance tests by: - Ensuring the fqdn_rand_string spec is passed undef as the second parameter so that the seed is not used as the charset - Ensuring the pw_hash spec is passed the key specifying the type of hash, rather than the value that will be used to generate the password - Expecting puppet to report nil instead of empty string for undef passwords - Removing the fqdn_rand_base64 test because there is no such function
34 lines
1.1 KiB
Ruby
34 lines
1.1 KiB
Ruby
#! /usr/bin/env ruby -S rspec
|
|
require 'spec_helper_acceptance'
|
|
|
|
# Windows and OS X do not have useful implementations of crypt(3)
|
|
describe 'pw_hash function', :unless => (UNSUPPORTED_PLATFORMS + ['windows', 'Darwin']).include?(fact('operatingsystem')) do
|
|
describe 'success' do
|
|
it 'hashes passwords' do
|
|
pp = <<-EOS
|
|
$o = pw_hash('password', 'sha-512', 'salt')
|
|
notice(inline_template('pw_hash is <%= @o.inspect %>'))
|
|
EOS
|
|
|
|
apply_manifest(pp, :catch_failures => true) do |r|
|
|
expect(r.stdout).to match(/pw_hash is "\$6\$salt\$IxDD3jeSOb5eB1CX5LBsqZFVkJdido3OUILO5Ifz5iwMuTS4XMS130MTSuDDl3aCI6WouIL9AjRbLCelDCy\.g\."/)
|
|
end
|
|
end
|
|
|
|
it 'returns nil if no password is provided' do
|
|
pp = <<-EOS
|
|
$o = pw_hash('', 'sha-512', 'salt')
|
|
notice(inline_template('pw_hash is <%= @o.inspect %>'))
|
|
EOS
|
|
|
|
apply_manifest(pp, :catch_failures => true) do |r|
|
|
expect(r.stdout).to match(/pw_hash is nil/)
|
|
end
|
|
end
|
|
end
|
|
describe 'failure' do
|
|
it 'handles less than three arguments'
|
|
it 'handles more than three arguments'
|
|
it 'handles non strings'
|
|
end
|
|
end
|