Skip to content

Nodes configuration

Silvio Montanari edited this page Jul 23, 2014 · 10 revisions

The "nodespec" metadata

In order to qualify your RSpec example group as a nodespec test you must define a nodespec metadata key. The content of the metadata value will be used to identify the minimal configuration information necessary in order for serverspec and nodespec to be able to connect to the server under test. This information, or set of options, is used to configure a communication adapter in nodespec.

The nodespec metadata can be:

  • a Hash. In this case you're inlining the configuration in your spec file.
  • a String. In this case the string value identifies the options into a yaml configuration file.
  • any object (typically you would set it to true). In this case you're not defining any specific configuration.

Configuring nodespec through a YAML file

Using a configuration file could be more effective if you plan to share configuration options between different nodes. By default nodespec will try and find a nodespec_config.yml file in the root of your project directory. Alternatively you can use a different file by passing its path to the environment variable NODESPEC_CONFIG.

Example configuration file

vagrant-vm2:
  adapter: vagrant
  vm_name: nodespec_vm_2
dbserver1:
  adapter: ssh
  host: 10.2.123.80
  user: root
  keys: /path/to/keyfile
iis-server:
  os: Windows
  adapter: winrm
  host: test.web.local
  user: testadmin
  pass: <somepassword>
  transport: ssl
  basic_auth_only: true

And this is how you could write a test for your database server in RSpec:

describe 'database host', nodespec: 'dbserver1' do
... # your tests here
end

Note: the example group description The example group description (the string that comes after the describe in RSpec) could also be used to identify the target hostname in your test, so you wouldn't have to code it in your configuration. For instance the previous test could alsow have been written like this:

describe '10.2.123.80', nodespec: 'dbserver1' do
... # your tests here
end

See the details on how to configure the different adapters for more information.

Communication adapters

Currently nodespec support the following ways to communicate to a target node:

  • native: local, you run specs against your own host (i.e. no configuration required)
  • ssh: for typical access to UN*X like hosts
  • winrm: for typical access to Windows based servers
  • aws_ec2: to access Amazon EC2 instances.
  • vagrant: to access any vagrant vm running on your host
The os option

The operating system of the machine you're testing is the only option that is common to each adapter. Usually you would only have to define it if you're connecting to a Windows machine, otherwise by default the underlying framework (specinfra) will assume a UN*X like system and try to detect the particular unix flavour. Of course you can always directly set it as a specific os (e.g. 'RedHat' or 'Ubuntu'). See the Serverspec documentation for more details.

Native adapter

This adapter normally does not require any configuration. Basically you're testing the same host where you're running the specs. The only option you may have to set is the operating system of choice, i.e. you have to explicitly set it to "Windows" if you're running on that OS.

Example:

describe 'my laptop', nodespec: true do
... # your tests here
end

On a Windows host:

describe 'my laptop', nodespec: {'os' => 'Windows'} do
... # your tests here
end

Ssh adapter

Use this adapter when you want to connect to your server through ssh. At a minimum you will need to specify a hostname to connect to (relying on your OpenSSH config for the rest).

The example group description can be used to define the target host. Alternatively you must set the host option in the node adapter configuration. Other useful options you can include are port, user, password, keys, and more in general any of the options documented in net-ssh.

Example:

describe "demo.server1.local", nodespec: {
  'adapter'  => 'ssh',
  'user'     => 'someuser',
  'password' => 'somepassword'
} do
... # your tests here
end

Winrm adapter

tbc

Clone this wiki locally