Martin Fowler

Micro Frontends

Martin Fowler

Recent years have seen an explosion of interest in the microservices architectural style, which has become popular due to its ability to allow customer-oriented teams to build and deploy software independently.

Is High Quality Software Worth the Cost?

Martin Fowler

A common debate in software development projects is between spending time on improving the quality of the software versus concentrating on releasing more valuable features.

Self-serve data platform

Martin Fowler

One of the main concerns of distributing the ownership of data to the domains is the duplicated effort and skills required to operate the data pipelines technology stack and infrastructure in each domain.

Data 248

Bliki: TechnicalDebt

Martin Fowler

Software systems are prone to the build up of cruft - deficiencies in internal quality that make it harder than it would ideally be to modify and extend the system further.

How To Take Action on Customer Discovery

Speaker: Nick Noreña, Innovation Coach and Advisor, Kromatic

We all want to build successful products - and that means satisfied customers. Before anything else, you must understand what problems you can solve. The best way to do that is to get out of the building and start asking questions. But how can you make the most of those conversations, and ensure that you walk away with productive insights? Join Nick Noreña, educator, entrepreneur, and currently Innovation Coach and Advisor at Kromatic, as he covers how we can effectively action our findings from customer discovery conversations.

How to Move Beyond a Monolithic Data Lake to a Distributed Data Mesh

Martin Fowler

Many enterprises are investing in a centralized data platform to provide support for business insights and (hopefully) automated decision making. Having worked with several of these organizations, my colleague Zhamak Dehghani feels there are fundamental problems with this common approach.

Data 247

Domain-Oriented Observability

Martin Fowler

Any serious software system needs some form of observability, so we can figure out how it is working and keep track of problems. But adding the code for this often results in lots of low-level cruft.

Domain-driven data architecture

Martin Fowler

Zhamak explains the first part of the data mesh concept - using the ideas behind Domain-Driven Design to structure the data platform. more…. skip-home-page

Downsides of micro frontends

Martin Fowler

Any significant architectural pattern has downsides. Cam finishes his explanation of micro frontends by looking at some of the costs of this approach, such as payload size and complexity in operations and governance. more…. skip-home-page

An example of a micro frontend application

Martin Fowler

After all the theory about micro frontends, Cam now digs into an example of how JavaScript integration can work with a simple application. more…. skip-home-page

Build Product Progress with a Strong Data Culture

Speaker: Nima Gardideh, CTO, Pearmill

Have you ever thought your product's progress was headed in one direction, and been shocked to see a different story reflected in big picture KPIs like revenue? It can be confusing when customer feedback or metrics like registration or retention are painting a different picture. No matter how sophisticated your analytics are, if you're asking the wrong questions - or looking at the wrong metrics - you're going to have trouble getting answers that can help you. Join Nima Gardideh, CTO of Pearmill, as he demonstrates how to build a strong data culture within your team, so everyone understands which metrics they should actually focus on - and why. Then, he'll explain how you can use your analytics to regularly review progress and successes. Finally, he'll discuss what you should keep in mind when instrumenting your analytics.

Completed Copyedit and other notes

Martin Fowler

I've added a couple more memos to my thoughts on producing the second edition of Refactoring. Last week I shone a light on the hidden heroes. whose technical reviews removed many a mistake from the book. Today I added some thoughts about the copyediting of the book , which we've just finished.

285
285

Cover design for the Refactoring 2nd Ed

Martin Fowler

We've got a cover design for the second edition of Refactoring. As with any book in my signature series, I needed to decide which bridge would feature in the photo.

285
285

Integration approaches for micro frontends

Martin Fowler

Cam moves on from the benefits of micro frontends to look at different ways of implementing them. He covers server-side template composition, build-time integration, and run-time integration via iframes, JavaScript, and Web Components. more…. skip-home-page

171
171

Other implementations for domain-oriented observability

Martin Fowler

Pete completes his discussion of domain-oriented observability by comparing domain probes to using events and aspect-oriented programming. more…. skip-home-page

What Is (and Isn’t) Product Management?

Speaker: Steve Johnson, VP of Products, Pragmatic Institute

Product Management is one of the most exciting - and most misunderstood - functions in technical organizations. Is it strategic or tactical? Is it a planning role or a support role? Many product professionals are unclear about what is (and isn't) product management. After all, product management spans many activities from business planning to market readiness. In this session, we’ll examine many product activities and artifacts for product strategy, planning, and growth, and introduce a simple tool that you can use in your organization to clarify the roles of product management and others. Steve Johnson explores the many roles of Product Management in this fun talk focused on why product managers should obsess on problems instead of solutions.

Implementation issues with micro frontends

Martin Fowler

Cam now looks at various issues that need to be considered to make this whole approach work. How to achieve coherent styling, dealing with shared components, inter-application communications and how to test it all. more…. skip-home-page

How to break a Monolith into Microservices

Martin Fowler

As monolithic systems become too large to deal with, many enterprises are drawn to breaking them down into the microservices architectural style. It is a worthwhile journey, but not an easy one.

Testing Domain Probes

Martin Fowler

Now he's shown you the basic idea, Pete shows how using domain probes makes it much easier to test observability behavior. more…. skip-home-page

Agile Australia Keynote: State of Agile in 2018

Martin Fowler

The transcript of my Agile Australia keynote on agile in 2018. I comment that although agile is now mainstream, much of what is done is faux-agile. I outline three main challenges: stop Agile Industrial Complex imposing process. raise importance of tech excellence. prefer products over projects. and one reason to be optimistic.

Agile 214

The 5 Levels of Analytics Maturity

Basic dashboards used to be enough to thrill end users. But over time, modern capabilities have emerged—and bare-minimum features are no longer cutting it. How have analytics changed? And where do your BI offerings fall short? Find out sophisticated ways to future-proof your application. Brought to you by Logi Analytics.

Product thinking in a data platform

Martin Fowler

Distribution of the data ownership and data pipeline implementation into the hands of the business domains raise an important concern around accessibility, usability and harmonization of distributed datasets. Zhamak explains that this is where the learning in applying product thinking and ownership of data assets come in handy. more…. skip-home-page

Data 150

What I Talk About When I Talk About Platforms

Martin Fowler

Evan Bottcher has been involved with several of our clients with microservices and platform building over the last few years. A couple of years ago, at one of our radar writing meetings, he gave a great presentation on what makes an effective way to think about platforms.

2nd Edition of Refactoring

Martin Fowler

Nearly twenty years ago, I wrote "Refactoring", which is probably my most successful book. It's still a useful book, as the technique is one that doesn't change much with new languages and technology. But given that, a book that uses java.util.Vector is showing its age a bit. So, for the last couple of years I've been working on a new edition.

Kindle edition of Refactoring now available from Amazon

Martin Fowler

Amazon is now selling the Kindle edition of Refactoring. As I write this, it's touch more expensive than the hardback since they are currently discounting the hardback but not the electronic version. more…. skip-home-page

173
173

Make an Impact with Analytics and Journey Maps

Speaker: Kirui K. K., Co-founder and CEO of Tanasuk Africa

If you want to offer a better user experience, it can be tempting to track each and every data point in your product. However, this can quickly get complicated and overwhelming as you collect more and more data. How do you know which metrics will help you improve? Kirui K. K., Co-founder & CEO Tanasuk Africa, wants you to know that analytics don't have to be complicated to make an impact - no matter the size of your company. Join him as he explains how to create a customer journey map, then use that map to figure out the metrics you need to know - and how to use them.

Completing the Pyramid

Martin Fowler

Ham completes his article on showing how to use test pyramid in practice by looking at acceptance tests and exploratory testing. He also finishes with a few words on pipelines and the need to avoid duplication in testing between the layers of the pyramid.

Bliki: IntegrationTest

Martin Fowler

Integration tests determine if independently developed units of software work correctly when they are connected to each other. The term has become blurred even by the diffuse standards of the software industry, so I've been wary of using it in my writing.

UI and End-to-End tests

Martin Fowler

The whole point of the test pyramid is to remind us that broad scope tests should be rare, since they are usually expensive and slow. Rareness isn't the same as absence, so now Ham takes a look at role of UI tests and end-to-end testing in general.

Contract Tests Ensure Faithful Doubles

Martin Fowler

Our approach to integration testing avoids hitting real services in order to make testing easier and faster. But then a question rears up - how do we know the test doubles for our integration tests are true doubles of the collaborating service? Ham answers this question by discussing Contract Tests and showing the role they play in his example application.

The Magic of Intent: Start Knowing The Goals of Your Users

Speaker: Terhi Hanninen, Senior Product Manager, Zalando, and Dr. Franziska Roth, Senior User Researcher, Zalando

It's important to know your users - what are their preferences, pain points, ultimate goals? With user research and usage data, you can get a great idea of how your users act. The tricky part is, very few users reliably act the same way every time they use your product. Join Terhi Hanninen, Senior Product Manager, and Dr. Franziska Roth, Senior User Researcher at Zalando, as they explain how they were able to reach a new level of user understanding - by taking their user research and segmenting their users by point-in-time intent. You'll leave with a strategy to change how your product team, and organization at large, understands your users.

Integration Tests in the Pyramid

Martin Fowler

People find the notion of integration tests confusing, since they are ill-defined even by the standards of testing terminology. So they are a great topic for Ham's example application and explanation.

Unit Tests in the Pyramid

Martin Fowler

Ham now starts looking at the pyramid in earnest, beginning with the foundation of the pyramid - unit tests.

Revised Agile Fluency Model

Martin Fowler

Several years ago, Diana Larsen and James Shore came up with their Agile Fluency model. This categorizes agile usage into four zones, where later zones produce more benefit, but also require greater investment. I've found this model a useful way to understand how different groups of people use agile ideas in varying ways.

Agile 202

Updated refactoring.com for second edition

Martin Fowler

With the new edition of my book on refactoring getting close to the bookshelves, I've spent some time to update refactoring.com. I've changed the visual design, put together a new home page to summarize what refactoring is, and updated the catalog.

160
160

Monetizing Analytics Features: Why Data Visualizations Will Never Be Enough

Think your customers will pay more for data visualizations in your application? Five years ago they may have. But today, dashboards and visualizations have become table stakes. Discover which features will differentiate your application and maximize the ROI of your embedded analytics. Brought to you by Logi Analytics.

Completing the extraction of a data-rich service

Martin Fowler

Praful completes the steps of extracting a data rich service by pointing the new service to the new database and removing the dead logic and schema from the monolith.

Data 159