Skip to content

Latest commit

 

History

History
194 lines (129 loc) · 10.6 KB

DEVELOPMENT.md

File metadata and controls

194 lines (129 loc) · 10.6 KB

Development Instructions

This is a guide to setting up the development environment for this project as well as running and testing it.

Setup

Clone your repository using your method of choice.

Make sure you have Mongo running on your computer

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.)

Open the project in VS Code

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:

Dialog suggesting installation of 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.

Installing the client dependencies

Before you start working you will need to install the dependencies for the client.

  1. Move into the client directory (cd client)
  2. Run npm install

Seeding the Database

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.

⚠️ Our example E2E tests also reseed the 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.

Running the project

  • The run Gradle task (./gradlew run in the server directory) will still run your Javalin server (a.k.a., the server side of your application), which is available at localhost: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:

  1. Go into the server directory and enter ./gradlew run.
  2. In a different terminal, go into the client directory and enter ng serve.
  3. You can then go to localhost:4200 in your favorite web browser and see your nifty Angular app.

MongoDB in VS Code

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".

Screenshot of the Mongo Extension pane

That will open a new tab with some options. Click "Open form" under "Advanced Connection Settings"

image

You can leave all the default settings and click the green "Connect" button to add the connection.

image

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.

Screenshot of displaying the users in the sample MongoDB database in VS Code

Testing and Continuous Integration

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

Testing the client

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 select Copy path and paste it into your browser of choice. You can also drag and drop index.html onto the tab area of your browser and it will open it.
  • We frequently combine these with ng test --no-watch --code-coverage.

Linting the client

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.

Testing the server

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 the test task.
    • It will fail if any of the the test coverage metrics is under 80%.
  • ./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 testing

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 and npm run cy:open (or npx cypress open) at the same time. If you are already running ng serve it will be easier to do this rather than closing it and running ng e2e.

The main page of Cypress looks like this:

image

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:

image

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.

GitHub Actions

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