Architecture Weekly #141 - 21st August 2023
Welcome to the new week! Christmas came earlier this year. Remember the last webinar with Jeremy D. Miller about Simplifying Architecture with Wolverine? We made it publicly available. You can watch it here: Besides the architecture knowledge, it’s an excellent chance for you to check how webinars for paid subscribers look like. Check the complete list of the webinars we had so far. One of the foundational things we wanted to show in the webinar is enabling focus on business behaviour. Focusing on the behaviour of our system is one of the foundations of my software design. That’s also a reason why I’m a big fan of modelling by events, CQRS, Vertical Slices and Feature Folders. What could be more focused on the behaviour than Behaviour-Driven Design (BDD)? The answer is not so simple, as BDD definition is too often flattened. I wrote my take on Behaviour-Driven Design and why I believe that's not (only) about tests. I feel that for developers, pushing BDD into the testing or domain-specific language corner is a way for an excuse. An excuse to outsource the responsibility of the behaviour to domain experts, business analysts and testers. So developers could continue what they liked the most: typing on the keyboard without the need to express the business context. Check also more in the intriguing talk made by Gojko Adzic He explains how important it is to understand what we’re trying to test before thinking about how. I liked how he goes much further than the typical Code Coverage discussion that people are overfocused. I like how Martin Fowler’s blog become a hub for other authors. I love his works, but now it has got to another level. I like how he’s giving a platform for diversed and high-quality voice of the community. Of course, it’s still biased by ThoughtWorks’ perspective, but who’s not biased? In the bias is also power, as we’re getting personal perspective. As long as we can understand and filter that through our view, we can get a much richer understanding than just flat articles trying to be objective at all costs. Still, articles on Martin Fowler’s blog are quite often super thorough. For instance: It’s an excellent case study showing how to balance product growth and the cost of our services. Too often, we decide to define our strategy based on our gut feeling and our past experience. The worst thing is if we don’t embrace that but show it as an educated decision and strategy that we should stick with. We can also cement our costs through the contracts, hiring strategy, and being unable to shift our strategy quickly. That usually ends up in drifting rather than quick iterations, which can mean a project failure. Check also a short talk by Fred Moyer, where he shares his experience on SLOs budget management on the scale: If we want to reach the market, that’s a must-have. We won’t survive crossing the adoption chasm without that. All of that should be based on understanding the customer needs and shifting our strategies quickly to define SLO; that’s a good balance between customers’ expectations and our capabilities. Product Management is one of the foundational aspects of building software products. Most of the failed projects I’ve seen so far failed not because of technical issues but because of not having a vision of the product. Product Manager is one of the hardest roles to fill. Such a person needs to be almost a renaissance man, understanding the business domain, customer needs, financial incentives, and technology behind products and knowing how to execute all of that. Too often, I see this role being created so C-level people can push the dirty work on someone without giving enough authority to make product decisions. That’s a no-go, and it won’t ever work. Still, I think that each of us should learn the aspects of building products and understand the challenges behind that. Even if we’re not planning to make the transition and won’t become product managers, our design will get much better. See a few good recent materials on product design as inspiration:
Last week I mentioned recent OSS issues. Let me do a follow-up. Moq author wrote a longer article explaining his motivations behind the issue he made: It’s a long wall of text to show that he still doesn’t understand that the community wasn’t mad because he wanted to have sustainable work on the library but because of how he did that and drove it. That’s also why understanding how to build a product is so essential. We open-source creators need to do a quick course on that. There’s a new initiative called OpenTF; you can check their manifesto: It’s a result of the HashiCorp licence change. This organisation wants to maintain the fork and maintain it. Interesting if some bigger cloud vendors like AWS, Microsoft or Google will join it. They’re the main reason why companies like HashiCorp, Elastic, Redis had to change their licensing not to be eaten by big corporations benefiting from their free work. My prediction is that they won’t and this initiative will be marginal, although I might be wrong, as a lot of companies made Terafform a critical part of their DevOps process. William Gibson said:
It means that if we looked carefully, we would see the trends that will grow into commodities soon. That’s also a reason why I’m highlighting privacy and security issues. I wouldn’t like such things to become a commodity. Or are they already? Check also other links! p.s. I invite you to join the paid version of Architecture Weekly. It already contains the exclusive Discord channel for subscribers (and my GitHub sponsors), monthly webinars, etc. It is a vibrant space for knowledge sharing. Don’t wait to be a part of it! p.s.2. Ukraine is still under brutal Russian invasion. A lot of Ukrainian people are hurt, without shelter and need help. You can help in various ways, for instance, directly helping refugees, spreading awareness, and putting pressure on your local government or companies. You can also support Ukraine by donating, e.g. to the Ukraine humanitarian organisation, Ambulances for Ukraine or Red Cross. Architecture
DevOpsAIAWSJava.NET
Node.jsProduct Design
ManagementCoding LifeSecurityTriviaYou're currently a free subscriber to Architecture Weekly. For the full experience, upgrade your subscription. |
Older messages
Architecture Weekly #140 - 14th August 2023
Monday, August 14, 2023
Welcome to the new week! I realised that I could do more to help you and other folks. I've been sharing online content for free in the last few years through my blog, conference talks, this
Architecture Weekly #139 - 7th August 2023
Monday, August 7, 2023
Welcome to the new week! Last week Jeremy D. Miller joined paid subscribers and me showing and discussing how we can simplify the architecture. We discussed the assumptions behind the Wolverine,
Webinar #12 - Jeremy D. Miller: Simplify your architecture with Wolverine
Thursday, August 3, 2023
Watch now (48 min) | Wolverine is the youngest child of our so-called Critter Stack. A .NET framework to help build boilerplate-free, robust CQRS and Messaging applications. Jeremy Miller was joking
Architecture Weekly #138 - 31st July 2023
Monday, July 31, 2023
Welcome to the new week! Let's start with a short reminder. This week, Wednesday, 2nd of August, we'll have the next webinar for paid subscribers community. Together with Jeremy D. Miller, we
Architecture Weekly #137 - 24th July 2023
Monday, July 24, 2023
Welcome to the new week! I took July as a break from commercial work and bigger engagements. I decided to keep sending the newsletter and post new articles, as I wanted to keep consistency. Yet, we
You Might Also Like
🎮 5 Cheap Apple AirPlay Receiver Alternatives — Your Game Controllers Need Firmware Updates Too
Tuesday, January 7, 2025
Also: The Best Free Offline Music Player Apps For Android How-To Geek Logo January 7, 2025 Did You Know It's a common practice in Japan to package toys with a single cheap piece of candy in order
Daily Coding Problem: Problem #1661 [Medium]
Tuesday, January 7, 2025
Daily Coding Problem Good morning! Here's your coding interview problem for today. This problem was asked by Triplebyte. Implement a data structure which carries out the following operations
DRF, Temp Files, Dataclasses, and More
Tuesday, January 7, 2025
Building HTTP APIs With Django REST Framework #663 – JANUARY 7, 2025 VIEW IN BROWSER The PyCoder's Weekly Logo Building HTTP APIs With Django REST Framework This course will get you ready to build
Charted | The Pyramid of S&P 500 Returns (1874-2024) 💰
Tuesday, January 7, 2025
In 2024, the S&P 500 surged 23%, setting a series of record highs. We show these returns in a historical context spanning 150 years. View Online | Subscribe | Download Our App Presented by: Global
LW 164 - How to create new arrivals collection in Shopify using Shopify Flow
Tuesday, January 7, 2025
How to create new arrivals collection in Shopify using Shopify Flow Shopify Development news and
Tic-Tac-D’Oh 💻
Tuesday, January 7, 2025
The latest from the dull side of the internet. Here's a version for your browser. Hunting for the end of the long tail • January 07, 2025 Tic-Tac-D'Oh Dell decides to rebrand its machines along
Spyglass Dispatch: CaptAIn AmerIca...
Tuesday, January 7, 2025
Hulu, Fubo, Venu • NVIDIA's Cosmos • NVIDIA's DIGITS • Meta's Board Addition • Meta's Fact-Checking Subtraction • Dude, You're Getting a Dell Pro Max Premium The Spyglass Dispatch
DeveloPassion's Newsletter #183 - Knowledge Management for All
Tuesday, January 7, 2025
A newsletter discussing Knowledge Management, Knowledge Work, Zen Productivity, Personal Organization, and more! Sébastien Dubois DeveloPassion's Newsletter DeveloPassion's Newsletter #183 -
CES 2025 ICYMI: 8 top reveals so far
Tuesday, January 7, 2025
Bluesky's most-needed feature; A mulching robot mower; Linux man pages -- ZDNET ZDNET Tech Today - US January 7, 2025 ces55gettyimages-2191705850 CES 2025: ZDNET's 8 most impressive products we
Post from Syncfusion Blogs on 01/07/2025
Tuesday, January 7, 2025
New blogs from Syncfusion Introducing the New Blazor Chat UI Component By Silambarasan Ilango Enhance real-time communication with the Blazor Chat UI. Discover its features and use cases for creating