Skip to main content

gem resource

Use the gem Chef InSpec audit resource to test if a global Gem package is installed.

Availability

Install

This resource is distributed with Chef InSpec and is automatically available for use.

Version

This resource first became available in v1.0.0 of InSpec.

Syntax

A gem resource block declares a package and (optionally) a package version:

describe gem('gem_package_name', 'gem_binary') do
  it { should be_installed }
end

where

  • ('gem_package_name') must specify a Gem package, such as 'rubocop'
  • ('gem_binary') can specify the path to a non-default gem binary, defaults to 'gem'
  • be_installed is a valid matcher for this resource

Properties

version (String)

The version property returns a string of the default version on the system:

its('version') { should eq '0.33.0' }

versions

The versions property returns an array of strings of all the versions of the gem installed on the system:

its('versions') { should include /0.33/ }

Examples

The following examples show how to use this Chef InSpec audit resource.

Verify that a gem package is installed, with a specific version

describe gem('rubocop') do
  it { should be_installed }
  its('version') { should eq '1.22.0' }
end

Verify that a particular version is installed when there are multiple versions installed

describe gem('rubocop') do
  it { should be_installed }
  its('versions') { should include /1.21.0/ }
  its('versions.count') { should_not be > 3 }
end

Verify that a gem package is not installed

describe gem('rubocop') do
  it { should_not be_installed }
end

Verify that a gem package is installed in an omnibus environment

describe gem('pry', '/opt/ruby-3.0.2/embedded/bin/gem') do
  it { should be_installed }
end

Verify that a gem package is installed in a chef omnibus environment

describe gem('chef-sugar', :chef) do
  it { should be_installed }
end

Verify that a gem package is installed in a chef-server omnibus environment

describe gem('knife-backup', :chef_server) do
  it { should be_installed }
end

Properties

version (String)

The version property returns a string of the default version on the system:

its('version') { should eq '1.22.0' }

versions

The versions property returns an array of strings of all the versions of the gem installed on the system:

its('versions') { should include /1.22/ }

Matchers

For a full list of available matchers, see our Universal Matchers page.

This resource has the following special matchers.

be_installed

The be_installed matcher tests if the named Gem package is installed:

it { should be_installed }
Edit this page on GitHub

Thank you for your feedback!

×