Dela via


Scenario Overview: Change Your Design Using Visualization and Modeling

To make sure that your software system meets its users' needs, use the visualization and modeling tools in Visual Studio Ultimate to help you update or change the design of the system. These tools include Unified Modeling Language (UML) diagrams, layer diagrams, code-based dependency graphs, sequence diagrams, and class diagrams. For example, you can use these tools to perform these tasks:

  • Clarify users' requirements and business processes.

  • Visualize and explore existing code.

  • Describe changes to an existing system.

  • Verify that the system meets its requirements.

  • Keep code consistent with the design.

This walkthrough uses an example scenario to achieve the following goals:

  • Provide a high-level overview of the tools and their benefits to a software project.

  • Show how two teams might use these tools in an example scenario, regardless of their development approaches.

For more information about these tools and the scenarios that they support, see:

In This Topic

Section

Description

Scenario Overview

Describes the example scenario and its participants.

Roles of Architecture and Modeling Diagrams in Software Development

Describes the roles that these tools can play during the software development lifecycle.

Understanding and Communicating Information about the System

Provides a high-level overview of how the participants use the tools in this scenario.

Updating the System using Visualization and Modeling

Provides deeper detail about each tool and how it can be used in this scenario.

Scenario Overview

This scenario describes episodes from the software development lifecycles of two fictitious companies: Dinner Now and Lucerne Publishing. Dinner Now provides a Web-based meal delivery service in Seattle. Customers can order meals and pay for them on the Dinner Now Web site. The orders are then sent to the appropriate local restaurant for delivery. Lucerne Publishing, a company in New York, runs several businesses both off and on the Web. For example, they run a Web site where customers can post restaurant reviews.

Lucerne recently acquired Dinner Now and wants to make the following changes:

  • Integrate their Web sites by adding restaurant review capabilities to Dinner Now.

  • Replace Dinner Now's payment system with Lucerne's system.

  • Expand the Dinner Now service across the region.

Dinner Now uses SCRUM and eXtreme Programming. They have very high test coverage and very little unsupported code. They minimize risks by creating small but working versions of a system and then adding functionality incrementally. They develop their code over short and frequent iterations. This lets them embrace change confidently, refactor code frequently, and avoid "big design up front".

Lucerne maintains a vastly larger and complex collection of systems, some of which are more than 40 years old. They are very cautious about making changes because of the complexity and scope of legacy code. They follow a more rigorous development process, preferring to design detailed solutions and to document the design and changes that occur during development.

Both teams use modeling diagrams in Visual Studio Ultimate to help them develop systems that meet the users' needs. They use Team Foundation Server alongside other tools to help them plan, organize, and manage their work.

For more information about Team Foundation Server, see:

  • Planning and tracking work

  • Testing, validating, and checking in updated code

Roles of Architecture and Modeling Diagrams in Software Development

The following table describes roles that these tools can play during multiple and various stages of the software development lifecycle:

User Requirements Modeling

Business Process Modeling

System Architecture & Design

Code Visualization & Exploration

Verification

Use case diagram (UML)

Activity diagram (UML)

Class diagram (UML)

Component diagram (UML)

Sequence diagram (UML)

Domain-Specific Language (DSL) diagram

Layer diagram, layer validation

Dependency graph (code-based)

Sequence diagram (code-based)

Class Designer (code-based)

Architecture Explorer

To draw UML diagrams and layer diagrams, you must create a modeling project as part of an existing solution or a new one. These diagrams must be created in the modeling project. Items on UML diagrams are part of a common model, and the UML diagrams are views of that model. Items on layer diagrams are located in the modeling project, but they are not stored in the common model. Code-based dependency graphs, sequence diagrams, and class diagrams usually exist outside the modeling project.

See:

To show alternate views of the architecture, you can reuse certain elements from the same model on multiple or different diagrams. For example, you can drag a component to another component diagram or to a sequence diagram so that it can function as an actor. See Edit UML Models and Diagrams.

Both teams also use layer validation to make sure that code under development remains consistent with the design.

See:

  • Keeping Code Consistent with the Design

  • Describe the Logical Architecture: Layer Diagrams

  • Validate Code with Layer Diagrams

    Note

    Visual Studio Premium supports layer validation and read-only versions of these graphs and diagrams for visualization and modeling.

Understanding and Communicating Information about the System

There is no prescribed order for using the Visual Studio Ultimate modeling diagrams, so you can use them as they fit with your needs or approach. Usually, teams revisit their models iteratively and frequently throughout a project. Each diagram offers particular strengths to help you understand, describe, and communicate different aspects of the system under development.

Dinner Now and Lucerne communicate with each another and with project stakeholders by using diagrams as their common language. For example, Dinner Now uses diagrams to perform these tasks:

  • Visualize existing code.

  • Communicate with Lucerne about new or updated user stories.

  • Identify changes that are required to support new or updated user stories.

Lucerne uses diagrams to perform these tasks:

  • Learn about the Dinner Now business process.

  • Understand the design of the system.

  • Communicate with Dinner Now about new or updated user requirements.

  • Document updates to the system.

The diagrams are integrated with Team Foundation Server so the teams can plan, manage, and track their work more easily. For example, they use models to identify test cases and development tasks and to estimate their work. Lucerne links Team Foundation Server work items to model elements so that they can monitor progress and make sure that the system meets the users' requirements. For example, they link use cases to test case work items so they can see that use cases are fulfilled when all the tests pass.

Before teams check in their changes, they validate the code against the tests and the design by running builds that include layer validation and automated tests. This helps make sure that the updated code does not conflict with the design and break previously working functionality.

See:

  • Understanding the role of the system in the business process

  • Describing new or updated user requirements

  • Creating tests from models

  • Identifying changes to the existing system

  • Keeping code consistent with the design

  • General tips for creating and using models

  • Planning and tracking work

  • Testing, validating, and checking in updated code

Understanding the Role of the System in the Business Process

Lucerne wants to learn more about the Dinner Now business process. They create the following diagrams to clarify their understanding with Dinner Now more easily:

Diagram

Describes

Use case diagram (UML)

See:

  • The activities that the Dinner Now system supports

  • The people and external systems that perform the activities

  • The major components of the system that support each activity

  • The parts of the business process that are outside the scope of the current system, for example, food delivery

Activity diagram (UML)

See:

The flow of steps that occur when a customer creates an order

Class diagram (UML)

See:

The business entities and terms that used in discussion and the relationships between those entities. For example, Order and Menu Item are part of the vocabulary in this scenario.

For example, Lucerne creates the following use case diagram to understand the tasks that are performed on the Dinner Now Web site and who performs them:

UML Use Case Diagram

UML Use Case Diagram

The following activity diagram describes the flow of steps when a customer creates an order on the Dinner Now Web site. In this release, comment elements identify the roles, and lines create swimlanes, which organize the steps by role:

UML Activity Diagram

UML Activity Diagram

The following class diagram describes the entities that participate in the order process:

UML Class Diagram

UML Class Diagram

Describing New or Updated User Requirements

Lucerne wants to add functionality to the Dinner Now system so that customers can read and contribute restaurant reviews. They update the following diagrams so that they can describe and discuss this new requirement with Dinner Now:

Diagram

Describes

Use case diagram (UML)

See:

A new use case for "Write a restaurant review"

Activity diagram (UML)

See:

The steps that occur when a customer wants to write a restaurant review

Class diagram (UML)

See:

The data that is required to store a review

For example, the following use case diagram includes a new "Write Review" use case to represent the new requirement. It is highlighted in orange on the diagram for easier identification:

UML Use Case Diagram

UML use case diagram

The following activity diagram includes new elements in orange to describe the flow of steps in the new use case:

UML Activity Diagram

UML activity diagram

The following class diagram includes a new Review class and its relationships to other classes so that the teams can discuss its details. Notice that a Customer and a Restaurant can have multiple Reviews:

UML Class Diagram

UML class diagram

Creating Tests from Models

Both teams agree that they need a complete set of tests for the system and its components before they make any changes. Lucerne has a specialized team that performs system and component-level testing. They reuse the tests created by Dinner Now and structure those tests using the UML diagrams:

  • Each use case is represented by one or multiple tests. The elements on the use case diagram link to Test Case work items in Team Foundation Server.

  • Each flow on an activity diagram or system-level sequence diagram is linked to one test at the very least. The test team systematically makes sure that they test every possible path through the activity diagram.

  • The terms used to describe the tests are based on the terms defined by use case, class, and activity diagrams.

As requirements change and the diagrams are updated to reflect those changes, the tests are also updated. A requirement is considered fulfilled only when the tests pass. When it is possible or practical, the tests are defined and based on UML diagrams before implementation starts.

See:

Identifying Changes to the Existing System

Dinner Now must estimate the cost of meeting the new requirement. This depends partly on how much this change will affect other parts of the system. To help them understand this, one of the Dinner Now developers creates the following graphs and diagrams from existing code:

Graph or diagram

Shows

Dependency graph

See:

Dependencies and other relationships in code.

For example, Dinner Now might start by reviewing assembly dependency graphs for an overview of the assemblies and their dependencies. They can drill into the graphs to explore the namespaces and classes in those assemblies.

Dinner Now can also create graphs to explore particular areas and other kinds of relationships in the code. They use Architecture Explorer or Solution Explorer to help them find and select the areas and relationships that interest them.

Code-based sequence diagram

See Visualize code on sequence diagrams.

Sequence of interactions between instances.

Sequence diagrams are generated from method definitions and are helpful for understanding how the code implements method behavior.

Code-based class diagram

See How to: Add Class Diagrams to Projects (Class Designer).

Existing classes in code

For example, the developer uses Architecture Explorer to select the namespaces that she wants to focus on and creates a dependency graph from the code. She adjusts its scope to focus on the areas that will be affected by the new scenario. These areas are selected and highlighted on the graph:

Namespace Dependency Graph

Namespace dependency graph

The developer expands the selected namespaces to see their classes, methods, and relationships:

Expanded namespace dependency graph

Expanded namespace dependency graph with visible cross-group links

The developer examines the code to find the affected classes and methods. She generates sequence diagrams and class diagrams from code to describe and discuss the changes. See Visualize code.

Tip

To see the effects of each change as you make them, regenerate dependency graphs and sequence diagrams from the code after each change.

To describe changes to other parts of the system, such as components or interactions, the team might draw these elements on whiteboards. They might also draw the following diagrams in Visual Studio so that the details can be captured, managed, and understood by both teams:

Diagrams

Describes

Activity diagram (UML)

See:

The flow of steps that occur when the system notices that a customer places an order from a restaurant again, prompting the customer to write a review.

Class diagram (UML)

See:

Logical classes and their relationships. For example, a new class is added to describe a Review and its relationships with other entities, such as Restaurant, Menu, and Customer.

To associate reviews with a customer, the system must store customer details. A UML class diagram can help clarify those details.

Code-based class diagram

See How to: Add Class Diagrams to Projects (Class Designer).

Existing classes in code.

Component diagram (UML)

See:

The high-level parts of the system, such as the Dinner Now Web site, and their interfaces. These interfaces define how components interact with each another through the methods or services that they provide and consume.

Sequence diagram (UML)

See:

The sequence of interactions between instances.

For example, the following component diagram shows the new component, which is a part of the Dinner Now Web Site component. The ReviewProcessing component handles the functionality of creating reviews and appears highlighted in orange:

UML Component Diagram

UML component diagram

The following sequence diagram shows the sequence of interactions that occur when the Dinner Now Web Site checks whether the customer has ordered from a restaurant before. If this is true, then it asks the customer to create a review, which is sent to the restaurant and published by the Web site:

UML Sequence Diagram

UML sequence diagram

Keeping Code Consistent with the Design

Dinner Now must make sure that the updated code stays consistent with the design. They create layer diagrams that describe the layers of functionality in the system, specify the permitted dependencies between them, and associate solution artifacts to those layers.

Diagram

Describes

Layer diagram

See:

The logical architecture of the code.

A layer diagram organizes and maps the artifacts in a Visual Studio solution to abstract groups called layers. These layers identify the roles, tasks, or functions that these artifacts perform in the system.

Layer diagrams are useful for describing the intended design of the system and validating evolving code against that design.

To create layers, drag items from Solution Explorer, dependency graphs, or Architecture Explorer. To draw new layers, use the toolbox or right-click the diagram surface.

To view existing dependencies, right-click the layer diagram surface, and then click Generate Dependencies. To specify intended dependencies, draw new dependencies.

For example, the following layer diagram describes dependencies between layers and the number of artifacts that are associated with each layer:

Layer diagram of integrated payment system

Layer Diagram

To make sure that conflicts with the design do not occur during code development, the teams uses layer validation on builds that are run on Team Foundation Build. They also create a custom MSBuild task to require layer validation in their check-in operations. They use build reports to collect validation errors.

See:

General Tips for Creating and Using Models

  • Most diagrams consist of nodes that are connected by lines. For each diagram type, the toolbox provides different kinds of nodes and lines.

    To open the toolbox, on the View menu, click Toolbox.

  • To create a node, drag it from the toolbox to the diagram. Certain kinds of nodes must be dragged onto existing nodes. For example, on a component diagram, a new port must be added to an existing component.

  • To create a line or a connection, click the appropriate tool in the toolbox, click the source node, and then click the target node. Some lines can be created only between certain kinds of nodes. When you move the pointer over a possible source or target, the pointer indicates whether you can create a connection.

  • When you create items on UML diagrams, you are also adding them to a common model. The UML diagrams in a modeling project are views of that model. Items on a layer diagram are part of the modeling project, even though they are not stored in the common model.

    To see the model, on the Architecture menu, point to Windows, and then click UML Model Explorer.

  • In some cases, you can drag certain items from UML Model Explorer to a UML diagram. Some elements within the same model can be used on multiple or different diagrams to show alternate views of the architecture. For example, you can drag a component to another component diagram or to a sequence diagram to use as an actor.

  • Visual Studio Ultimate supports UML 2.1.2. This overview describes only the major features of the UML diagrams in this release, but there are many books that discuss UML and its use in detail.

See Developing Models for Software Design.

Planning and Tracking Work

Visual Studio Ultimate modeling diagrams are integrated with Team Foundation Server so that you can plan, manage, and track work more easily. Both teams use models to identify test cases and development tasks and to estimate their work. Lucerne creates and links Team Foundation Server work items to model elements, such as use cases or components. This helps them monitor their progress and trace their work back to the users' requirements. This helps them make sure that their changes continue to meet those requirements.

As their work progresses, the teams update their work items to reflect the time that they spent on their tasks. They also monitor and report status on their work by using the following Team Foundation Server features:

  • Daily burndown reports that show whether they will complete the planned work in the expected time. They generate other similar reports from Team Foundation Server to track the progress of bugs.

  • An iteration worksheet that uses Microsoft Excel to help the team monitor and balance the workload between its members. This worksheet is linked to Team Foundation Server and provides focus for discussion during their regular progress meetings. 

  • A development dashboard that uses Office Project to keep the team informed about important project information.

See:

Testing, Validating, and Checking In Code

As the teams complete each task, they check their code into Team Foundation version control and receive reminders from Team Foundation Server, if they forget. Before Team Foundation Server accepts their check-ins, the teams run unit tests and layer validation to verify the code against their test cases and the design. They use Team Foundation Server to run builds, automated unit tests, and layer validation regularly. This helps make sure that the code meets the following criteria:

  • It works.

  • It does not break previously working code.

  • It does not conflict with the design.

Dinner Now has a large collection of automated tests, which Lucerne can reuse because almost all still apply. Lucerne can also build on these tests and add new ones to cover new functionality. Both also use Visual Studio Ultimate to run manual tests.

To make sure that the code conforms to the design, the teams configure their builds in Team Foundation Build to include layer validation. If any conflicts occur, a report is generated with the details.

See:

Updating the System Using Visualization and Modeling

Lucerne and Dinner Now must integrate their payment systems. The following sections show the modeling diagrams in Visual Studio Ultimate help them perform this task:

  • Understand the User Requirements: Use Case Diagrams

  • Understand the Business Process: Activity Diagrams

  • Describe the System Structure: Component Diagrams

  • Describe the Interactions: Sequence Diagrams

  • Visualize Existing Code: Dependency Graphs

  • Define a Glossary of Types: Class Diagrams

  • Describe the Logical Architecture: Layer Diagrams

See:

Understand the User Requirements: Use Case Diagrams

Use case diagrams summarize the activities that a system supports and who performs those activities. Lucerne uses a use case diagram to learn the following about the Dinner Now system:

  • Customers create orders.

  • Restaurants receive orders.

  • The External Payment Processor Gateway, which the Dinner Now Payment System uses to validate payments, is out of scope for the Web site.

The diagram also shows how some of the major use cases divide into smaller use cases. Lucerne wants to use its own payment system. They highlight the Process Payment use case in a different color to indicate that it requires changes:

Highlighting Process Payment on a use case diagram

Highlighting Process Payment on the use case diagram

If development time was short, the team might discuss whether they want to let customers pay restaurants directly. To show this, they would replace the Process Payment use case with one that is outside the Dinner Now system boundary. They would then link the Customer directly to the Restaurant, indicating that Dinner Now would only process orders:

Rescoping Pay Restaurant on the use case diagram

Rescoping Pay Restaurant on the use case diagram

See:

Drawing a Use Case Diagram

A use case diagram has the following major features:

  • Actors represent roles played by persons, organizations, machines, or software systems. For example, Customer, Restaurant, and the Dinner Now Payment System are actors.

  • Use cases represent interactions between actors and the system under development. They can represent any scale of interaction from a single mouse-click or message to a transaction extended over many days.

  • Associations link actors to use cases.

  • A larger use case can include smaller ones, for example, Create Order includes Select Restaurant. You can extend a use case, which adds goals and steps to the extended use case, to indicate that the use case occurs only under certain conditions. Use cases can also inherit from each another.

  • A subsystem represents the software system that is under development or one of its components. It is a large box that contains use cases. A use case diagram clarifies what is inside or outside the subsystem boundary. To indicate that the user must accomplish certain goals in other ways, draw those use cases outside the subsystem boundary.

  • Artifacts link elements on the diagram to other diagrams or documents.

See:

Summary: Strengths of Use Case Diagrams

Use case diagrams help you visualize:

  • The activities that a system supports or does not support

  • The people and external systems that perform those activities

  • The major components of the system that support each activity, which you can represent as subsystems nested inside the parent system

  • How a use case might divide into smaller ones or variations

Relationship to Other Diagrams

Diagram

Describes

Activity diagram

The flow of steps in a use case and those who perform those steps in that use case.

The names of use cases frequently mirror the steps in an activity diagram. Activity diagrams support elements such as decisions, merges, inputs and outputs, concurrent flows, and so on.

See:

Sequence diagram

The sequence of interactions between the participants in a use case.

See:

Class diagram (UML)

The entities or types that participate in the use case.

See:

Understand the Business Process: Activity Diagrams

Activity diagrams describe the flow of steps in a business process and provide a simple way to communicate workflow. A development project can have multiple activity diagrams. Usually, an activity encompasses all actions that result from one external action, such as ordering a meal, updating a menu, or adding a new restaurant to the business. An activity might also describe the details of a complex action.

Lucerne updates the following activity diagram to show that Lucerne processes the payment and pays the restaurant. They replace the Dinner Now Payment System with the Lucerne Payment System as highlighted:

Lucerne payment system on activity diagram

Replacing the Dinner Now Payment System on the activity diagram

The updated diagram helps Lucerne and Dinner Now visualize where the Lucerne Payment System fits into the business process. In this release, comments are used to identify the roles that perform the steps. Lines are used to create swimlanes, which organize the steps by role.

The teams might also consider discussing an alternative story where the customer pays the restaurant instead after the order is delivered. This would create different requirements for the software system.

Previously, Dinner Now drew these diagrams on a whiteboard or in PowerPoint. They now also use Visual Studio Ultimate to draw these diagrams so that both teams can capture, understand, and manage the details.

See:

Drawing an Activity Diagram

An activity diagram has the following major features:

  • An initial node that indicates the first action of the activity.

    The diagram should always have one of these nodes.

  • Actions that describe steps where the user or software performs a task.

  • Control flows that show the flow between actions.

  • Decision nodes that represent conditional branches in the flow.

  • Fork nodes that divide single flows into concurrent flows.

  • Activity final nodes that shows ends of the activity.

    Although these nodes are optional, it is useful to include them on the diagram to show where the activity ends.

See:

Summary: Strengths of Activity Diagrams

Activity diagrams help you visualize and describe the flow of control and information between the actions of a business, system, or program. This is a simple and useful way to describe workflow when communicating with other people.

Relationship to Other Diagrams

Diagram

Description

Use case diagram

Summarize the activities that each actor performs.

See:

Component diagram

Visualize the system as a collection of reusable parts that provide or consume behavior through a well-defined set of interfaces.

See:

Describe the System Structure: Component Diagrams

Component diagrams describe a system as a collection of separable parts that provide or consume behavior through a well-defined set of interfaces. The parts can be on any scale and can connect in any manner.

To help Lucerne and Dinner Now visualize and discuss the system's components and their interfaces, they create the following component diagrams:

External components in the payment system

Components of the Dinner Now payment system

This diagram shows different component types and their dependencies. For example, both the Dinner Now Web Site and the Lucerne Payment System require the External Payment Processor Gateway to validate payments. The arrows between components represent the dependencies that indicate which components require the functionality of other components.

To use the Lucerne Payment System, the Dinner Now Web Site must be updated to use the PaymentApproval and PayableInsertion interfaces on the Lucerne Payment System.

The following diagram shows a specific configuration of components for the Dinner Now Web Site. This configuration indicates that any instance of the Web site consists of four parts:

  • CustomerProcessing

  • OrderProcessing

  • ReviewProcessing

  • PaymentProcessing

These parts are instances of the specified component types and are connected as follows:

Components inside Dinner Now Web site

Components inside the Dinner Now Web Site

The Dinner Now Web Site delegates its behavior to these parts, which handle the functions of the Web site. The arrows between the parent component and its member components show delegations that indicate which parts handle the messages that the parent receives or sends through its interfaces.

In this configuration, the PaymentProcessing component processes customer payments. Therefore, it must be updated to integrate with Lucerne's payment system. In other scenarios, multiple instances of a component type might exist in the same parent component.

See:

Drawing a Component Diagram

A component diagram has the following major features:

  • Components that represent separable pieces of system functionality.

  • Provided interface ports that represent groups of messages or calls which components implement and are used by other components or external systems.

  • Required interface ports that represent groups of messages or calls which components send to other components or external systems. This kind of port describes the operations that a component at least expects from other components or external systems.

  • Parts are members of components and are typically instances of other components. A part is a piece of the internal design of the parent component.

  • Dependencies that indicate components require the functionality of other components.

  • Delegations that indicate parts of a component handle the messages sent from or received by the parent component.

See:

Summary: Strengths of Component Diagrams

Component diagrams help you visualize:

  • The system as a collection of separable parts regardless of their implementation language or style.

  • Components with well-defined interfaces, making the design easier to understand and update when the requirements change.

Relationship to Other Diagrams

Diagram

Description

Dependency graph

Visualize the organization and relationships in existing code.

To identify candidates for components, create a dependency graph and group items by their function in the system.

See:

Sequence diagram

Visualize the sequence of interactions between components or the parts inside a component.

To create a lifeline on a sequence diagram from a component, right-click the component, and then click Create Lifeline.

See:

Class diagram (UML)

Define the interfaces on the provided or required ports and the classes that implement the functionality of the components.

See:

Layer diagram

Describe the logical architecture of the system as it relates to components. Use layer validation to make sure that the code stays consistent with the design.

See:

Activity diagram

Visualize the internal processing that components perform in response to incoming messages.

See:

Visualize Existing Code: Dependency Graphs

Dependency graphs show the current organization and relationships in the code. Items are represented by nodes on the graph, and relationships are represented by links. Dependency graphs can help you perform the following kinds of tasks:

  • Explore unfamiliar code.

  • Understand where and how a proposed change might affect existing code.

  • Find areas of complexity, natural layers or patterns, or other areas that might benefit from improvement.

For example, Dinner Now must estimate the cost of updating the PaymentProcessing component. This depends partly on how much this change will affect other parts of the system. To help them understand this, one of the Dinner Now developers generates dependency graphs from the code and adjusts the scope focus on the areas that might be affected by the change.

The following graph shows the dependencies between the PaymentProcessing class and other parts of the Dinner Now system, which appear selected:

Dependency graph for Dinner Now payment system

Dependency graph for Dinner Now payment system

The developer explores the graph by expanding the PaymentProcessing class and selecting its members to see the areas that are potentially affected:

Methods inside PaymentProcessing and dependencies

Methods inside PaymentProcessing class and their dependencies

They generate the following graph for the Lucerne Payment System to inspect its classes, methods, and dependencies. The team sees that the Lucerne system might also require work to interact with the other parts of Dinner Now:

Dependency graph for Lucerne payment system

Dependency graph for Lucerne Payment System

Both teams work together to determine the changes that are required to integrate the two systems. They decide to refactor some of the code so that it will be easier to update. The PaymentApprover class will move to the DinnerNow.Business namespace and will require some new methods. The Dinner Now classes that handle transactions will have their own namespace. The teams create and use work items to plan, organize, and track their work. They link the work items to model elements where it is useful.

After reorganizing the code, the teams generate a new dependency graph to see the updated structure and relationships:

Dependency graph with reorganized code

Dependency graph with reorganized code

This graph shows that the PaymentApprover class is now in the DinnerNow.Business namespace and has some new methods. The Dinner Now transaction classes now have their own PaymentSystem namespace, which makes it easier to deal with that code later.

Creating a Dependency Graph

  • For a quick overview of source code, follow these steps to generate a dependency graph:

    On the Architecture menu, point to Generate Dependency Graph, and then click For Solution.

    For a quick overview of compiled code, create a blank dependency graph, and then drag assembly files or binary files to the graph surface.

    See Map dependencies across your code on dependency graphs.

  • To explore specific code or solution items, use Solution Explorer or Architecture Explorer to select the items and relationships that you want to visualize. You can then either generate a new graph or add selected items to an existing graph.

    See Map dependencies across your code on dependency graphs and Find code with Architecture Explorer.

  • To help you explore the graph, rearrange the layout so that it suits the kinds of tasks that you want to perform.

    For example, to visualize layering in the code, select a tree layout. See Browse and rearrange dependency graphs.

  • To help you focus on specific areas of the graph, adjust its scope by filtering out items or customizing their appearance. See Edit and customize dependency graphs.

Summary: Strengths of Dependency Graphs

Dependency graphs help you:

  • Learn about the organization and relationships in existing code.

  • Identify areas that might be affected by a proposed change.

  • Find areas of complexity, patterns, layers, or other areas that you could improve to make the code easier to maintain, change, and reuse.

Relationship to Other Diagrams

Diagram

Describes

Layer diagram

The logical architecture of the system. Use layer validation to make sure that the code stays consistent with the design.

To help you identify existing layers or intended layers, create a dependency graph and group related items. To create a layer diagram, drag items from the graph or from Architecture Explorer.

See:

Component diagram

Components, their interfaces, and their relationships.

To help you identify components, create dependency graph and group items by their function in the system.

See:

Class diagram (UML)

Classes, their attributes and operations, and their relationships.

To help you identify these elements, create a graph document that shows those elements.

See:

Class diagram (code-based)

Existing classes in code.

To visualize and modify an existing class in code, use Class Designer.

See How to: Add Class Diagrams to Projects (Class Designer).

Describe the Interactions: Sequence Diagrams

Sequence diagrams describe a series of interactions between parts of a system. The parts can be of any scale. For example, they can range from individual objects in a program to large subsystems or external actors. The interactions can be of any scale and type. For example, they can range from individual messages to extended transactions and can be function calls or Web service messages.

To help Lucerne and Dinner Now describe and discuss the steps in the Process Payment use case, they create the following sequence diagram from the component diagram. The lifelines mirror the Dinner Now Web Site component and its parts. The messages that appear between lifelines follow the connections on the component diagrams:

Sequence diagram for Process Payment use case

Sequence diagram for the Process Payment use case

The sequence diagram shows that when the customer creates an order, the Dinner Now Web Site calls ProcessOrder on an instance of OrderProcessing. Next, OrderProcessing calls ProcessPayment on PaymentProcessing. This continues until the External Payment Processor Gateway validates the payment. Only then does control return to the Dinner Now Web Site.

Lucerne must estimate the cost of updating their payment system to integrate with the Dinner Now system. To help them understand this, one of their developers generates sequence diagrams from the code to visualize the existing interactions.

See:

Drawing a Sequence Diagram

A sequence diagram has the following major features:

  • Vertical lifelines represent actors or instances of software objects.

    To add an actor symbol, which indicates a participant is outside the system under development, click the lifeline. In the Properties window, set Actor to True. If the Properties window is not open, press F4.

  • Horizontal messages represent method calls, Web service messages, or some other communication. Execution occurrences are vertical shaded rectangles that appear on lifelines and represent the periods during which receiving objects process calls.

  • During a synchronous message, the sender object waits for control to <<return>> as in a regular function call. During an asynchronous message, the sender can continue immediately.

  • Use <<create>> messages to indicate the construction of objects by other objects. It should be the first message sent to the object.

See:

Summary: Strengths of Sequence Diagrams

Sequence diagrams help you visualize:

  • The flow of control that transfers between actors or objects during the execution of a use case.

  • The implementation of a method call or message.

Relationship to Other Diagrams

Diagram

Description

Class diagram (UML)

Define the classes that lifelines represent and the parameters and return values that are used in messages sent between lifelines.

To create a class from a lifeline, right-click the lifeline, and then click Create Class or Create Interface. To create a lifeline from a type on a class diagram, right-click the type, and then click Create Lifeline.

See:

Component diagram

Describe the components that lifelines represent and the interfaces that provide and consume the behavior represented by messages.

To create a lifeline from a component diagram, right-click the component, and then click Create Lifeline.

See:

Use case diagram

Summarize the interactions between users and components on a sequence diagram as a use case, which represents a user's goal.

See:

Define a Glossary of Types: Class Diagrams

Class diagrams define the entities, terms, or concepts that participate in the system and their relationships with one another. For example, you can use these diagrams during development to describe the attributes and operations for each class, regardless of their implementation language or style.

To help Lucerne describe and discuss the entities that participate in the Process Payment use case, they draw the following class diagram:

Process Payment entities on the class diagram

Process Payment entities on a class diagram

This diagram shows that a Customer can have many orders and different ways to pay for orders. BankAccount and CreditCard both inherit from Payment.

During development, Lucerne uses the following class diagram to describe and discuss the details of each class:

Process Payment entity details on a class diagram

Process Payment details on the class diagram

See:

Drawing a Class Diagram

A class diagram has the following major features:

  • Types such as classes, interfaces, and enumerations:

    • A class is the definition of objects that share specific structural or behavioral characteristics.

    • An interface defines a part of the externally visible behavior of an object.

    • An enumeration is a classifier that contains a list of literal values.

  • Attributes are values of a certain type that describe each instance of a classifier. A classifier is a general name for types, components, use cases, and even actors.

  • Operations are methods or functions that instances of a classifier can perform.

  • An association indicates some kind of relationship between two classifiers.

    • An aggregation is an association that indicates a shared ownership between classifiers.

    • A composition is an association that indicates a whole-part relationship between classifiers.

    To show aggregations or compositions, set the Aggregation property on an association. Shared shows aggregations and Composite shows compositions.

  • A dependency indicates that changing the definition of one classifier might change the definition of another classifier.

  • A generalization indicates that a specific classifier inherits part of its definition from a general classifier. A realization indicates that a class implements the operations and attributes offered by an interface.

    To create these relationships, use the Inheritance tool. Alternatively, a realization can be represented as a lollipop.

  • Packages are groups of classifiers, associations, lifelines, components, and other packages. Import relationships indicate that one package includes all definitions of another package.

As a starting point to explore and discuss existing classes, you can use Class Designer to create class diagrams from code.

See:

Summary: Strengths of Class Diagrams

Class diagrams help you define:

  • A common glossary of terms to use when discussing the users' needs and the entities that participate in the system. See Modeling User Requirements.

  • Types that are used by parts of the system, such as components, regardless of their implementation. See Modeling the Architecture of a Software System.

  • Relationships, such as dependencies, between types. For example, you can show that one type can be associated with multiple instances of another type.

Relationship to Other Diagrams

Diagram

Description

Use case diagram

Define the types that are used to describe goals and steps in use cases.

See:

Activity diagram

Define the types of data that pass through object nodes, input pins, output pins, and activity parameter nodes.

See:

Component diagram

Describe components, their interfaces, and their relationships. A class might also describe a complete component.

See:

Layer diagram

Define the logical architecture of the system as it relates to classes.

Use layer validation to make sure that the code stays consistent with the design.

See:

Sequence diagram

Define the types of lifelines and the operations, parameters, and return values for all messages that the lifeline can receive.

To create a lifeline from a type on a class diagram, right-click the type, and then click Create Lifeline.

See:

Dependency graph

Visualize the organization and relationships in existing code.

To identify classes, their relationships, and their methods, create a graph document that shows those elements.

See:

Describe the Logical Architecture: Layer Diagrams

Layer diagrams describe the logical architecture of a system by organizing the artifacts in your solution into abstract groups, or layers. Artifacts can be many things, such as namespaces, projects, classes, methods, and so on. Layers represent and describe the roles or tasks that the artifacts perform in the system. You can also include layer validation in your build and check-in operations to make sure that the code stays consistent with its design.

To keep the code consistent with the design, Dinner Now and Lucerne use the following layer diagram to validate their code as it evolves:

Layer diagram of integrated payment system

Layer diagram for Dinner Now integrated with Lucerne

The layers on this diagram link to the corresponding Dinner Now and Lucerne solution artifacts. For example, the Business layer links to the DinnerNow.Business namespace and its members, which now include the PaymentApprover class. The Resource Access layer links to the DinnerNow.Data namespace. The arrows, or dependencies, specify that only the Business layer can use the functionality in the Resource Access layer. As the teams update their code, layer validation is performed regularly to catch conflicts as they occur and to help the teams resolve them promptly.

The teams work together to incrementally integrate and test the two systems. They first make sure that PaymentApprover and the rest of Dinner Now work with one another successfully before they deal with PaymentProcessing.

The following dependency graph shows the new calls between the Dinner Now and PaymentApprover:

Updated dependency graph with integrated system

Dependency graph with updated method calls

After they confirm that the system works as expected, Dinner Now comments out the PaymentProcessing code. The layer validation reports are clean, and the resulting dependency graph shows that no more PaymentProcessing dependencies exist:

Dependency graph without PaymentProcessing

Dependency graph without PaymentProcessing

See:

Drawing a Layer Diagram

A layer diagram has the following major features:

  • Layers describe logical groups of artifacts.

  • A link is an association between a layer and an artifact.

    To create layers from artifacts, drag items from Solution Explorer, dependency graphs, or Architecture Explorer. To draw new layers and then link them to artifacts, use the toolbox or right-click the diagram surface to create the layers, and then drag items to those layers.

    The number on a layer shows the number of artifacts that are linked to the layer. These artifacts can be namespaces, projects, classes, methods, and so on. When you interpret the number of artifacts on a layer, remember the following:

    • If a layer links to an artifact that contains other artifacts, but the layer does not link directly to the other artifacts, then the number includes only the linked artifact. However, the other artifacts are included for analysis during layer validation.

      For example, if a layer is linked to a single namespace, then the number of linked artifacts is 1, even if the namespace contains classes. If the layer also has links to each class in the namespace, then the number will include the linked classes.

    • If a layer contains other layers that are linked to artifacts, then the container layer is also linked to those artifacts, even though the number on the container layer does not include those artifacts.

    To see the artifacts that are linked to a layer, right-click the layer, and then click View Links to open Layer Explorer.

  • A dependency indicates that one layer can use the functionality in another layer, but not vice versa. A bidirectional dependency indicates that one layer can use the functionality in another layer, and vice versa.

    To display existing dependencies on the layer diagram, right-click the diagram surface, and then click Generate Dependencies. To describe intended dependencies, draw new ones.

See:

Summary: Strengths of Layer Diagrams

Layer diagrams help you:

  • Describe the logical architecture of a system according to the functionality of its artifacts.

  • Make sure that code under development conforms to the specified design.

Relationship to Other Diagrams

Diagram

Description

Dependency graph

Visualize the organization and relationships in existing code.

To create layers, generate a dependency graph, and then group items on the graph as potential layers. Drag the groups from the graph to the layer diagram.

See:

Component diagram

Describe components, their interfaces, and their relationships.

To visualize layers, create a component diagram that describes the functionality of different components in the system.

See:

External Resources

Category

Links

Forums

Blogs

Visual Studio ALM + Team Foundation Server Blog

Technical Articles and Journals

The Architecture Journal - Issue 23: Architecture Modeling and Processes

Other Sites

MSDN Architecture Center

See Also

Concepts

Visualize code

Developing Models for Software Design

Using Models within the Development Process

Use models in Agile development

Validating Your System During Development

Extending UML Models and Diagrams