Design for Testability: A vital aspect of the system Architect role in SAFe

Share on Socialmedia


The system architect role is vital to the successful definition, design, delivery, and support of any IT project. A system architect examination and suggests the correct blend of IT components to accomplish a particular business, department, team, or functional goal. They impartially investigate wanted processes and results and advice on the correct mix of IT systems and segments to components those objectives. System architecture is firmly lined up with administration plan.

The Various Levels of System Architects

The system modeler works at a several different levels in IT, from high-level business system to low-level project consulting.

  • At the highest level, system architects help to define and settle on the correct IT system and approach that will best help long-term strategies and goals.
  • At the medium level, system architects advise on the best tools, frameworks, hardware, software, and other IT components to accomplish mid-term departmental and useful goals.
  • At the most reduced dimension, system architects counsel with and exhort project teams on the particular programming, equipment, and different components expected to deliver characterized IT anticipate results.

System architects are matter of fact and technology specialists. They see marketable strategies and goals, break down technical solutions, and make suggestions on the correct blend of IT components to accomplish those targets.


Design for Testability (DFT) is anything but another idea. It has been utilized with electronic hardware design for more than 50 years. The reason there is straightforward: in the event that you need to have the capacity to test an integrated circuit both during the structure arrange and in later production, you need to plan it with the goal that it tends to be tried. You need to put the snares” in when you plan it. You can’t just include testability later., as the circuit is as of now in silicon; you can’t transform it now. DFT is a critical non-utilitarian requirement that influences practically every part of electronic equipment plan. In a like form, complex agile software frameworks require testing both during design and production, and similar standards apply. You need to plan your software for testability, else you won’t have the capacity to test it when it’s set.

The Economic Value of DFT

Agile testing covers two explicit business viewpoints: from one perspective, it offers the capacity to evaluate the item, in this way limiting the effect of imperfections’ being delivered to the user. On the other, it bolsters iterative improvement by giving snappy criticism inside a ceaseless coordination process. None of these elements can come into a play if the framework does not consider straightforward system / component /unit-level testing. This implies agile projects, which support testability through each structure choice, will empower the project to accomplish shorter runway for business and architectural epics.

DFT reduce the effect of substantial system scope, and affords agile teams the advantage of working with something that is more manageable. That is the reason the role of a System Architect is so critical in agile at scale, however it additionally mirrors an alternate inspiration: rather than characterizing a Big Design Up-front (BDUF), agile designer builds up and continue a viable product development stream by guaranteeing the benefits that are produced are of high caliber and needn’t be returned to. This diminishes the expense of deferral being developed in light of the fact that in a system that is intended for testability, all jobs require less time.

Impact on System Architecture

Experience instructs us that we ultimately achieve a superior plan when we design for testability. To be sure, it is regularly the situation that DFT drives a reasonable detachment of concerns, layered architecture or administration orientation, high cohesiveness of substances in the code, and so forth. Our tests carry on particularly like system “customers”— unit tests mirror the conduct of a comparing customer class or classes conjuring target class strategies; segment tests mimic the conduct of customer segments; practical tests copy the end client—the “customer” for the whole framework. On the off chance that we structure for testability at all these levels, we are additionally accommodating clear and reasonable interfaces between classes, segments, administrations and, at last, the UI and rest of the system.

Cultural Impact

Designing for Testability can’t be considered exclusively the responsibility of the system architect. Every single agile teams must do DFT, a nonstop journey that supports item development exertion between developers, testers and system architects. It makes a culture of shared duty regarding item development stream, where all effectively add to the framework structure and testability.

System Architect Role and DFT

As for structuring for testability, the system architect can assume a basically job in DFT:

Choice of technologies

In addition to their fundamental reason, software libraries, systems, repositories and administrations should to likewise support testability. For instance, developments that help the reversal of control might be valuable, not just regarding planning an adaptable system, yet additionally in connection to testability.

Implementation Decisions

For example, having excessively logic at DB side (a typical issue of many- many products) makes testing for all intents and purposes inconceivable. So, does the unreasonable use of asynchronous message lines inside the system.

Design conventions

Configuration designs like façade, gateway, or eyewitness encourage testability. But then, such a typical thing like utilizing a web benefit intermediary class may not. A good convention is to utilize some ” abstract ” interface, which would communicate with the intermediary, along these lines allowing the substitution of one with a ridicule object when necessary.

Approach to creating fake objects and mocks

What tools and methodologies should to be connected to make stubs, mocks and “spies” in the code, which would support unit-and component testing?

Logging and dumps

In large systems, regularly some system level tests bomb however all unit tests pass. Accordingly, it might hard to analyze the main driver of the issue without a decent logging methodology and the capacity to retrieve thorough memory (or convention) dumps.

Flexible configuration

This enables the basic organization to the test condition and simple connecting of test information sources and outside ridicule protests through just refreshing the design records.


  • The table above is expected to give an underlying arrangement of thoughts that may bring forth some new architectural epics for DFT. Obviously, the gradual methodology is dependably the best, as the groups can stay concentrated on the value delivery of new highlights and stories, while including testability. Also, the social part of DFT is best accomplished by implementing incremental steps that demonstrate the group —after each and every plan activity—that it is less demanding to compose new tests at various dimensions of reflection and in this way how the team speed increments.
  • Let the teams take a few of current client stories and figure out what might be the base update exertion to give them a chance to compose a few of unit tests in the zones where they beforehand proved unable. At that point they can impart the discoveries and real ways to deal with others (for example at the closest Design CoP get together). In Table 1, you can see which of the perspectives depicted above might be influenced by these discoveries – are there new structure rules for all teams or changes to the system design, and so on.?
  • We propose utilizing a comparable methodology at the system level: let the system team or Feature Teams endeavor to automate system level tests, where they would have recently flopped, yet given them a chance to do as such with regards to their present a couple of highlights. DFT is a difficult task. In any case, such as everything else we can approach it gradually. When we talk about agile testing and that it is so essential to promptly begin mechanizing testing, we should mull over certainty that present software system are regularly test-unfriendly. From one viewpoint, this is a pitiful truth about the business; on the other, with Design for Testability, the agile endeavor has a reestablished shot of outperforming the competition as the organization develops it capacity ready to convey substantially more incentive to their clients, and to do significantly more quickly.

For more blogs:

Aleph Technologies is a premier IT training and staffing group with state of the art facilities based in Dallas, Texas. Aleph Technologies specializes in providing hands-on classroom based and onsite IT certification training courses taught by expert instructors with practical industry experience.