Skip to main content

Posts

Showing posts from 2017

Anti-Lean Quotes

Set of quotes which usually highlights Anti-Lean behavior Create waste instead of Eliminate waste ' Developer who is not working at least on 4 projects is not properly utilized ' - less is definitely more and only done-done work counts by end of the day, limited work in progress is helping to focus on right priorities ' In case of any network issues please create a ticket on the help desk system at our partner's web-page' - creating catch 22 situations by design is craziness, such a process does not make any sense 'Yes, this is what our customers really need but could we add also this small feature, just in the case?' - extra feature creates an extra complexity, it is better to stay focused on real value and make it great for the users ' I know that you are working on the top priority but I am sure that you can do also this small task till noon' - probably there will be nothing really done by noon, task switching is more expensiv...

What to expect from devops

Build smart automation automate everything and everywhere implement clever monitoring  in case of a failure automatically fall back into the previous working state Enable continues development give all developers easy and simple way how to do continues development without compromises build support for step-by-step deployment and A/B testing deliver production-like environment runnable on developer's workstation  Rule the cloud deeply understand cloud technology code scalable infrastructure for actual and future needs enforce optimal security model Be step ahead always think one step in future about necessary improvements constantly identify bottlenecks and limits of current production system with possible solutions  apply agile and lean principles 

Toyota Production System and Agile Software Development

Andon Board : The facility for workers to signal problems to supervisors for immediate remedy, stopping the production process if necessary. Workstations along the production line can activate a warning on an illuminated central display board, which constantly displays productivity levels. =>  SCRUM/Kanban board + CI/CD automation Asa-ichi Meeting : A meeting held every morning in Toyota plants to discuss quality deviations and eliminate their causes. An essential part of the practice of kaizen. => Daily stand up Genchi Genbutsu: Going to the source to find the facts to make correct decisions, build consensus and achieve goals. => Retrospective (Root Cause Analysis) + face2face communication Heijunka: Leveling the production schedule in both volume and variety. A precondition for just-in-time and elimination of mura, muri and muda. => Velocity + self-organization + sustainable development Jidoka : Making problems visible so that they can be ...

Learn-Refactor-Measure

"... if I knew this a year ago I would did it better" This is a typical reaction when you learn something new and you are automatically applying it on stuff you did in past. The crucial question is: Should I go back and make it better or just let it go like it is? In software engineering it is question about refactoring. Honestly I prefer to do refactoring because I believe that " make things better " is a role of engineering in general. But on the other hand I am also lazy, older guys are telling me: " do not touch it if it works " and I really need to see a value of such a work. Therefore I have to somehow measure and visualize source code. This could be done by static code analyze, test coverage and performance tools. From the results I can Learn if my Refactor really made things Measurable better or not. 

Agile coaching hints

boring stand-ups typical reason: every team member is solving very different issue, no intersections or direct collaboration; basically "I do not care" about 1 status sentence of my colleagues because there is no connection to my current work + strong individualism possible solution: moving towards to the feature team, e.g. instead of doing 1 feature by 1 developer 6 weeks, try to split work and do it in parallel by 3+ developers with feature lead in 2 weeks or even faster if possible (could be challenging at the beginning but helps to build no siloed knowledge) + build the team too long stand-ups typical reason: too much details + bike-shading and direct follow ups on stand-up with whole team + manager's hijacking possible solution: park every discussion longer than 1 minute after the stand-up and follow up only with committed people (pigs & chickens); 'kill' any bike-shading; have manager's talk after the stand-up non realistic estimations ...

Agile is not a religion

It is quite annoying to me when argument during discussion is like this:  it must be XY because the book says it. It is kind of: Bible is saying XY so we have to follow = end of discussion.  I am not very happy in such a case because we probably do not understand principles and just trying to blindly imitate something without deep knowledge of the matter. I prefer to admit it or show personal standpoint.

Refactoring value

It is absolutely normal to invest time & money into cleaning service, so working desks, floors or toilets are clean and tidy. Working in messy environment is not easy and productive. Find a pen on table covered by tons of papers, gadgets and books can take few minutes instead of 1 second when it is just there. This makes sense for everybody. But when we talking about cleaning & tidying = refactoring of source code it is not so obvious and some managers suddenly needs SWOT analyses, meetings and arguments to understand why we should invest into it. The reason is very simple: what is business value of refactoring? Product management do not see any new feature (it was working before) but only risk of regressions. Also they have feeling that we did tons of shortcuts & dirty hacks till now so one more cannot hurts. Let's ask another way: what is business value of cleaning of working desk? Mainly: better, faster & comfortable work. Is is not directly linked with bu...

Good question is sometimes better than good answer

Almost everybody in IT knows 'Answer to the Ultimate Question of Life, the Universe, and Everything', it is 42 - according to Douglas Adams book, but who knows the question? It is just joke from the book but anyway makes valid point. Good questions are important. From my coaching experience I can confirm it. People appreciate when I am asking good questions which help them to think different way or change perspective. They feel that in many cases it is more helpful than direct answers because they are able to figure out solution themselves. It is process of learning principles and getting fluency. It is obvious that non-directive approach needs time. It would be crazy to do it in critical or very stressed situations where direct answer do the job right.

What is technical debt?

Software engineers are very often pushed to implement solution which consumes less effort instead of the right one (clean and well designed). It is short term thinking: now we do it 'quick & dirty' and maybe later we will make proper way, which usually never happens. Common reasons for this decision are: time to market, nervous customers, release deadline, it is 'mess anyway' or manager's bonus for 'green' excel. The final result of all these quick hacks and dirty workarounds are accumulated in technical debt, which we would have to pay to make it right. Critical amount of technical debt is illuminated by classic symptoms: maintainability is very low factoring of code is awful (spaghetti) ownership of code does not exists unit tests are just fake or joke static code analysis is rather turned off CI is unstable and very slow (CD is only dream) adding new features is very time consuming  estimations are just guess from magic ball architect...