module Serverspec module Commands class Base class NotImplementedError < Exception; end def check_enabled service raise NotImplementedError.new end def check_file file "test -f #{file}" end def check_directory directory "test -d #{directory}" end def check_user user "id #{user}" end def check_group group "getent group | grep -wq #{group}" end def check_installed package raise NotImplementedError.new end def check_listening port "netstat -tunl | grep ':#{port} '" end def check_running service "service #{service} status" end def check_running_under_supervisor service "supervisorctl status #{service}" end def check_process process "ps aux | grep -w #{process} | grep -qv grep" end def check_file_contain file, expected_pattern "grep -q '#{expected_pattern}' #{file}" end def check_file_contain_within file, expected_pattern, from=nil, to=nil from ||= '1' to ||= '$' checker = check_file_contain("-", expected_pattern) "sed -n '#{from},#{to}p' #{file} | #{checker}" end def check_mode file, mode "stat -c %a #{file} | grep '^#{mode}$'" end def check_owner file, owner "stat -c %U #{file} | grep '^#{owner}$'" end def check_grouped file, group "stat -c %G #{file} | grep '^#{group}$'" end def check_cron_entry user, entry entry_escaped = entry.gsub(/\*/, '\\*') "crontab -u #{user} -l | grep \"#{entry_escaped}\"" end def check_link link, target "stat -c %N #{link} | grep #{target}" end def check_installed_by_gem name "gem list --local | grep '^#{name} '" end def check_belonging_group user, group "id #{user} | awk '{print $2}' | grep #{group}" end def check_iptables_rule rule, table=nil, chain=nil cmd = "iptables" cmd += " -t #{table}" if table cmd += " -S" cmd += " #{chain}" if chain rule.gsub!(/\-/, '\\-') cmd += " | grep '#{rule}'" cmd end def check_zfs zfs, property=nil, value=nil raise NotImplementedError.new end def get_mode(file) "stat -c %a #{file}" end end end end