-
Notifications
You must be signed in to change notification settings - Fork 22
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
docs: [FC-0074] add docs about creating and consuming events #439
Conversation
Thanks for the pull request, @mariajgrimaldi! This repository is currently maintained by @openedx/hooks-extension-framework. Once you've gone through the following steps feel free to tag them in a comment and let them know that your changes are ready for engineering review.
|
13cbe55
to
29c4c3a
Compare
9b5a636
to
992e7a2
Compare
+-------------------+----------------------------------------------------------------------------------------------------+ | ||
| Learning | Allows learners to consume content and perform actions in a learning activity on the platform. | | ||
+-------------------+----------------------------------------------------------------------------------------------------+ | ||
| Analytics | Provides insights into learner behavior and course performance. | |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think I commented this on a previous PR, but I'd avoid use of the term "insights" here so it's not confused with the Insights deprecated service.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for raising this. I used "visibility" instead.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I only have a few suggestions. The rest looks good.
Thanks for this PR @mariajgrimaldi
docs/how-tos/consume-an-event.rst
Outdated
|
||
- You have a development environment set up using `Tutor`_. | ||
- You have a basic understanding of Python and Django. | ||
- You have created a new Open edX event. If not, you can follow the :doc:`../how-tos/create-a-new-event` guide to create a new event. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We may want to edit this part because we don't need a new event to consume events.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for noticing! 7980afc
docs/how-tos/consume-an-event.rst
Outdated
- In the test suite, you can use the ``send_event`` method to trigger the event and pass the necessary data to the event receiver. In this case, we are passing the user, course and enrollment data to the event receiver as the triggering logic would do. | ||
- After triggering the event, you can assert that the event receiver executed the custom logic as expected. In this case, we are checking that the request was sent to the webhook with the correct data. | ||
|
||
You can review this example to understand how you can test the event receiver and ensure that the custom logic is executed when the event is triggered in the openedx-events-2-zapier plugin. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You can review this example to understand how you can test the event receiver and ensure that the custom logic is executed when the event is triggered in the openedx-events-2-zapier plugin. | |
You can review this example to understand how you can test the event receiver and ensure that the custom logic is executed when the event is triggered in the openedx-events-2-zapier_ plugin. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed, thank you! bdccd4c
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me, made a couple comments, good to merge when you're satisfied.
enrollment=enrollment_data | ||
) | ||
|
||
# Assert that the request was sent to the webhook with the correct data |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Are you missing an assert statement here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The assert of the output data is long, so I left it out and mentioned reviewing the repo directly in L123.
docs/how-tos/consume-an-event.rst
Outdated
|
||
These event receivers are usually implemented independently of the service in an `Open edX Django plugins`_ and are registered in the ``handlers.py`` (according to `OEP-49`_) file of the plugin. You can review the ``handlers.py`` file of the `openedx-events-2-zapier`_ plugin to understand how the event receivers are implemented and connected to the events. | ||
|
||
.. TODO: change receivers.py in openedx-events-2-zapier to handlers.py |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should this be done before the PR merges?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not necessarily. I still have some work to do on the repo so I'll do it then. I'll drop the comment for now, thanks!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for addressing my feedback. After addressing the feedback left, this is ready to go.
Thanks @mariajgrimaldi ✨
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this is fantastic work. I left a minor question but definitely not a blocker.
This PR shows an impressive amount of effort and attention put into it.
Merge when you are ready.
docs/how-tos/create-a-new-event.rst
Outdated
- The event should be an instance of the ``OpenEdxPublicSignal`` class to ensure that the event is consistent with the Open edX event framework. | ||
- Receivers should be able to access the event payload in their receivers to react to the event. | ||
|
||
.. TODO: add reference to how to add event bus support to the event's payload |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
do we have any link already that we could write in? even if it is a PR where this is being written it would point readers in the right direction. If nothing is available, would you consider removing this comment?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here's the PR for the how-to add event bus support for an event: #428. I'm hoping it gets merged soon so we can reference it here before merging.
Co-authored-by: Sarina Canelake <[email protected]>
915011f
to
00a8d3f
Compare
Hey, this PR broke the docs build. https://readthedocs.org/projects/docsopenedxorg/builds/26859007/ |
I'll look into it @sarina. Thanks! |
Description
Update how-to documents to create and consume a new event considering design suggestions introduced in #438 and old docs as well.
Here are the main documents to review:
The other changes are improvements to the current docs:
Supporting information
Addresses #360 #362
Testing instructions
Deadline
None
Other information
Depends on feedback on #438
Checklists
Check off if complete or not applicable:
Merge Checklist:
Post Merge:
finished.