Assignment 9

Due

Exercise 1: User testing of Balsamiq/Figma mockup of your Chat/Messaging App (20%)

For this part of the assignment you will do a user testing session of your Balsamiq/Figma Chat/Messaging App mockup from [HW8 Exercise 2](../hw8/#exercise-2-iterate-and-implement-a-balsamiqfigma-mockup-of-your-chatmessaging-app-30). This is similar to the user testing you did in [HW7 Exercise 3](../hw7/#exercise-3-user-testing-of-calculator-balsamiqfigma-mockup-20) for the high fidelity calculator prototype. Prepare for the user testing by writing a list of three tasks for your user to perform with your medium fidelity mockup. During the study, you will ask your participant to perform three tasks. Using Balsamiq or Figma you can add some interactivity to your design which will help you discover issues your users might have that involve interactions with your design. While the user is performing tasks, try to jot down notes about their behavior and questions. These will be helpful for recalling insights in your writeup.
The participant in your testing session does not have to be a student. It can be anyone you know including a friend or family member. If it is not feasible for you to conduct in-person user testing, contact the staff and we will work with you to develop an alternative remote-testing plan.

**Deliverable:** An HTML page with a short video of your user performing tasks with your paper prototype, and a write up with your three tasks, insights from the user testing, plans for changes, and raw user testing notes in an appendix at the end.

Exercise 2: HTML/CSS + JS for Chat/Messaging App (74%)

This exercise will involve implementing HTML/CSS as well as Javascript functionality. 30% of the grade is for the HTML/CSS and 44% of the grade is for the Javascript functionality. Now that you have iterated on your Chat/Messaging App design, it is time to implement a high fidelity HTML & CSS prototype. This prototype must look like your intended interface but need not provide functionality. Next you will use javascript to add functionality to the HTML & CSS prototype. We have supplied a client library and a server for implementing the chat/messaging app. This week you will be using the client library to add basic functionality to your prototype. In the next assignment you will add custom features developed from the user testing and prototyping cycle. We have also provided a starter skeleton in the homework assignment which has UI for signing up for an account, logging in, and logging out of the messaging server. You will need to serve the skeleton using a local server in order to avoid CORS issues. Any of the following [one line static http servers](https://gist.github.com/willurd/5720255) should work. Your final submission should include the ability to send, receive, and delete messages as well as display a collection of messages. We will be grading you on usability, design, and the quality of your code implementation. The [documentation](js/docs) will be very helpful for understanding the client. Especially the [home page](js/docs/index.html) and [client page](js/docs/Client.html).
You will need to manually trust the certificate on the messaging server. Go to https://128.52.128.220/ in chrome. Chrome will warn you that the connection is insecure. Click advanced and continue to the server. You should see a message which looks like an error `{"message":"Server error","error":{"message":"Not Found","level":"error"}}`. *Debugging* - If you see `Welcome to NGINX` then you are using a url with `http` protocol instead of `https` protocol. You must use https://128.52.128.220/. - If clicking on advanced does not give you an option to continue, click anywhere on the screen and type `thisisunsafe`. If you see the error message described above you should be ok.

If your files don't seem to be updating make sure to clear the cache by holding shift and pressing the refresh button. Alternatively, you can follow [these instructions](https://developers.google.com/web/tools/chrome-devtools/network/reference#disable-cache) to disable the browser cache while the dev tools are open.

Per the course's [collaboration policy](/collaboration.html) that "your code must be your own", you are not allowed to use Javascript libraries or frameworks. However, we will consider allowing certain specific-purpose libraries if they enable interesting UI prospects that would otherwise require a large amount of vanilla JS code and effort.

**Deliverable:** Your functional prototype of the chat/messaging app. Include a short description of what functionality is included either at the top of the HTML file, or near relevant parts.

Exercise 3: Recitation Design Critique (3%)

As we have mentioned, part of learning how to become a good UI designer is practicing the ability to critique and discuss the designs of your peers. In recitation we will do a design critique of [HW8 Exercise 2](../hw8/#exercise-2-iterate-and-implement-a-balsamiqfigma-mockup-of-your-chatmessaging-app-30). 3% of the credit on this assignment is allocated to participating in that design critique. The recitation is held on . The zoom link for recitation is on piazza.

Exercise 4: HW8 Feedback (3%)

Since this is a new class, we need your constructive feedback about every aspect of it: lectures, homeworks, recitations etc. Please go to this [google form](https://docs.google.com/forms/d/e/1FAIpQLSfGKp1fJe3tfzbSAWXbXRpkn5w6y4xOk7w77SS9xnraKv2-qw/viewform) and answer its questions.

Submitting your homework

Similar to the previous assignments, we are going to use Github Classroom again. Authorize Github Classroom here and accept the assignment, then follow the instructions there. Please follow the structure and naming of the starter repo, though you can add any additional files if you need them.

Make sure to update README.md with your Kerberos username, especially if it's different than your GitHub username.

If you push after the deadline, it will count towards your slack hours.