Skip to main content

Managing Complexity

"The Data Access layer should be in its own project", was one of the points that I came across during a discussion with another architect from my team. The reasoning was that if it is separate, it wouldn't impact the service using it. While on the surface the logic seems sound, do we ever stop and think, hmm do we really need to introduce this complexity? How many times do we see us switching from SQL Server to Mongo DB? Is the additional complexity and work really worth it?

Software Developers, especially those from object oriented language background (C#, Java, etc.) tend to love complexity. I too have been guilty of the same. But recently I came across a tweet which made me pause and take notice.

One should always follow SOLID principles while developing but also keep in mind the practicalities of the situation. Not all of us are developing the next Netflix, mostly we are just putting data over text boxes.

Managing complexity and your itch to create a truly flexible software is a balancing act. My advice would to keep it simple and match your needs not some lofty version of ideal software that you have in mind.

Comments

Popular posts from this blog

Integrating React with SonarQube using Azure DevOps Pipelines

In the world of automation, code quality is of paramount importance. SonarQube and Azure DevOps are two tools which solve this problem in a continuous and automated way. They play well for a majority of languages and frameworks. However, to make the integration work for React applications still remains a challenge. In this post we will explore how we can integrate a React application to SonarQube using Azure DevOps pipelines to continuously build and assess code quality. Creating the React Application Let's start at the beginning. We will use npx to create a Typescript based React app. Why Typescript? I find it easier to work and more maintainable owing to its strongly-typed behavior. You can very well follow this guide for jsx based applications too. We will use the fantastic Create-React-App (CRA) tool to create a React application called ' sonar-azuredevops-app '. > npx create-react-app sonar-azuredevops-app --template typescript Once the project creation is done, we

Creating a Smart Playlist

A few days earlier I was thinking that wouldn't it be nice if I had something which will automatically generate a playlist for me with no artists repeated. Also, it would be nice if I could block those artists which I really hate (like Himesh Reshammiya!). Since I couldn't find anything already available, I decided to code it myself. Here is the outcome -  This application is created entirely in .NET Framework 4/WPF and uses Windows Media Player Library as its source of information. So you have to keep your Windows Media Player Library updated for this to work. It is tested only on Windows 7/Vista. You can download it from here . UPDATE : You can download the Windows XP version of the application here . Please provide your feedback!

Bhagavad Gita Reader

Few days ago I had a heated argument with my friend about religion. Still fresh from watching " Religulous ", I was countering his every argument. Fed up, he asked me to read Bhagavad Gita and then tell him if I find anything wrong with it. Faced with the prospect of reading a book running into hundreds of pages, I asked him to keep it cool and let it go. He anyways went ahead and gifted me the holy book. Now I don't have the patience or passion to read such a thick religious book (yeah go ahead, judge me), I was thinking of a shortcut. That's when the idea of Bhagavad Gita Reader came into my mind. Snapshot - (Click for a larger view) This application divides Bhagavad Gita into chapters and verses. Then each verse and its translation is shown. There are no extra "interpretations to clutter up your mind." This application is built on WPF/.NET 4.0 with MVVM Light framework - A great framework with a very small learning curve as compared to Prism  albeit