This is a guide to setting up the development environment for this project as well as running and testing it.
Clone your repository using your method of choice.
For all of this to work, it's critical that you have Mongo installed and working. This should be true for all the lab computers, but if you want to also work on your own computer you will need to set it up there as well.
If you're unsure if it's set up and working correctly, try running mongo
.
If your MongoDB server isn't running you'll likely get an error
message like:
Error: couldn't connect to server 127.0.0.1:27017, connection attempt failed: SocketException: Error connecting to 127.0.0.1:27017 :: caused by :: Connection refused :
(Type exit
to exit out of the mongo
tool.)
Launch Visual Studio Code, and then choose File -> Open Folder…
. Navigate to your clone
of the repo and choose Open
.
You may see a dialog that looks like this if you don't already have the recommended extensions:
Don't worry if you don't get the dialog, it is probably because you already have them all installed.
Like in previous labs, click "Install All" to automatically install them.
Before you start working you will need to install the dependencies for the client.
- Move into the
client
directory (cd client
) - Run
npm install
To give yourself some data to work with instead of starting with an empty database in our development environment, you need to 'seed' the database with some starter data. Seed data and the seed script are stored in the top level directory database
. To seed the database, move into that directory and run ./mongoseed.sh
(or .\mongoseed.bat
on Windows). This will take each of the JSON files in database/seed/
and insert their elements into the dev
database.
These scripts also drop the database before seeding it so it is clean. You should run this after first cloning the project and again anytime you want to reset the database or you add new seed data to the database/seed/
directory.
dev
database
whenever you run them to ensure that those tests happen in a predictable
state, so be prepared for that.
❗ You'll want to create your own seed files and add them to the
database/seed/
directory for new types used by your project. There
are nice tools like
next.json-generator.com that you
can use to easily generate sophisticated seed data for your project.
- The run Gradle task (
./gradlew run
in theserver
directory) will still run your Javalin server (a.k.a., the server side of your application), which is available atlocalhost:4567
. - The build task will still build the server (including running Checkstyle and all the tests), but not run it.
Once you have successfully run npm install
, in order to serve up the client side of your project, you will run
ng serve
(from the client
directory as well). The client will be available by default at localhost:4200
. If your server is running, you will be able to see data for users if you navigate to the right place in the project.
To recap, here are the steps needed to run the project:
- Go into the
server
directory and enter./gradlew run
. - In a different terminal, go into the
client
directory and enterng serve
. - You can then go to
localhost:4200
in your favorite web browser and see your nifty Angular app.
We have included the MongoDB for VS Code in the recommended extensions. This extension allows you to view and edit things in the Mongo database.
Expand for setup instructions
When installed you will see a new icon in the sidebar, click it and click "Add Connection".
That will open a new tab with some options. Click "Open form" under "Advanced Connection Settings"
You can leave all the default settings and click the green "Connect" button to add the connection.
You will then have the MongoDB server in the sidebar.
You can explore the databases and collections here. You can click a record to view and edit it.
There are numerous testing options! You should definitely add:
- JUnit tests for your server code
- Karma/Angular tests for your client code
- End-to-end (E2E) tests that exercise the entire system
From the client
directory, ng test
runs the client tests.
- This will pop up a Chrome window with the results of the tests.
- This will run "forever", updating both in your terminal and in the Chrome
window that gets generated. Typing CTRL-C in the terminal window will end
the
ng test
process and close the generated Chrome window. - You can add
ng test --no-watch
if you just want to run the tests once instead of going into the "run forever" mode. - You can add
ng test --code-coverage
if you want to compute the code coverage.- It outputs the test coverage percentages and will fail if any are lower than 80%.
- It generates a coverage report you can find in your client directory
client/coverage/client/index.html
. - Right click on
index.html
in VSCode and selectCopy path
and paste it into your browser of choice. You can also drag and dropindex.html
onto the tab area of your browser and it will open it.
- We frequently combine these with
ng test --no-watch --code-coverage
.
We have included a tool called ESLint which helps analyze the client
TypeScript and template HTML code and catch various errors and concerns. You will most likely see it directly in VS Code as yellow and red underlines. You can also directly run the linter on the entire client by running ng lint
in the terminal in the client
directory. This will check the whole client project and tell you if there are any issues.
From the server
directory, ./gradlew test
runs the server tests once.
- It generates a report you can find in
server/build/reports/tests/test/index.html
. - If you use
./gradlew test jacocoTestReport
it also generates a coverage report.- You can find the report
server/build/jacocoHtml/index.html
, in addition to the regular report generated by thetest
task. - It will fail if any of the the test coverage metrics is under 80%.
- You can find the report
./gradlew check
will run both the tests and Checkstyle, which will look for style issues in your Java code. The GitHub Actions are set to use./gradlew check
, and will fail if Checkstyle finds any violations, so you want to run that locally as well so you're not surprised when you push your changes to GitHub.
In addition to these automated server tests, you might want to manually explore the requests and different parameters at the API level. To see what is happening and explore your API, you can use Thunder Client. There are more instructions about how to do this in here.
End to end (E2E) testing involves the whole software stack rather than one part of it. Our E2E tests look at the behavior of both the client, the server, and the database, and how they interact by simulating how a real user would interact with the app.
We use Cypress for our end-to-end tests. There are a few ways to run the E2E tests. They are all started from the client
directory and require the server be running at the same time (./gradlew run
in the server
directory).
ng e2e
both builds and serves the client and runs through all the Cypress end-to-end tests once.ng e2e --watch
builds and serves the client but just opens Cypress for you to be able to run the tests you want without closing automatically.- This is the same as running
ng serve
andnpm run cy:open
(ornpx cypress open
) at the same time. If you are already runningng serve
it will be easier to do this rather than closing it and runningng e2e
.
- This is the same as running
The main page of Cypress looks like this:
You can click on any of the integration test files to run their tests or run them all. When you run a set of tests you will see something like this:
There are a lot of neat things you can do here like inspect each test and find which selectors to use in the tests you are writing. We encourage you to look through some of the Cypress documentation linked in the "Resources" section below.
There are several GitHub Actions workflows set up in the repo:
- Server Java - JUnit tests for the server (
gradle-build
) - Client Angular - Karma tests (
ng-test
) and ESLint linting (ng-lint
) for the client - End to End - Cypress tests for end-to-end testing