- Questions that you need to answer (as a team!) are indicated with question mark symbols (:question:)
- Tasks that specify work to do without a written response will be bulleted
- Remember to set up ZenHub with your stories and estimates
Write up your answers to these questions in a Google Doc and turn that in via Canvas on the assignment for this lab.
- Make sure that everyone in your group has edit privileges on the document.
- Make sure that the link you turn in gives us at least comment privileges.
- Include the URL of the GitHub repository for your group at the top of the GDoc. This will make it easier for us to figure out which team is "Snoozing Llamas".
Definitely ask if you're ever confused about what you need to do for a given task, or what the answer to a question is, etc.
The client side of our project has changed since lab #2. The directory structure is mostly the same, but the client-side interface uses Angular to handle most of the creation of the elements of the user interface. Angular's template syntax extends HTML and JavaScript. The testing is handled in two new places (Angular spec files for testing Angular and e2e tests) with new tools (Jasmine/Karma and Protractor).
The starting code includes several interesting
ways of using Angular components to display user data.
It includes two ways of organizing the user-list information:
a list and a grid.
The grid approach to organizing the user-list information
leverages a user-card component.
The user-card component is also used (in a slightly different way) in the user-profile component.
Karma tests for each component are named
almost the same as the component but include .spec
before the .ts
,
and Protractor E2E tests for user-list
are located in e2e/src
inside the client
folder.
❓ Answer questions 1 and 2 in QUESTIONS.
In Lab 2, you worked with your partner to implement an API for requesting
'to-dos' from a server. In this lab, you'll be using a to-do API provided
with the lab. The API meets the specifications of lab 2 and
can be found at localhost:4567/api/todos
when you are running your server
(go into the server directory and execute ./gradlew run
)
Now that we have a reliable way to request todo data from our server, we should write a nice client-side application to help us request and view this data.
-
Use Angular to build a nice client-side interface which allows the user to:
- filter search results by status, owner, body text, and category
- see returned todo items in a useful, meaningful way including:
- choosing to limit the number of todos displayed
- sorting the todos by various fields
-
Your new functionality should be contained in a 'todos' view, with a 'todo-list' component and probably a service.
Note: You do NOT need to have multiple views of your todos like we provided you for users
-
You should make some decisions about when to request data from the API, and when to simply use Angular's filtering tools to change how the data is displayed.
- You have to use Angular's filtering at least once
- You have to use the server's filtering at least once
- ❓ Make note of why you choose to do each of those two things the way you did
❓ Answer question 3 about your filtering in QUESTIONS
Your project should have tests, specifically Karma Angular (client-side) tests that help you meaningfully practice using continuous integration. You should expand on these tests as appropriate so that your GitHub Actions checks are telling you something about the health of your project.
- As you work, create a branch for a new feature, write unit tests for the new Angular components you are adding and using (Karma), write new end-to-end tests for the new views (Protractor), and address failing builds.
- Use pull requests or work together with your lab partner to merge things into master when a feature is working and is tested (with passing tests and decent coverage).
❓ Answer question 4 about your E2E tests in QUESTIONS
- ❓ How does the navigation menu (with Home and Users) work in this project? Compare
server/src/main/java/umm3601/Server.java
andclient/src/app/app-routing.module.ts
. Both do a kind of routing; what does each accomplish and how? - ❓ What does the
user.service.ts
do? Why is it not just done in theuser-list.component.ts
? - You need to use filtering in Angular and filtering on the server each at least one time.
Our example filters users by company on the client side in Angular and filters users by role on the server side in Java.
- ❓ What is one thing you filtered in Angular and why did that approach make sense for that filter?
- ❓ What is one thing you filtered using the server and why did that approach make sense for that filter?
- ❓ What behaviors did you test via your E2E tests? For each behavior:
- ❓ Why did you test that particular behavior?
- ❓ What is the "it" for that test? (You don't need to tell how the test works since your code will do that)