Skip to content

Full-stack chess application built as a course project for BYU CS 240. It features a networked client-server architecture, with a command-line client, a server to manage users and games, and shared modules for implementing chess rules and game state management. Created in Winter 2025 by Fletcher Smith.

Notifications You must be signed in to change notification settings

BlondArrow72/chess

Repository files navigation

♕ BYU CS 240 Chess

This project demonstrates mastery of proper software design, client/server architecture, networking using HTTP and WebSocket, database persistence, unit testing, serialization, and security.

10k Architecture Overview

The application implements a multiplayer chess server and a command line chess client.

Sequence Diagram

Modules

The application has three modules.

  • Client: The command line program used to play a game of chess over the network.
  • Server: The command line program that listens for network requests from the client and manages users and games.
  • Shared: Code that is used by both the client and the server. This includes the rules of chess and tracking the state of a game.

Starter Code

As you create your chess application you will move through specific phases of development. This starts with implementing the moves of chess and finishes with sending game moves over the network between your client and server. You will start each phase by copying course provided starter-code for that phase into the source code of the project. Do not copy a phases' starter code before you are ready to begin work on that phase.

IntelliJ Support

Open the project directory in IntelliJ in order to develop, run, and debug your code using an IDE.

Maven Support

You can use the following commands to build, test, package, and run your code.

Command Description
mvn compile Builds the code
mvn package Run the tests and build an Uber jar file
mvn package -DskipTests Build an Uber jar file
mvn install Installs the packages into the local repository
mvn test Run all the tests
mvn -pl shared test Run all the shared tests
mvn -pl client exec:java Build and run the client Main
mvn -pl server exec:java Build and run the server Main

These commands are configured by the pom.xml (Project Object Model) files. There is a POM file in the root of the project, and one in each of the modules. The root POM defines any global dependencies and references the module POM files.

Running the program using Java

Once you have compiled your project into an uber jar, you can execute it with the following command.

java -jar client/target/client-jar-with-dependencies.jar

♕ 240 Chess Client: chess.ChessPiece@7852e922

About

Full-stack chess application built as a course project for BYU CS 240. It features a networked client-server architecture, with a command-line client, a server to manage users and games, and shared modules for implementing chess rules and game state management. Created in Winter 2025 by Fletcher Smith.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published