Drakon flowcharts, changing jobs, and boring tech π‘
Monday Ideas β Edition #62
Hey, Luca here! Welcome to the Monday Ideas π‘
Every Monday I will send you an email like this withΒ 3 short ideasΒ about making great software, working with humans, and personal growth.
You will also receive a long-form, original article on Thursday, like the last one:
To receive all the full articles and support Refactoring, consider subscribing if you havenβt already!
p.s. you can learn more about theΒ benefits of the paid plan here.
π» Typo
This week I am promoting Typo β an intelligent engineering management platform that enables modern software teams with visibility, insights & tools to code better, deploy faster & stay aligned with business goals.
By seamlessly integrating with your dev tool stack (Git, Issue Tracker, CI/CD, Incident Management, Slack),Β TypoΒ connects the dots between engineering signals & developer experience, to deliver the following:
π For Leaders β align engineering with business goals & support teams to deliver their best with developer wellbeing insights
π½ For Managers β identify delivery bottlenecks, predict release delays & drive continuous improvement with customized team goals & weekly progress reports
π¨ For Developers β measure the impact of their work on team goals & ship code faster with automated dev workflows in Slack
1) βοΈ Boring vs exciting tech
I have a bias for choosingΒ boring technology.
My definition of boring tech is: good tech that has almostΒ everything figured out:
β Many known winsΒ β it is widely adopted and supported.
β Many known failsΒ β limitations are well known and documented.
β Few unknown failsΒ β we know it inside out because so many things have already been tried.
Exciting tech, instead, is good tech that is stillΒ discovering thingsΒ about itself:
β Many known winsΒ β new paradigm!
β Few known failsΒ β it will solve all my problems!
β Many unknown failsΒ β because we just haven't discovered them yet.
In tech, new things are generally better than old ones, and the former eventually replace the latter. However, new stuff has also the unfair advantage that some downsides just haven't been figured out yet.
An old adage says that new tech solves old problems and creates new ones. But since new problems only surfaceΒ a while afterΒ the old ones have been solved, you have a window of time in which new tech looksΒ disproportionatelyΒ better than it actually is.
In conclusion you can say that:
Boring tech is saferΒ βΒ because of fewer unknowns.
Exciting tech looks betterΒ βΒ and maybe it is, but you will also discover more downsides over time.
I wrote more advice about choosing tech in this past Refactoring article:
2) πΌ Changing jobs often β or not?
I am a fan of using your early years for broad learning β that is, you build the horizontal leg of the T-shape first.
For this reason you will probably benefit from changing jobs often, early in your career.
This might be divisive, but it is just common sense to me: if you want to see different thingsβfrom a technical, product, and organizational point of viewβyou just need different companies.
How long you should stay depends on how much you can learn. A couple of years is usually a good amount of time to have a good impact and learn new tricks. In healthy, high-growth contexts, you can benefit from staying more, while you can stay less when things are not going the right way.
As a hard and fast rule, I would always stay at least 18 months in any position that is not extremely pointless or toxic. Less than that, the onboarding tax you pay is just too high and cuts into the value you can create for the company and for yourself. Also, a long string of short experiences doesnβt make for a good impression with future employers.
More advice on when to quit your job π
Later in your career, when you get into senior positions, I would look instead for environments where you can stay longer and have a long term impact. Leadership and upper management positions, in fact:
β³ Need more time to create value β initiatives are bigger, planning cycles are longer, and you just need more time to accomplish anything.
π€ Are built on strong trust β every time you change jobs you lose all the trust you built in your previous experience, which is crucial to advance to leadership roles. In that respect, changing jobs too often can even slow down your career.
More advice about growing your career in this past edition π
3) π Drakon Flowcharts
I have struggled to draw good flowcharts for years and I just found out that there is a better way called DRAKON.
DRAKON is a visual language, created in the aerospace industry, that defines a few simple rules on top of regular flowcharts:
Line intersections are forbidden
Only straight lines and right angles are allowed
Arrows are replaced with plain lines
Time in the diagram flows downwards and branching goes to the right
...and, magically, flowcharts look 10x better!
And thatβs it for today! If you are finding this newsletter valuable, consider doing any of these:
1) βοΈ Subscribe to the newsletterΒ β if you arenβt already, consider becoming a paid subscriber. You can learn more about theΒ benefits of the paid plan here.
2)Β β€οΈΒ Share itΒ β Refactoring lives thanks to word of mouth. Share the article with your team or with someone to whom it might be useful!
I wish you aΒ great week! βοΈ
Luca
Hey Luca
Love the refactoring newsletter and I think it would be a great fit for tech PMs in my subscriber base.
Would you like to do a mutual subscribe and recommendation on Substack? Happy to hear you here or on ProductifyLabs@gmail.com