You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
In Scenario 7.0, this has been removed: firstly because we got rid of the 'stringly-typed' events, and, more significantly, because we felt that the level of abstraction for Scenario is at the "Juju event". The intention was that people would run the Juju event that would cause the custom event to be emitted, e.g. ctx.on.relation_changed() might end up causing a DatabaseCreated event to be emitted.
our charm unit tests shouldn't know about library specificities. Our charm does not look into the relation databags, it only interfaces with the library. Taking the approach you are proposing entails our charm unit test to replicate the behavior of libraries that we don't have ownership over.
I feel like the charm author probably does need to know which Juju events will cause the custom events to be able to manually use the charm and to be able to write integration tests, and that you shouldn't need to manage the relation databags.
However, there are potentially many events and you have to know which ones might be triggered for what's happening. For example, with the data_platform DatabaseRequires class from data-platform-libs, it probably needs something like:
deftest_credentials():
ctx=Context(DemoAPICharm)
db_rel=Relation("database")
container=Container("webapp", can_connect=True)
state=State(relations={db_rel})
state=ctx.run(ctx.on.relation_created(), state)
state=ctx.run(ctx.on.relation_joined(), state)
state=ctx.run(ctx.on.relation_changed(), state)
state=ctx.run(ctx.on.secret_changed(), state)
assertstate.get_container("webapp")... # check that the config file is there or whatever
Maybe tests that rely on custom events should be Catan tests? I think what I want to be testing is that when I integrate the two charms the state of the charm I'm writing ends up the way I expect.
However, maybe we should add back some way to run custom events explicitly. @gruyaume also needed the ability to provide custom arguments for creating the event, which Scenario 6 can't do.
custom_event would be a static method on CharmEvents with a signature like (attribute: str, *args, **kwargs) and it would pass *args and **kwargs through to the custom event class.
The text was updated successfully, but these errors were encountered:
Scenario 7 provided a way for charm libs to provide Scenario extensions, or maybe pytest fixtures that encapsulate the library API that's exposed to the charm?
I feel that test doubles for custom events fit squarely there.
P.S. perhaps two things/approaches could be offered:
a lib mock that charm under test interacts with under Scenario
a lib double that creates batches of events that charm+lib under test process under Catan
Scenario 7 provided a way for charm libs to provide Scenario extensions, or maybe pytest fixtures that encapsulate the library API that's exposed to the charm?
Yeah, doing something like this had crossed my mind too, although there's a lot more to figure out, and then a bunch of buy-in needed.
In Scenario 6, it's possible to run custom events:
In Scenario 7.0, this has been removed: firstly because we got rid of the 'stringly-typed' events, and, more significantly, because we felt that the level of abstraction for Scenario is at the "Juju event". The intention was that people would run the Juju event that would cause the custom event to be emitted, e.g.
ctx.on.relation_changed()
might end up causing aDatabaseCreated
event to be emitted.@gruyaume pushed back on this:
I feel like the charm author probably does need to know which Juju events will cause the custom events to be able to manually use the charm and to be able to write integration tests, and that you shouldn't need to manage the relation databags.
However, there are potentially many events and you have to know which ones might be triggered for what's happening. For example, with the data_platform
DatabaseRequires
class from data-platform-libs, it probably needs something like:Maybe tests that rely on custom events should be Catan tests? I think what I want to be testing is that when I integrate the two charms the state of the charm I'm writing ends up the way I expect.
However, maybe we should add back some way to run custom events explicitly. @gruyaume also needed the ability to provide custom arguments for creating the event, which Scenario 6 can't do.
Maybe this looks like this?
custom_event
would be a static method onCharmEvents
with a signature like(attribute: str, *args, **kwargs)
and it would pass*args
and**kwargs
through to the custom event class.The text was updated successfully, but these errors were encountered: