Skip to content
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

Feedback: 'NServiceBus sagas: Saga basics' #6894

Closed
BenHughesTPR opened this issue Nov 5, 2024 · 4 comments
Closed

Feedback: 'NServiceBus sagas: Saga basics' #6894

BenHughesTPR opened this issue Nov 5, 2024 · 4 comments
Assignees

Comments

@BenHughesTPR
Copy link

Feedback for 'NServiceBus sagas: Saga basics' https://docs.particular.net/tutorials/nservicebus-sagas/1-saga-basics/

Location in GitHub: https://github.com/Particular/docs.particular.net/blob/master/tutorials/nservicebus-sagas/1-saga-basics/tutorial.md

Naming convention of Policy is inconsistent with other documentation/examples: https://docs.particular.net/nservicebus/sagas/#a-simple-saga

@andreasohlund
Copy link
Member

Thanks for the feedback @BenHughesTPR

Docs like https://docs.particular.net/nservicebus/sagas/#a-simple-saga that speak about the feature itself, ie a "Saga" where the target audience is developers we want to be explicit and name things in a way that makes the most sense in that context, MySaga etc etc

In the tutorials, which are meant to be more like "real code in a business project" we tend to want to use names that are likely to be meaningful to the fictive business people. "Policies" is something that sagas are a great fit when it comes to implementation but when talking to the business the word "Saga" is likely not something they have in their vocabulary so talking about a ShippingPolicy vs a ShippingSaga would likely make it that conversation easier.

ShippingPolicySaga might be an option but I prefer the simpler name since that is what will show up in visualizations like the ServiceInsight saga view.

Also, the developers will still know it's a saga since ShippingPolicy implements Saga<T> when reading the code.

I know this is quite a bit of a personal opinion here, what do U think?

@BenHughesTPR
Copy link
Author

Hi Andreas, thanks for your response - I'm coming from the perspective of someone brand new to NServiceBus, so I'm working through each of the tutorials right now. I do like how opinionated NServiceBus is, but I think that comes with a real need for consistency, so seeing different naming in different places threw me off a bit.

I think the thing we're always striving for is that ubiquitous language that developers and business owners can speak, so my suggestion would be to maybe have a naming best practices section in the documentation here: https://docs.particular.net/nservicebus/sagas/#a-simple-saga. Then it could contain some guidance on when a saga is best called a policy or a workflow, or whatever language best captures the underlying business context.

@andreasohlund
Copy link
Member

That is a good idea, I have raised #6899 to capture this. Are there more things that comes to mind on top of the ones I have listed?

@andreasohlund andreasohlund self-assigned this Nov 6, 2024
@BenHughesTPR
Copy link
Author

Hi Andreas, nothing more from me for the time being - thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants