Developed on MacOS and ARM 64. Fall 2024.
To build and run this project, you need to:
- Clone this repo.
- Install Maven 3.9.5 (Follow the download and installation instructions here: https://maven.apache.org/docs/3.9.5/release-notes.html).
- Install JDK. This project was developed using JDK 17, so this version is recommended. Download the JDK for your device here: https://www.oracle.com/java/technologies/javase/jdk17-archive-downloads.html.
- Install any IDE that can run a Java project. This project was developed using VS Code (Download here: https://code.visualstudio.com/download).
- Set up the project by running the following command in the IndividualProject directory by running the command below. Terminate execution (^C) as soon as you see
System Setup
.
mvn spring-boot:run -Dspring-boot.run.arguments="setup"
To deploy your app on the cloud, you can use Google Cloud Platform's App Engine (overview here: https://cloud.google.com/appengine/docs/an-overview-of-app-engine). To begin, you need to:
- Download and install the gcloud CLI (link: https://cloud.google.com/sdk/docs/install)
- Run the following on your terminal for authentication and setting up your SDK:
gcloud init
- Create a project on Google Cloud Console
- Navigate to the IndividualProject directory in your local copy of the repo and create an
app.yaml
file containing the following:
entrypoint: java -jar target/IndividualProject-0.0.1-SNAPSHOT.jar
runtime: java17
instance_class: F1
- Make sure that you have set up the project as described in step 5 of this section.
- Run the following command, replacing
PROJECT_ID
with your GCP Project ID:
gcloud config set project PROJECT_ID
- Run the following command in your terminal to deploy:
gcloud app deploy
- Running the following command will tell you what URL your app has been deployed in:
gcloud app browse
- Test your app using Postman. You can find a video demo of this app being tested on Postman in the Video-Demo-Link.txt of this repo's root directory.
Voila - Your app is now fully deployed on the cloud!
You can see what the app instance on Google Cloud looks like in the Google-Cloud-Instance.png image found in the root directory of this repo.
The unit tests for this project can be found in the IndividualProject/src/test/java/dev/coms4156/project/individualproject directory. In that directory, you will find unit tests for each of the classes developed for this project.
To run the unit tests, you must first build the project (see here) and run the following command in the IndividualProject directory
mvn clean test
Running the command above will show you if all the unit tests are successful or any errors that occurred.
Style checking was done using the checkstyle tool on Maven. You can run checkstyle using the following command:
mvn checkstyle:check
Below is the checkstyle report as of 09/27/24, showing that there are 0 checkstyle violations:
PMD is used for the static code analysis report (install here: https://pmd.github.io/). Run PMD with the following command,
mvn pmd:check
Below is the PMD report as of 09/26/24:
data:image/s3,"s3://crabby-images/2ce7c/2ce7cd27b104a124ff574aa1f5f9c6d9d31d3a64" alt="Screenshot 2024-09-26 at 23 58 51"
This project uses JaCoco to analyze branch coverage for the unit tests. Run the unit tests first (see here), and then run the following command:
mvn jacoco:report
A target directory will be created (if it doesn't exist already) in IndividualProject and you can find the coverage report in IndividualProject/target/site/jacoco/index.html. Below is the coverage report as of 09/26/24: