inspec/test/unit/resources/user_test.rb

238 lines
9.5 KiB
Ruby

require "helper"
require "inspec/resource"
require "inspec/resources/users"
require "inspec/resources/command"
describe "Inspec::Resources::User" do
# ubuntu
it "generates the resource_id for current resource" do
resource = MockLoader.new(:ubuntu).load_resource("user", "root")
_(resource.resource_id).must_equal "root"
end
it "read user on ubuntu" do
resource = MockLoader.new(:ubuntu).load_resource("user", "root")
_(resource.exists?).must_equal true
_(resource.group).must_equal "root"
_(resource.groups).must_equal ["root"]
_(resource.home).must_equal "/root"
_(resource.shell).must_equal "/bin/bash"
_(resource.mindays).must_equal 0
_(resource.maxdays).must_equal 99999
_(resource.warndays).must_equal 7
end
# ubuntu 14.04 test with ldap user
it "read user on ubuntu" do
resource = MockLoader.new(:ubuntu).load_resource("user", "jfolmer")
_(resource.exists?).must_equal true
_(resource.group).must_equal "domain users"
_(resource.groups).must_equal ["domain users", "domain admins", "denied rodc password replication group"]
_(resource.home).must_equal "/jfolmer"
_(resource.shell).must_equal "/bin/bash"
_(resource.mindays).must_equal 0
_(resource.maxdays).must_equal 99999
_(resource.warndays).must_equal 7
end
# serverspec compatibility tests of introduced matchers and properties
it "serverspec compatibility tests on ubuntu" do
resource = MockLoader.new(:ubuntu).load_resource("user", "root")
_(resource.exists?).must_equal true
_(resource.has_uid?(0)).must_equal true
_(resource.belongs_to_primary_group?("root")).must_equal true
_(resource.belongs_to_group?("root")).must_equal true
_(resource.has_home_directory?("/root")).must_equal true
_(resource.has_login_shell?("/bin/bash")).must_equal true
_(resource.minimum_days_between_password_change).must_equal 0
_(resource.maximum_days_between_password_change).must_equal 99999
_(resource.has_authorized_key?("ssh-ed25519 50m3r4nd0m57r1ng mockkey")).must_equal true
_(resource.encrypted_password).must_equal "!"
end
it "serverspec compatibility tests on freebsd" do
resource = MockLoader.new(:freebsd11).load_resource("user", "fzipi")
_(resource.exists?).must_equal true
_(resource.has_uid?(1000)).must_equal true
_(resource.belongs_to_primary_group?("fzipi")).must_equal true
_(resource.belongs_to_group?("fzipi")).must_equal true
_(resource.has_home_directory?("/home/fzipi")).must_equal true
_(resource.has_login_shell?("/usr/local/bin/bash")).must_equal true
assert_nil(resource.minimum_days_between_password_change)
assert_nil(resource.maximum_days_between_password_change)
_(resource.has_authorized_key?("ssh-ed25519 50m3r4nd0m57r1ng mockkey")).must_equal true
end
it "serverspec compatibility tests on OSX" do
resource = MockLoader.new(:macos10_10).load_resource("user", "chartmann")
_(resource.exists?).must_equal true
_(resource.has_uid?(501)).must_equal true
_(resource.belongs_to_primary_group?("staff")).must_equal true
_(resource.belongs_to_group?("com.apple.sharepoint.group.1")).must_equal true
_(resource.has_home_directory?("/Users/chartmann")).must_equal true
_(resource.has_login_shell?("/bin/zsh")).must_equal true
assert_nil(resource.minimum_days_between_password_change)
assert_nil(resource.maximum_days_between_password_change)
ex = _ { resource.encrypted_password }.must_raise(Inspec::Exceptions::ResourceSkipped)
_(ex.message).must_include "encrypted_password property is not applicable for your system"
_(resource.has_authorized_key?("ssh-ed25519 50m3r4nd0m57r1ng mockkey")).must_equal true
end
it "serverspec compatibility tests on windows" do
resource = MockLoader.new(:windows).load_resource("user", "administrator")
_(resource.exists?).must_equal true
_(resource.belongs_to_group?("Administrators")).must_equal true
ex = _ { resource.encrypted_password }.must_raise(Inspec::Exceptions::ResourceSkipped)
_(ex.message).must_include "encrypted_password property is not applicable for your system"
end
it "handles a password that has never changed" do
resource = quick_resource(:user, :linux) do |cmd|
cmd.strip!
case cmd
when "chage -l" then
string <<~EOM
Last password change : never
Password expires : never
Password inactive : never
Account expires : never
Minimum number of days between password change : 0
Maximum number of days between password change : 99999
Number of days of warning before password expires : 7
EOM
else
string "" # doesn't matter... they don't error for some reason
end
end
_(resource.passwordage).must_be_nil
end
it "generates the resource_id for current resource" do
resource = MockLoader.new(:centos7).load_resource("user", "root")
_(resource.resource_id).must_equal "root"
end
it "read user on centos7" do
resource = MockLoader.new(:centos7).load_resource("user", "root")
_(resource.exists?).must_equal true
_(resource.group).must_equal "root"
_(resource.groups).must_equal ["root"]
_(resource.home).must_equal "/root"
_(resource.shell).must_equal "/bin/bash"
_(resource.mindays).must_equal 0
_(resource.maxdays).must_equal 99999
_(resource.warndays).must_equal 7
_(resource.passwordage).must_be_kind_of Integer # changes every day
end
it "read user on centos7" do
resource = MockLoader.new(:wrlinux).load_resource("user", "root")
_(resource.exists?).must_equal true
_(resource.group).must_equal "root"
_(resource.groups).must_equal ["root"]
_(resource.home).must_equal "/root"
_(resource.shell).must_equal "/bin/bash"
_(resource.mindays).must_equal 0
_(resource.maxdays).must_equal 99999
_(resource.warndays).must_equal 7
end
it "read user on hpux" do
resource = MockLoader.new(:hpux).load_resource("user", "root")
_(resource.home).must_equal "/"
_(resource.shell).must_equal "/sbin/sh"
end
it "read user on freebsd" do
resource = MockLoader.new(:freebsd11).load_resource("user", "fzipi")
_(resource.exists?).must_equal true
_(resource.group).must_equal "fzipi"
_(resource.groups).must_equal %w{fzipi wheel users}
_(resource.home).must_equal "/home/fzipi"
_(resource.shell).must_equal "/usr/local/bin/bash"
_(resource.mindays).must_be_nil
_(resource.maxdays).must_be_nil
_(resource.warndays).must_be_nil
end
it "read user on OSX" do
resource = MockLoader.new(:macos10_10).load_resource("user", "chartmann")
_(resource.exists?).must_equal true
_(resource.group).must_equal "staff"
_(resource.groups).must_equal ["staff", "com.apple.sharepoint.group.1", "everyone"]
_(resource.home).must_equal "/Users/chartmann"
_(resource.shell).must_equal "/bin/zsh"
_(resource.mindays).must_be_nil
_(resource.maxdays).must_be_nil
_(resource.warndays).must_be_nil
end
it "read administrator user on Windows" do
resource = MockLoader.new(:windows).load_resource("user", "Administrator")
_(resource.uid).wont_be_nil
_(resource.exists?).must_equal true
_(resource.group).must_be_nil
_(resource.groups).must_equal %w{Administrators Users}
_(resource.home).wont_be_nil
_(resource.shell).must_be_nil
_(resource.mindays).wont_be_nil
_(resource.maxdays).wont_be_nil
_(resource.warndays).must_be_nil
_(resource.disabled?).must_equal false
_(resource.lastlogin).must_equal "11/14/2019 21:03:09"
end
it "read guest user on Windows" do
resource = MockLoader.new(:windows).load_resource("user", "Guest")
_(resource.uid).wont_be_nil
_(resource.exists?).must_equal true
_(resource.group).must_be_nil
_(resource.groups).must_equal ["Users"]
_(resource.home).wont_be_nil
_(resource.shell).must_be_nil
_(resource.mindays).wont_be_nil
_(resource.maxdays).wont_be_nil
_(resource.warndays).must_be_nil
_(resource.disabled?).must_equal true
_(resource.lastlogin).must_be_nil
end
it "read disabled user on Windows" do
resource = MockLoader.new(:windows).load_resource("user", "Guest")
_(resource.uid).wont_be_nil
_(resource.exists?).must_equal true
_(resource.disabled?).must_equal true
_(resource.lastlogin).must_be_nil
end
it "read user on undefined os" do
resource = MockLoader.new(:undefined).load_resource("user", "root")
_(resource.exists?).must_equal false
_(resource.group).must_be_nil
_(resource.groups).must_be_nil
_(resource.home).must_be_nil
_(resource.shell).must_be_nil
_(resource.mindays).must_be_nil
_(resource.maxdays).must_be_nil
_(resource.warndays).must_be_nil
end
it "read user on Windows without case-sensitivity" do
resource = MockLoader.new(:windows).load_resource("user", "administrator")
_(resource.exists?).must_equal true
_(resource.uid).wont_be_nil
_(resource.group).must_be_nil
_(resource.groups).must_equal %w{Administrators Users}
end
it "read user groups on Windows without case-sensitivity using include matcher" do
resource = MockLoader.new(:windows).load_resource("user", "administrator")
_(resource.exists?).must_equal true
_(resource.uid).wont_be_nil
_(resource.group).must_be_nil
_(resource.groups).must_include "Administrators"
_(resource.groups).must_include "administrators"
end
end