Sonntag, 5. Oktober 2025

(Vibe) coding

 

Recently, I started a small private project to replace the handwritten fuel notices with a mobile application. 

Highly motivated, I installed Android Studio and started my first project to create a simple project where I can enter fuel price, amount of fuel, total mileage and mileage since the last fuel. With some samples, I got fast familiar with the basics and was able to create the UI for this really simple application.

Today I decided to restart from scratch doing completely using Android Studio and Cursor and did the same in just one hour and additionally added and export/import functionality and getting a history. I was really surprised how easy it worked when you have absolutely no idea what code has been created and you just look at the result.

In this vibe coding session, the focus was totally on the outcome. I need to to care about the code at all and got what I wanted. That was a great experience creating something new from scratch and I can recommand that to experiment yourself.

To be honest, I am sceptical about the whole KI hype as I also had a lot of hallucination experience which costed me in the end more time of working compared to do it on my own immediately. On the other hand, I also had great experiences where I got great results which saved me time of summarising or creating a document. I rarely got really new information but that can be the result of limited prompting because of limited knowledge.

What did I learned from my today’s experience for my daily work as Scrum Master? Isn't that great having an outcome oriented approach on creating a product? Indeed, that is great - at least for prototyping. From a non-functional-requirement perspective, I have no idea if I created top, good or bad work. Did Cursor added a security hole in my application? I do not know. Does the application save resources? I do now know. Is it maintainable? I do not know. Will I need some day a Vibe coding clean-up specialist? Maybe.

From an Agile perspective, my today’s experiment showed me that it is possible to exchange in a project knowledge with shorter time to market while I might added an unknown amount of technical debt. From my today's perspective, it is essential to get an understanding what have been created by the AI, what will probably consume my next days. All in all, I would have invested the same amount of time for the creating and building up knowledge.

Montag, 5. Mai 2025

Health is more than you think


When it comes to the health topic, the majority has physical health in mind. Biased by the daily business, in organisation the health topic is reduced to available meaning healthy, not-available meaning sick. This simple view is tricky because it only reflects the current state and with this the current personal costs. In times, where costs of employees are a key factor to success, I like to use the term human asset over human resources.

The WHO constitution states: "Health is a state of complete physical, mental and social well-being and not merely the absence of disease or infirmity." An important implication of this definition is that mental health is more than just the absence of mental disorders or disabilities.

Additionally, the WHO enriches the mental health definition with

  • Mental health is more than the absence of mental disorders.
  • Mental health is an integral part of health; indeed, there is no health without mental health.
  • Mental health is determined by a range of socioeconomic, biological and environmental factors.

 What does that mean now regarding staying healthy and care about human assets?

Taking the picture from above, all three categories interact with each other. Imagine you have a broken leg and cannot prepare for your run and you cannot meet your friends. In that case physical sickness effects on your mental sickness as you might get sad to miss the running event and you miss interaction with your friends.

If you loose a family member, this probably effects on your mental and also on your physical heath.

If you are extremely stressed in the company, you probably get physical sick and/or you start isolating yourself at home as you want to regenerate.

There are plenty of examples showing these interactions. As individual, a key take away is, if there is a physical issue, think larger for the solution. The core issue might be on the social or the mental part.

As organisation, also think larger to prevent sick leaves as these costs money, either directly or indirectly through lower throughput and release delays and react on global changes. A very good example is here Home Office. While it burst all level of Health by less traffic stress and more time with the family, it reduces social interaction within the company and reduced communication leads to missing know how. Mental health, but also social health, is an important topic for leadership. Good leadership reduces the risk of mental sick leaves and this reduces risks and costs. The key is to actively prevent or mitigate  over just reacting on health issues.

Physical health can be supported my medical offers, (team) sport activities and adjustable tables.

Social health can be supported by face to face events and bringing employees together, starting from a coffee kitchen to team sport events.

Montag, 14. April 2025

Mutation Testing

 Out of a good discussion within the team about testing, in special about mutation testing, I want to share a good insight from Uncle Bob about that topic

https://blog.cleancoder.com/uncle-bob/2016/06/10/MutationTesting.html

Donnerstag, 10. April 2025

Do not let your tester be the bottleneck!

 


You might know the situation, when it is a stressful time with a lot of features to implement and developer focus on coding while the tester takes the tickets after coding and tests the ticket. This is a classic waterfall approach.

In software development time to deliver got a high focus through Agile and the previous role concept of tester has changed. This article shows the advantages of spreading testing tasks and explores strategies to ensure that the tester in your team does not become the bottleneck in your process.


Spreading the testing responsibility across the team can bring you several advantages:

  • Faster feedback: With more team members who are involved in testing, other developers get feedback earlier. The higher your ratio of devs to testers is, the higher is the value of this feedback loop
  • Reduce risk: Even if the tester is highly skilled, other persons have different approaches to test something. By having different perspectives on the product, risks of bugs can reduce
  • Balanced workload: In Scrum, when a number of developer starts at the beginning of the sprint with coding and get finished close togehter with their first task, you have then a high peak of workload for your tester, while devs "wait" for feedback. The longer your release cycles are the more imbalanced are the workloads. Shifting reduce the health risks for your tester. As a leader, beware that developer get the work additionally to their coding tasks. Even if there is a big benefit in this balancing, it needs a lot of leader support to avoid misunderstandings.
  • Skill development: When developer are coding their tickets, the have a hard focus on the code view of the product. Having developer who avoid testing and working on requirements, I would rename them to coders instead of developer. Developer crafting solutions. To craft solutions, you should know the customers perspective and you perfectly get this by using the product during tests.

What are the strategies to shift 

  • Shift-Left Testing: Integrate testing early in the development cycle. By involving testers from the beginning, potential issues can be identified and addressed sooner, reducing the load during the final stages.
  • Automated Testing: Implement automated testing tools to handle repetitive and time-consuming tasks. This allows testers to focus on more complex and critical testing activities.
  • Cross-Functional Teams: Encourage developers to take on some testing responsibilities. This not only distributes the workload more evenly but also fosters a culture of quality across the team.
  • Test-Driven Development: Encourage developers to write tests before coding. This practice ensures that testing is an integral part of the development process and helps catch issues early.
  • Regular Training: Provide ongoing training for testers to keep them updated with the latest testing tools and methodologies. Skilled testers can work more efficiently and effectively.
Do I need then a pure tester at all when developer are testing?

I put this questions here as in the past 20 years, I often heard that. Of course it is possible to remove the role from the list of available roles in the company and shift the tasks of this role completely to the developers. But beware of just cutting of the quality guy as there is no need anymore. Developers need of course also time to test and probably will do the tests less efficient as a pure tester. 
The probably better questions are
  • Do I need somebody who has a focus on the quality through the whole development process
  • Who checks non-functional requirements
  • Do I want to have a person with a focus on specific tests like load tests
Getting more clarity of tasks helps to find your team setup.