-
Notifications
You must be signed in to change notification settings - Fork 8
[Discussion] Test Scenario Runners #2
Comments
Could we use Consul's service segmentation to simulate network partitions? It would be nice when testing e.g. circuit relay to know that two nodes can't communicate directly and have that enforced by the test setup. |
YAML might be better suited, particularly for embedding snippets of stuff for other languages (bash etc.), keys, parts of scenarios etc., and the fact that humans will be writing these? As a potential writer of scenarios I'd expect to be able to describe: global_config:
# some stuff like run name, permissions, consul and coordinator service configurations etc.
nodes:
- num: 50
network: &nat # some nat nonsense
steps:
- &install |
go get dht
some_other_install
- |
generate_data
run_dht
metrics: # how to generate metrics
- num: 500
<<: *nat # run the same nat as the above guys
steps:
- *install
- |
run_dht_to_get_data
metrics: Probably some synchronization will be necessary so nodes are in expected states before certain steps run. Some variance between nodes might be necessary, for example exposing an instance ID as an environment variable or something so instances can deterministically generate random data/keys/peer IDs etc. Is this the kind of input you're after? |
@yusefnapora interesting idea! partitions are not yet on the roadmap, but would love some more ideas on that matter! |
@anacrolix yeah, this is absolutely lovely. i'm definitely a YAML fan, and it's a drop in replacement so i'm totally okay with that. as far as the "steps" go, i don't want to recreate docker, so i'd want to limit the instruction set to a well specified DSL. that's what i'm interested in establishing. my gut feeling is that for sake of learning what we want to do and getting something done quickly, we start by just exposing a programmatic API for controlling daemons via the control protocol. this API will include:
|
@yusefnapora @bigs just making sure you are aware the service segmentation is an enterprise feature of Consul and not a part of the open source version. Not saying it isn't worth paying for, just that we will have to pay. |
thanks! fortunately, we don’t need it to execute what we want.
…On Tue, Mar 12, 2019 at 03:13 Adrian Lanzafame ***@***.***> wrote:
@yusefnapora <https://github.com/yusefnapora> @bigs
<https://github.com/bigs> just making sure you are aware the service
segmentation is an enterprise feature of Consul and not a part of the open
source version. Not saying it isn't worth paying for, just that we will
have to pay.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#2 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AANBWileCOkK-lM27GKftSv4DXwOpMrXks5vV1ObgaJpZM4a0yky>
.
|
Test Scenario Runners
Scenarios encode behavior of nodes in the test network. These scenarios are analyzed via metrics output. How should they work?
Overview
At present, topologies are defined using a pretty simple JSON file. I'd like to extend these with a plugin for test scenarios. Scenarios control daemons via the control protocol, creating simulated work loads that we can then analyze via grafana, etc.
General implementation guidelines
There are two major pieces to this work.
Scenario Plugin
The testlab will have to be extended with a new plugin type that executes scenarios and populates their runtime environment with necessary information to discover the daemon network. This plugin will have to have a standardized environment that all scenarios can depend on to exist. It should probably include access to consul for service discovery and some sort of scoping to limit it to a subset of peers tagged with metadata.
Scenario Framework
Golang library that leverages the scenario plugin environment to power these scenarios. Open questions:
The text was updated successfully, but these errors were encountered: