-
Notifications
You must be signed in to change notification settings - Fork 130
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
[Workflow] More workflow SDK examples #575
Conversation
Signed-off-by: Chris Gillum <[email protected]>
@berndverst when you're back from vacation, I was hoping you can help provide me guidance on this PR. A couple initial questions I have:
Any guidance from a Python contributor would be appreciated. |
Codecov ReportAll modified lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #575 +/- ##
=======================================
Coverage 86.40% 86.40%
=======================================
Files 74 74
Lines 3605 3605
=======================================
Hits 3115 3115
Misses 490 490 ☔ View full report in Codecov by Sentry. |
The primary purpose of the Ideally you just expand the existing Another option is to add new example folders, but we would not add these to be run as integration tests. The downside there is that we'd have no way to ensure we don't break these examples in the future - and nobody will be manually running the examples as part of the release process (we do not need manual verification today and we don't want to be adding such a step). Perhaps that is ok. I think what I would like to see in this PR is for your "examples" to be actually used in an end to end scenario that is run via mechanical-markdown. @RyanLettieri and @DeepanshuA can help you here as they have gone through this exercise recently for workflows. EDIT: If the goal is for the example to be essentially documentation, please move this to https://github.com/dapr/python-sdk/tree/master/daprdocs/content/en/python-sdk-docs/python-sdk-extensions instead. |
@cgillum or a completely different idea: This is what powers the docs here: In that case the code should not be in the |
@cgillum friendly bump |
This pull request has been automatically marked as stale because it has not had activity in the last 60 days. It will be closed in 7 days if no further activity occurs. Please feel free to give a status update now, ping for review, or re-open when it's ready. Thank you for your contributions! |
This pull request has been automatically closed because it has not had activity in the last 67 days. Please feel free to give a status update now, ping for review, or re-open when it's ready. Thank you for your contributions! |
@berndverst sorry for letting this PR go stale. I ended up going on vacation and didn't get around to picking this back up until now. Would you mind reopening this PR so that I can complete it? My hope was to have some automated testing of these snippets so that we can be confident that the patterns in the doc article I linked to is always known to be working. With that in mind, I think the mechanical markdown option might make the most sense. I assume that content under daprdocs/content/en/python-sdk-docs/python-sdk-extensions would not have any automatic validation? |
As discussed in chat, feel free to add examples to the Here is where the examples run on CI are defined. You can either leave We can later ensure the other examples are run on a scheduled basis, and maybe also via a slash command like |
By the way, if you do want an example to be run automatically via our mechanical markdown tool - you need to create a README.md -- and add the right metadata. Check out some of our other examples and read about it: https://github.com/dapr/mechanical-markdown |
Signed-off-by: Chris Gillum <[email protected]>
Signed-off-by: Chris Gillum <[email protected]>
I went ahead and moved the samples to live under the workflow extension directory. I'm keeping the existing examples directory untouched. However, I didn't go as far as to enable mechanical markdown on the new examples since I'm not confident that it can support the interactive nature of two of the examples (I didn't do the research to confirm this yet). We'll need to eventually come up with a plan for how to keep these examples up to date, but they won't impact the existing CI. |
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 don't think anyone will look for the example in this folder.
And if we ever want to run automatic validation of the example in the future we currently need it to be a subfolder of the main examples
folder at the root level anyway.
If you want to keep it here - we can change that in the future. But for now you'd at least need to update the Readme at the root to point someone to this.
Can you move the contents of this examples
folder to a new folder under examples
? (As a sibling folder of demo-workflow
)
And since I see you added mechanical markdown annotations - did you ever verify this example runs with mechnical markdown?
pip3 install -r mechanical-markdown
then from the folder that has your new example mm.py Readme.md
.
Signed-off-by: Chris Gillum <[email protected]>
@berndverst I went ahead and moved these back under the root examples directory per your suggestion. The README.md doesn't have any mechanical markdown currently. I can add it, but there are a couple challenges:
Let me know if I should revisit this for this PR. If MM can handle validation via regex expressions, then we can at least automate the first two examples. |
Merging this, with the expectation that these tests will not be runnable by any automation. We will also not be manually validating these examples for future releases (that's why we have automation to begin with). In the future you might want to move the critical features you wish to verify into a single example to be run by CI/CD as validation. For now this is fine to merge. |
Description
I've added several Python examples that correspond to the code snippets in the following documentation page: https://docs.dapr.io/developing-applications/building-blocks/workflow/workflow-patterns/
Issue reference
Related to dapr/docs#3496
Checklist
Please make sure you've completed the relevant tasks for this PR, out of the following list: