Want to dive right in? Here's the GitHub Link: https://github.com/DataRPM-Labs/sigma
Reusability, Extensibility, Scalability and Maintainability (RESM) are the key principles of Software Programming. Design Patterns and Guidelines help us to achieve the best practices in programming. However, when it comes to ensuring and maintaining a consistent pattern of programming standards across multiple teams of developers contributing towards a product or a set of products in an organisation, it is still a significant challenge.
To meet the fast-changing market demands and to reap the benefits of continuous development and delivery, most of the product development happens as an iterative process. We first work on the MVP and then extend and continue to enhance and extend on top of that. It requires a good amount of experience to foresee this and allow the scope of extension hooks in the design while implementing any functionality.
If these extension needs are not thought through and planned ahead of time, teams end up writing code that deviates design principles and soon the code becomes an unmaintainable myriad of if/else loops and so on.
Moreover, every individual in a team comes from different programming backgrounds and usually follow their preferred way of coding, especially in modularizing and structuring the code, which also plays a significant role in ending up with a non-uniform code base. Programming frameworks do help to minimise these variations but still a lot depends on a developer’s individual programming style, which makes it difficult for new developers to get ramped up quickly and be productive fast.
A workflow-based development approach in such situations helps tremendously to bring in natural extension points during an implementation, reducing the need to think a great deal about future requirements, as well as to establish a coding approach that can help standardise coding across the board with a very clear readability. We have already seen this being successfully applied to business processes to achieve RESM.
A workflow-based approach makes it very easy to define & edit primary process flows #Opensource (tweet this)
Applying the same concepts we have created Sigma – The Micro Workflow for Java Programmers, which provides the same flexibility without adding any additional external dependencies. Here are the essential characteristics of Sigma:
Some of the key Features are listed below:
How to use it:
Let’s consider a user registration flow to an application. Below is the desired expectation of the flow when a user submits the Registration form.
4. On Failure —
1. Send an alert to Support team and Send back helpline number back to the caller.
If you want to implement this using Sigma here is what you have to do:
UserRegistrationRequest.java –
@WorkflowRequest
@Context(name = UserRegistrationContext.class)
@Flows(flows = { @Flow(simple = @States(names = { MandatoryFieldValidation.class, UserCreationAPICall.class})),
@Flow(conditional = {
@ConditionalFlow(exp = “context.isUserApiCallStatus() == true”, states = {
CreateDefaultProfile.class,SendVerificationEmail.class
})}),
@Flow(conditional = {
@ConditionalFlow(exp = “context.isUserApiCallStatus() == false”, states = {
SendAlertToSupport.class
})})
})
public class UserRegistrationRequest {
private String userid;
private String password;
private String email;
private String address; // This can be another pojo
private boolean apiSuccessFlag;
/* Removed getters and setter from here for simplicity. You can find the working version under testcases */
}
public class UserRegistrationContext extends WorkflowContext<UserRegistrationRequest>{
private boolean userApiCallStatus;
private String userProfileId;
/* Removed getters and setter from here for simplicity. You can find the working version under testcases */
}
public class MandatoryFieldValidation implements WorkflowState<UserRegistrationRequest, UserRegistrationContext>{
@Override
public void execute(UserRegistrationContext context) throws WorkflowStateException {
UserRegistrationRequest request = context.getRequest();
// Logic to validate attributes
System.out.println(“-Executing—” + this.getClass().getName());
}
}
How to Call Execute → This is how you execute the workflow.
@Test
public void runUserRegistrationFlowWithAPISuccess () {
UserRegistrationRequest request = new UserRegistrationRequest(“user123”, “passxyz”, “user@user.com”, “Address 123”);
request.setApiSuccessFlag(true);
try {
UserRegistrationContext workflowContext = (UserRegistrationContext) new WorkflowEngine()
.execute(request);
assertTrue(workflowContext.isSuccess());
System.out.println(“Print–User Profile Id–” + workflowContext.getUserProfileId());
assertTrue(workflowContext.getUserProfileId() != null);
} catch (WorkflowExecutionException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
What do you gain by using Sigma?
GitHub Link: https://github.com/DataRPM-Labs/sigma
Subscribe to get all the news, info and tutorials you need to build better business apps and sites