Use Case Diagram for the Chess Game

Learn how to define use cases and create the corresponding use case diagram for the chess game.

Let’s build the use case diagram of the chess game and understand the relationship between its different components.

First, let’s define the different elements of our chess game, followed by the complete use case diagram of the system.

System

Our system is a "Chess game."

Actors

Here are the main actors of our chess game.

Primary actors

  • Player: This is the primary user and is responsible for playing the chess game. It can start a new game, make move or resign/forfeit a game.

Secondary actors

  • Admin: This can add, remove, or update a player's account and membership, view open games, and validate player moves.

Use Cases

In this section, we'll define the use cases for the chess game. We have listed down the use cases according to their respective interactions with a particular actor.

Note: You will see some use cases occurring multiple times because they are shared among different actors in the system.

Player

  • Create/Update account: To create a new account to play a chess game or to update account information of an existing account

  • Login/Logout: To log in to or log out from an account

  • View open games: View available games that are waiting for players to join

  • Join a game: Join an open game

  • Create a new game: To create a new game to start playing

  • Make move: To make a move in the game

  • Resign or forfeit a game: To resign or forfeit a game so that it ends

Admin

  • Block/unblock member: To block or unblock a member from playing the chess game

  • Cancel/Update membership: To cancel the membership or to update the membership of an account

  • Add/modify member: To add a new member or update member information

  • Login/Logout: To log in to or log out from an account

  • View open games: View available games that are waiting for players to join

  • Validate Moves: To validate player move

  • Declare results: To declare the result of the game when the game is over

Relationships

This section describes the relationships between and among actors and their use cases.

Include

  • The “Make move” has an include relationship with the “Validate move” because the admin has to validate if the move was as per the rules set.

  • The “Resign or forfeit a game” use case has an include relationshop with the “Declare result” use case because the game will be over, and results will be declared when a player either resigns or forfeit from the game.

Extend

  • The “Block/unblock member” has an extend relationship with the “Cancel/Update membership” since when the admin unblocks a member, there is a chance that their membership will be updated. When the admin blocks a member, its membership might be canceled.

  • The “Validate move” use case has an extend relationshop with the “Declare result” use case as there is a chance that the game will be over and results will be declared when a player makes a validate move and checkmate another player.

Generalization

The “Make move” has a generalization relationship with the “Play pawn”, “Play bishop”, “Play king”, “Play queen”, “Play knight”, and “Play rook”, since a player can make any of these six moves.

Associations

The table below shows the association relationship between actors and their use cases.

Level up your interview prep. Join Educative to access 80+ hands-on prep courses.