Skip to content

Commit

Permalink
Add CapabilityConfig resource methods
Browse files Browse the repository at this point in the history
Convinient methods to get the CapabilityConfig instance
of a given resource
  • Loading branch information
atd committed Dec 24, 2024
1 parent d74e579 commit 379f36a
Show file tree
Hide file tree
Showing 3 changed files with 76 additions and 1 deletion.
20 changes: 20 additions & 0 deletions lib/resource_registry/capabilities/capability_config.rb
Original file line number Diff line number Diff line change
Expand Up @@ -14,13 +14,33 @@ module CapabilityConfig
# Class methods interface for capability configuration
module ClassMethods
extend T::Sig
extend T::Generic
extend T::Helpers
abstract!

has_attached_class!

# The key of the capability, this key will be used to take it from yaml configuration
sig { abstract.returns(Symbol) }
def key
end

sig { params(resource: Resource).returns(T::Boolean) }
def resource_capability?(resource:)
resource.capabilities.key?(key)
end

sig { params(resource: Resource).returns(T.nilable(T.attached_class))}
def resource_capability(resource:)
return unless resource_capability?(resource:)

T.cast(resource.capabilities[key], self)
end

sig { params(resource: Resource).returns(T.attached_class)}
def resource_capability!(resource:)
T.must(resource_capability(resource: ))
end
end

requires_ancestor { Object }
Expand Down
2 changes: 1 addition & 1 deletion lib/resource_registry/resource.rb
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,7 @@ def build_dto(verb, **parameters)
T::Class[T.type_parameter(:CapabilityConfig)],
# Referencing `ClassMethods` here is not ideal but it seems Sorbet
# provides no other mechanism to do this
Capabilities::CapabilityConfig::ClassMethods,
Capabilities::CapabilityConfig::ClassMethods[T.untyped],
T::Class[Capabilities::CapabilityConfig]
)
)
Expand Down
55 changes: 55 additions & 0 deletions spec/resource_registry/capabilities/capability_config_spec.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
# typed: false

require "spec_helper"
require_relative "../../../lib/resource_registry/capabilities/capability_config"

class DummyCapability < T::Struct
include ResourceRegistry::Capabilities::CapabilityConfig

def self.key
:dummy_capability
end
end

RSpec.describe ResourceRegistry::Capabilities::CapabilityConfig do
let(:schema) do
SchemaRegistry::Schema.new(
name: "dummy",
namespace: "dummies",
properties: [
SchemaRegistry::Property.new(
name: "foo",
types: [SchemaRegistry::PropertyType::String],
required: true
)
]
)
end
let(:capabilities) { { dummy_capability: DummyCapability.new } }
let(:resource) do
ResourceRegistry::Resource.new(
repository_raw: DummyRepo.to_s,
capabilities:,
verbs: {
},
schema:
)
end

it "should return resource's capability" do
expect(DummyCapability.resource_capability?(resource:)).to be true
expect(DummyCapability.resource_capability(resource:)).to be_a(DummyCapability)
expect(DummyCapability.resource_capability!(resource:)).to be_a(DummyCapability)
end

context 'without the capability' do
let(:capabilities) { {} }

it "should return resource's capability" do
expect(DummyCapability.resource_capability?(resource:)).to be false
expect(DummyCapability.resource_capability(resource:)).to be_nil
end
end
end


0 comments on commit 379f36a

Please sign in to comment.