On this page
processes resource
Use the processes Chef InSpec audit resource to test properties for programs that are running on the system.
Availability
Installation
This resource is distributed along with Chef InSpec itself. You can use it automatically.
Version
This resource first became available in v1.0.0 of InSpec.
Syntax
A processes resource block declares the name of the process to be tested, and then declares one (or more) property/value pairs:
describe processes('process_name') do
  its('property_name') { should eq ['property_value'] }
end
where
- processes('process_name')specifies the name of a process to check. If this is a string, it will be converted to a Regexp. For more specificity, pass a Regexp directly. If left blank, all processes will be returned.
- property_namemay be used to test user (- its('users')) and state properties (- its('states'))
Examples
The following examples show how to use this Chef InSpec audit resource.
Test if the list length for the mysqld process is 1
describe processes('mysqld') do
  its('list.length') { should eq 1 }
end
Test if the process is owned by a specific user
describe processes('init') do
  its('users') { should eq ['root'] }
end
describe processes('winlogon') do
  its('users') { should cmp "NT AUTHORITY\\SYSTEM" }
end
Test if a high-priority process is running
describe processes('linux_process') do
  its('states') { should eq ['R<'] }
end
describe processes('windows_process') do
  its('labels') { should cmp "High" }
end
Test if a process exists on the system
describe processes('some_process') do
  it { should exist }
end
Test for a process using a specific Regexp
If the process name is too common for a string to uniquely find it, you may use a regexp. Inclusion of whitespace characters may be needed.
describe processes(Regexp.new("/usr/local/bin/swap -d")) do
  its('list.length') { should eq 1 }
end
Notes for auditing Windows systems
Sometimes with system properties there isn’t a direct comparison between different operating systems. Most of the property_name’s do align between the different OS’s.
There are however some exception’s, for example, within linux states offers multiple properties. Windows doesn’t have direct comparison that is a single property so instead states is mapped to the property of Responding, This is a boolean true/false flag to help determine if the process is hung.
Below is a mapping table to help you understand what property the unix field maps to the windows Get-Process Property
| unix ps field | windows PowerShell Property | 
|---|---|
| labels | PriorityClass | 
| pids | Id | 
| cpus | CPU | 
| mem | PM | 
| vsz | VirtualMemorySize | 
| rss | NPM | 
| tty | SessionId | 
| states | Responding | 
| start | StartTime | 
| time | TotalProcessorTime | 
| users | UserName | 
| commands | Path | 
Matchers
For a full list of available matchers, please visit our matchers page.
property_name
The property_name matcher tests the named property for the specified value:
its('property_name') { should eq ['property_value'] }
© Chef Software, Inc.
Licensed under the Creative Commons Attribution 3.0 Unported License.
The Chef™ Mark and Chef Logo are either registered trademarks/service marks or trademarks/servicemarks of Chef, in the United States and other countries and are used with Chef Inc's permission.
We are not affiliated with, endorsed or sponsored by Chef Inc.
 https://docs.chef.io/inspec/resources/processes/