Class: Unix::Host

Inherits:
Beaker::Host show all
Includes:
Exec, File, Group, Pkg, User
Defined in:
lib/beaker/host/unix.rb

Constant Summary

Constants inherited from Beaker::Host

Beaker::Host::SELECT_TIMEOUT

Instance Attribute Summary

Attributes included from Beaker::CommandFactory

#assertions

Attributes inherited from Beaker::Host

#host_hash, #logger, #name, #options

Instance Method Summary collapse

Methods included from Pkg

#check_for_command, #check_for_package, #determine_if_x86_64, #extract_rpm_proxy_options, #install_local_package, #install_package, #install_package_with_rpm, #pe_puppet_agent_promoted_package_info, #pe_puppet_agent_promoted_package_install, #pkg_initialize, #puppet_agent_dev_package_info, #solaris_install_local_package, #solaris_puppet_agent_dev_package_info, #uncompress_local_tarball, #uninstall_package, #update_apt_if_needed, #upgrade_package

Methods included from Beaker::CommandFactory

#execute, #fail_test

Methods included from Exec

#add_env_var, #clear_env_var, #delete_env_var, #echo, #environment_string, #environment_variable_string_pair_array, #get_env_var, #get_ip, #mirror_env_to_profile_d, #mkdir_p, #mv, #path, #ping, #prepend_commands, #reboot, #rm_rf, #selinux_enabled?, #ssh_permit_user_environment, #ssh_service_restart, #ssh_set_user_environment, #touch

Methods included from File

#file_exist?, #noask_file_text, #package_config_dir, #path_split, #repo_filename, #repo_type, #scp_path, #system_temp_path, #tmpdir, #tmpfile

Methods included from Group

#group_absent, #group_get, #group_gid, #group_list, #group_present

Methods included from User

#user_absent, #user_get, #user_list, #user_present

Methods inherited from Beaker::Host

#+, #[], #[]=, #close, #connection, create, #delete, #do_rsync_to, #do_scp_from, #do_scp_to, #exec, #get_ip, #get_public_ip, #graceful_restarts?, #has_key?, #hostname, #ip, #is_cygwin?, #is_pe?, #is_powershell?, #is_using_passenger?, #is_x86_64?, #log_prefix, #node_name, #pkg_initialize, #platform, #port_open?, #puppet_configprint, #reachable_name, #to_s, #to_str, #up?, #use_service_scripts?, #uses_passenger!, #wait_for_port

Methods included from Beaker::DSL::Patterns

#block_on

Methods included from Beaker::DSL::Helpers::HoconHelpers

#hocon_file_edit_in_place_on, #hocon_file_edit_on, #hocon_file_read_on

Methods included from Beaker::DSL::Helpers::WebHelpers

#link_exists?, #port_open_within?

Methods included from Beaker::DSL::Helpers::TestHelpers

#current_step_name, #current_test_filename, #current_test_name, #set_current_step_name, #set_current_test_filename, #set_current_test_name

Methods included from Beaker::DSL::Helpers::HostHelpers

#add_system32_hosts_entry, #archive_file_from, #backup_the_file, #check_for_package, #create_remote_file, #create_tmpdir_on, #curl_on, #curl_with_retries, #echo_on, #execute_powershell_script_on, #exit_code, #install_package, #on, #retry_on, #rsync_to, #run_script, #run_script_on, #scp_from, #scp_to, #shell, #stderr, #stdout, #upgrade_package

Constructor Details

#initialize(name, host_hash, options) ⇒ Host


70
71
72
73
74
# File 'lib/beaker/host/unix.rb', line 70

def initialize name, host_hash, options
  super

  @external_copy_base = nil
end

Instance Method Details

#determine_ssh_serverSymbol

Note:

This method is mostly a placeholder method, since only :openssh can be returned at this time. Checkout Windows::Host#determine_ssh_server for an example where work needs to be done to determine the answer

Determines which SSH Server is in use on this host


33
34
35
# File 'lib/beaker/host/unix.rb', line 33

def determine_ssh_server
  :openssh
end

#external_copy_baseObject


37
38
39
40
41
42
43
44
# File 'lib/beaker/host/unix.rb', line 37

def external_copy_base
  return @external_copy_base if @external_copy_base
  @external_copy_base = '/root'
  variant, version, arch, codename = self['platform'].to_array
  # Solaris 10 uses / as the root user directory. Solaris 11 uses /root (like most).
  @external_copy_base = '/' if variant == 'solaris' && version == '10'
  @external_copy_base
end

#platform_defaultsObject


17
18
19
20
21
22
23
24
# File 'lib/beaker/host/unix.rb', line 17

def platform_defaults
  h = Beaker::Options::OptionsHash.new
  h.merge({
    'user'             => 'root',
    'group'            => 'root',
    'pathseparator'    => ':',
  })
end

#skip_set_env?String?

Tells you whether a host platform supports beaker's

{Beaker::HostPrebuiltSteps#set_env} method

51
52
53
54
55
56
57
58
59
# File 'lib/beaker/host/unix.rb', line 51

def skip_set_env?
  variant, version, arch, codename = self['platform'].to_array
  case variant
  when /^(f5|netscaler)$/
    "no puppet-agent package for network device platform '#{variant}'"
  else
    nil
  end
end

#validate_setupObject

Validates that the host was setup correctly

Raises:

  • (ArgumentError)

    If the host is setup incorrectly, this will be raised with the appropriate message


66
67
68
# File 'lib/beaker/host/unix.rb', line 66

def validate_setup
  nil
end