Class: ConfigurationService::Test::Orchestrator
- Inherits:
-
Object
- Object
- ConfigurationService::Test::Orchestrator
- Defined in:
- lib/configuration_service/test/orchestrator.rb
Overview
The declarative test orchestration API
This is the declarative API that describes what must be done to test a configuration service provider. It catalogues all the services that the cucumber step definitions expect from a test orchestration provider.
It keeps no domain state, because that would couple it to the service implementation. By making no assumptions at all about the API or data, it allows implementors to produce service implementations that do not adhere to the anticipated ConfigurationService::Base API, by writing their own OrchestrationProvider from scratch.
However, implementors who are trying to produce ConfigurationService::Base providers should extend OrchestrationProvider, which anticipates a compatible provider API.
Note that the response instance variable is not domain state; it is a test artifact (Response or similar) that orchestration providers use to wrap responses from the service provider.
Instance Method Summary collapse
-
#authorize(activity) ⇒ Object
Authorize the next consuming or publishing operation for
activity. -
#bootstrap_configuration_service_environmentally ⇒ Object
Bootstrap a configuration service environmentally.
-
#bootstrapped_configuration_service_functional? ⇒ Boolean
Tests that a bootstrapped configuration service is functional.
-
#deauthorize ⇒ Object
Remove any previous authorization.
-
#environmental_service_configuration_scrubbed? ⇒ Boolean
Tests that environmental service configuration is scrubbed.
-
#existing_configuration ⇒ Object
Return a published configuration fixture.
-
#existing_revision ⇒ Object
Return the revision of a published configuration fixture.
-
#given_environmental_service_configuration ⇒ Object
Arrange environmental service configuration.
-
#given_existing_configuration ⇒ Object
Arrange a published configuration fixture.
-
#given_invalid_configuration ⇒ Object
Use invalid configuration data in the next publishing operation.
-
#given_metadata ⇒ Object
Include metadata in the next publishing operation.
-
#given_missing_configuration ⇒ Object
Delete any existing configuration.
-
#given_publication_failure ⇒ Object
Arrange for the next publication operation to fail.
-
#given_request_failure ⇒ Object
Arrange for the next consuming operation to fail.
-
#initialize(provider_class) ⇒ Orchestrator
constructor
Return a new orchestrator initialized with a new instance of
provider_class. -
#publish_configuration ⇒ Object
Perform a publishing operation against the service under test.
-
#published_configuration ⇒ Object
(also: #requested_configuration)
The last published or consumed configuration data.
-
#published_metadata ⇒ Object
The last published metadata.
-
#published_revision ⇒ Object
The revision of the last published or consumed configuration.
-
#request_allowed? ⇒ Boolean
True if the last consuming or publishing operation was allowed.
-
#request_configuration ⇒ Object
Perform a consuming operation against the service under test.
-
#request_failed? ⇒ Boolean
True if the last consuming or publishing operation failed.
-
#request_not_found? ⇒ Boolean
True if the last consuming operation did not return data.
-
#request_not_matched? ⇒ Boolean
True if the last consuming operation did not return data.
Constructor Details
#initialize(provider_class) ⇒ Orchestrator
Return a new orchestrator initialized with a new instance of provider_class.
The provider is expected to use a consistent configuration identifier for all publishing and consuming operations.
36 37 38 |
# File 'lib/configuration_service/test/orchestrator.rb', line 36 def initialize(provider_class) @provider = provider_class.new end |
Instance Method Details
#authorize(activity) ⇒ Object
Authorize the next consuming or publishing operation for activity
Valid activities (as per ACTIVITY_ROLE_MAP in ConfigurationService::Test::OrchestrationProvider) are:
-
:requesting_configurations -
:publishing_configurations -
:nothing
Where possible, the orchestration provider should authorize :nothing by providing valid credentials that don’t allow operations on the configuration identifier that it tests against.
103 104 105 106 |
# File 'lib/configuration_service/test/orchestrator.rb', line 103 def (activity) role = role_for(activity) or raise "unknown authorizable activity #{activity.inspect}" @provider.(role) end |
#bootstrap_configuration_service_environmentally ⇒ Object
Bootstrap a configuration service environmentally
Environmental service configuration (as arranged by #given_environmental_service_configuration) is given to an EnvironmentContext factory to create a service configuration instance.
TODO This method is imperative
236 237 238 239 |
# File 'lib/configuration_service/test/orchestrator.rb', line 236 def bootstrap_configuration_service_environmentally factory = ConfigurationService::Factory::EnvironmentContext.new(@env, "CFGSRV") @service = factory.create end |
#bootstrapped_configuration_service_functional? ⇒ Boolean
Tests that a bootstrapped configuration service is functional
TODO This method is imperative
246 247 248 249 250 251 252 253 |
# File 'lib/configuration_service/test/orchestrator.rb', line 246 def bootstrapped_configuration_service_functional? response = begin ConfigurationService::Test::Response::Success.new(@service.request_configuration) rescue ConfigurationService::Error => e ConfigurationService::Test::Response::Failure.new(e) end !response.failed? end |
#deauthorize ⇒ Object
Remove any previous authorization
E.g. as arranged by #authorize.
113 114 115 |
# File 'lib/configuration_service/test/orchestrator.rb', line 113 def @provider. end |
#environmental_service_configuration_scrubbed? ⇒ Boolean
Tests that environmental service configuration is scrubbed
TODO This method is imperative
260 261 262 |
# File 'lib/configuration_service/test/orchestrator.rb', line 260 def environmental_service_configuration_scrubbed? !@env.include?("CFGSRV_TOKEN") end |
#existing_configuration ⇒ Object
Return a published configuration fixture
E.g. as arranged by #given_existing_configuration.
TODO remove; step definitions expect this to be Comparable
75 76 77 |
# File 'lib/configuration_service/test/orchestrator.rb', line 75 def existing_configuration @provider.existing_configuration end |
#existing_revision ⇒ Object
Return the revision of a published configuration fixture
E.g. as arranged by #given_existing_configuration.
TODO remove; step definitions expect this to be Comparable
86 87 88 |
# File 'lib/configuration_service/test/orchestrator.rb', line 86 def existing_revision @provider.existing_revision end |
#given_environmental_service_configuration ⇒ Object
Arrange environmental service configuration
Environmental service configuration is configuration for bootstrapping a configuration service and provider.
TODO This method is imperative
215 216 217 218 219 220 221 222 223 224 225 |
# File 'lib/configuration_service/test/orchestrator.rb', line 215 def given_environmental_service_configuration sp_env = @provider.service_provider_configuration.inject({}) do |m, (k, v)| m["CFGSRV_PROVIDER_#{k.to_s.upcase}"] = v m end @env = { "CFGSRV_IDENTIFIER" => "acme", "CFGSRV_TOKEN" => "ea81cbfb-221c-41ad-826e-d3eff6342345", "CFGSRV_PROVIDER" => @provider.service_provider_id, }.merge(sp_env) end |
#given_existing_configuration ⇒ Object
Arrange a published configuration fixture
50 51 52 |
# File 'lib/configuration_service/test/orchestrator.rb', line 50 def given_existing_configuration @provider.given_existing_configuration end |
#given_invalid_configuration ⇒ Object
Use invalid configuration data in the next publishing operation
57 58 59 |
# File 'lib/configuration_service/test/orchestrator.rb', line 57 def given_invalid_configuration @provider.given_invalid_configuration end |
#given_metadata ⇒ Object
Include metadata in the next publishing operation
43 44 45 |
# File 'lib/configuration_service/test/orchestrator.rb', line 43 def @provider. end |
#given_missing_configuration ⇒ Object
Delete any existing configuration
64 65 66 |
# File 'lib/configuration_service/test/orchestrator.rb', line 64 def given_missing_configuration @provider.given_missing_configuration end |
#given_publication_failure ⇒ Object
Arrange for the next publication operation to fail
196 197 198 |
# File 'lib/configuration_service/test/orchestrator.rb', line 196 def given_publication_failure @provider.fail_next_request end |
#given_request_failure ⇒ Object
Arrange for the next consuming operation to fail
203 204 205 |
# File 'lib/configuration_service/test/orchestrator.rb', line 203 def given_request_failure @provider.fail_next_request end |
#publish_configuration ⇒ Object
Perform a publishing operation against the service under test
The provider is expected to wrap the response in a Response (or simimlar) and return that.
133 134 135 |
# File 'lib/configuration_service/test/orchestrator.rb', line 133 def publish_configuration @response = @provider.publish_configuration end |
#published_configuration ⇒ Object Also known as: requested_configuration
The last published or consumed configuration data
Note that this is the data itself, not a Configuration object.
174 175 176 |
# File 'lib/configuration_service/test/orchestrator.rb', line 174 def published_configuration @response.data end |
#published_metadata ⇒ Object
The last published metadata
189 190 191 |
# File 'lib/configuration_service/test/orchestrator.rb', line 189 def @response. end |
#published_revision ⇒ Object
The revision of the last published or consumed configuration
182 183 184 |
# File 'lib/configuration_service/test/orchestrator.rb', line 182 def published_revision @response.revision end |
#request_allowed? ⇒ Boolean
True if the last consuming or publishing operation was allowed
140 141 142 |
# File 'lib/configuration_service/test/orchestrator.rb', line 140 def request_allowed? @response.allowed? end |
#request_configuration ⇒ Object
Perform a consuming operation against the service under test
The provider is expected to wrap the response in a Response (or simimlar) and return that.
123 124 125 |
# File 'lib/configuration_service/test/orchestrator.rb', line 123 def request_configuration @response = @provider.request_configuration end |
#request_failed? ⇒ Boolean
True if the last consuming or publishing operation failed
Operations that were not allowed (as per #request_allowed?) or considered failed.
150 151 152 |
# File 'lib/configuration_service/test/orchestrator.rb', line 150 def request_failed? @response.failed? end |
#request_not_found? ⇒ Boolean
True if the last consuming operation did not return data
157 158 159 |
# File 'lib/configuration_service/test/orchestrator.rb', line 157 def request_not_found? not @response.found? end |
#request_not_matched? ⇒ Boolean
True if the last consuming operation did not return data
TODO: distinguish #request_not_matched? to mean “found data, but filtered out by metadata filter”
165 166 167 |
# File 'lib/configuration_service/test/orchestrator.rb', line 165 def request_not_matched? not @response.found? end |