mirror of
https://github.com/inspec/inspec
synced 2024-11-27 15:10:44 +00:00
577688a3a0
Many of the resources are named as a top-level class with a fairly generic class name, such as "OS". This causes an issue specifically with kitchen-google which depends on a gem which depends on the "os" gem which itself defines an OS class with a different superclass. This prevents users from using TK, Google Compute, and Inspec without this fix. Some mocked commands had their digest changed as well due to the new indentation, specifically in the User and RegistryKey classes. I strongly recommend viewing this diff with `git diff --ignore-space-change` to see the *real* changes. :)
48 lines
1.1 KiB
Ruby
48 lines
1.1 KiB
Ruby
# encoding: utf-8
|
|
# author: Christoph Hartmann
|
|
# author: Dominik Richter
|
|
|
|
module Inspec::Resources
|
|
class NpmPackage < Inspec.resource(1)
|
|
name 'npm'
|
|
desc 'Use the npm InSpec audit resource to test if a global npm package is installed. npm is the the package manager for Nodejs packages, such as bower and StatsD.'
|
|
example "
|
|
describe npm('bower') do
|
|
it { should be_installed }
|
|
end
|
|
"
|
|
|
|
def initialize(package_name)
|
|
@package_name = package_name
|
|
@cache = nil
|
|
end
|
|
|
|
def info
|
|
return @info if defined?(@info)
|
|
|
|
cmd = inspec.command("npm ls -g --json #{@package_name}")
|
|
@info = {
|
|
name: @package_name,
|
|
type: 'npm',
|
|
installed: cmd.exit_status == 0,
|
|
}
|
|
return @info unless @info[:installed]
|
|
|
|
pkgs = JSON.parse(cmd.stdout)
|
|
@info[:version] = pkgs['dependencies'][@package_name]['version']
|
|
@info
|
|
end
|
|
|
|
def installed?
|
|
info[:installed] == true
|
|
end
|
|
|
|
def version
|
|
info[:version]
|
|
end
|
|
|
|
def to_s
|
|
"Npm Package #{@package_name}"
|
|
end
|
|
end
|
|
end
|