inspec/test/unit/plugin/v2/api_base_test.rb

98 lines
3.9 KiB
Ruby
Raw Normal View History

require "minitest/autorun"
require_relative "../../../../lib/inspec/plugin/v2"
class PluginV2VersionedApiTests < Minitest::Test
# you can call Inspec.plugin(2) and get the plugin base class
def test_calling_Inspec_dot_plugin_with_2_returns_the_plugin_base_class
klass = Inspec.plugin(2)
assert_kind_of Class, klass
assert_equal "Inspec::Plugin::V2::PluginBase", klass.name
end
def test_calling_Inspec_dot_plugin_with_2_and_mock_plugin_returns_the_mock_plugin_base_class
klass = Inspec.plugin(2, :mock_plugin_type)
assert_kind_of Class, klass, "2-arg form of Inspec.plugin() should return a specific plugin type base class"
assert_equal "Inspec::Plugin::V2::PluginType::Mock", klass.name
end
end
class PluginV2BaseMgmtMethods < Minitest::Test
def test_plugin_v2_management_class_methods_present
%i{
base_class_for_type
find_name_by_implementation_class
registry
register_plugin_type
plugin_name
}.each do |method_name|
klass = Inspec::Plugin::V2::PluginBase
assert_respond_to klass, method_name, "Base class plugin management class method: #{method_name}"
end
end
def test_plugin_type_base_classes_can_be_accessed_by_name
klass = Inspec::Plugin::V2::PluginBase.base_class_for_type(:mock_plugin_type)
assert_kind_of Class, klass, "base_class_for_type should work for mock_plugin_type"
assert_equal "Inspec::Plugin::V2::PluginType::Mock", klass.name
end
end
class PluginV2BaseDslMethods < Minitest::Test
def test_plugin_v2_dsl_methods_present
[
:plugin_name,
:mock_plugin_type,
# [ :input_provider, :platform, :fetcher, :source_reader, :reporter ]
].each do |method_name|
klass = Inspec::Plugin::V2::PluginBase
assert_respond_to klass, method_name, "Plugin DSL methods"
end
end
def test_when_calling_plugin_name_the_plugin_is_registered
test_plugin_name = :dsl_plugin_name_test
reg = Inspec::Plugin::V2::Registry.instance
reg.__reset
refute reg.known_plugin?(test_plugin_name), "should not know plugin name in advance"
assert_equal 0, reg.loaded_count, "Should start with no plugins loaded"
assert_equal 0, reg.known_count, "Should start with no plugins known"
assert_raises(Inspec::Plugin::V2::LoadError, "plugin definitions must include the plugin_name call") do
# Make a plugin class, including calling the plugin type DSL definition method, but do not call plugin_name
Class.new(Inspec.plugin(2)) do
# Plugin class body
mock_plugin_type :dsl_plugin_name_test do
Class.new(Inspec.plugin(2, :mock_plugin_type))
end
end
end
refute reg.known_plugin?(test_plugin_name), "failing to load a nameless plugin should not somehow register the plugin"
assert_equal 0, reg.loaded_count, "Should have no plugins loaded after failing to load a nameless plugin"
assert_equal 0, reg.known_count, "Should have no plugins known after failing to load a nameless plugin"
# Now create another plugin class, but this time *do* call plugin_name
name_provided_class = Class.new(Inspec.plugin(2)) do
# Plugin class body
plugin_name :dsl_plugin_name_test
mock_plugin_type :dsl_plugin_name_test do
Class.new(Inspec.plugin(2, :mock_plugin_type))
end
end
assert reg.known_plugin?(test_plugin_name), "plugin name should register the plugin"
assert_equal 0, reg.loaded_count, "plugin_name should not load the plugin"
assert_equal 1, reg.known_count, "plugin_name should cause one plugin to be known"
status = reg[test_plugin_name]
assert_equal name_provided_class, status.plugin_class
assert_equal 2, status.api_generation
assert_includes status.plugin_types, :mock_plugin_type
end
def test_plugin_type_registers_an_activation_dsl_method
klass = Inspec::Plugin::V2::PluginBase
assert_respond_to klass, :mock_plugin_type, "Activation method for mock_plugin_type"
end
end