Agile Architecture by Molly Dishman and Martin Fowler

I'm copying here what Mahmoud Atef mentioned in his post on Linkedin that sums up this video. I think it's really important to follow such tips in order to provide some sort of architecture management during the software development. Here is what Mahmoud wrote:

I was lucky to listen to  "Agile Architecture" talk by Molly Dishman & Martin Fowler (attached @the end of this post). I come up with eight points that I want to share my thoughts about.

  1. Focus on the things that are hard to change and make them changeable. Mainly, service contracts and database design are the most rigid parts in any architecture design. Sometimes it's OK to fix them if the requirements are very clear from the beginning of the project, which is rare to happen. Most of the time, you need to find a way to simplify the change in these parts whenever it is needed.
  2. Architects are more working as team leads and have to get their hands into code. In agile project, architects are almost engaged along the project lifetime. They are required to solve day-to-day technical challenges and come up with solutions to new problems. This couldn't be done unless they have hands on the project code and know its current status and improvements needed.
  3. Architecture is more like city planing with all the dynamics implied rather than a static building structure. Evolutionary design and refactoring are two of the main features in agile projects nowadays. Architects have to believe that their designs will be changed with time and start to think how flexible and tolerant are their designs. They also need to be more willing to experiment things and change if it doesn't work.
  4. The best place of detailed design is in people minds. Detailed design document became part of the history because, simply nobody needs it. If it comes to details, code is the most updated detailed design a programmer can get. Architect has to make sure that there is a common understanding of the application design and how it works.
  5. Highlight example part of the code and let people to understand and copy from. Sample of code is one of the most powerful methods of ensuring common understanding for the design. It also puts programmers on the right track rapidly by copping the sample and put their changes with lowest effort.
  6. Use code analysis tool to keep the code standards followed across the project. You need to have a tool to scan the code base and give you a comprehensive report about the standard violations. This will give you and your team faster and broader vision on the problems you have to tackle.
  7. Keep an eye on the code commits to get an overview of developers performance. It's not enough to use tools to give you report on how code is going on, you need to check some of the project commits to get an overview on how programmers are implementing their stories and how far is the code stream from your design.
  8. Give architects and senior developers time to think about architecture. Time is the key factor for innovation and improvement. If the team is always on rush to deliver and no time to step back and think, they won't have a chance to think about the application which will affect the overall implementation and performance in a very bad way.


Finally, for more videos for Martin Fowler you can check this page.



Comments

  1. The effectiveness of IEEE Project Domains depends very much on the situation in which they are applied. In order to further improve IEEE Final Year Project Domains practices we need to explicitly describe and utilise our knowledge about software domains of software engineering Final Year Project Domains for CSE technologies. This paper suggests a modelling formalism for supporting systematic reuse of software engineering technologies during planning of software projects and improvement programmes in Project Centers in Chennai for CSE.

    Spring Framework has already made serious inroads as an integrated technology stack for building user-facing applications. Spring Framework Corporate TRaining the authors explore the idea of using Java in Big Data platforms.
    Specifically, Spring Framework provides various tasks are geared around preparing data for further analysis and visualization. Spring Training in Chennai

    ReplyDelete

Post a Comment

Popular posts from this blog

PrimeFaces Push with Atmosphere

JavaOne 2015 Session: EJB 3.2/JPA 2.1 Best Practices with Real-Life Examples by Gohar

Adding MyBatis mapper files dynamically