You will implement a front-end for a blogging service using React library. This is an individual assignment. This assignment will help you
- Make a simple React (version 16.13.1) application before diving into your projects
- Make test suites for the React application you implement
- Let you try out stuff we have learned in our practice sessions
Our blog will support three models: User, Articles, and Comments. You are required to create a total of five pages as shown in the below storyboard, meeting the following requirements:
- Log In page (
/login
)-
You must have the following fields:
JSX Tag type id input email-input input pw-input button login-button -
Users should be able to log-in by filling up the email and password inputs and hitting the log-in button.
-
As we don't have a proper backend, we don't do real, security-aware authentication yet, but users should only be able to log-in with an account with an email of '[email protected]' and password of 'iluvswpp'.
-
When a user tries to log-in with invalid inputs, the frontend should emit
Email or password is wrong
message throughalert
command (in Javascript). -
After logging-in, users should find themselves at the article list page. (
/articles
) That is, when the user tries to go login page after logged in, the page should be redirected to article list page. -
This is the only page that unauthorized users will have access to. Unauthorized users trying to access any other pages should be redirected to this page!
-
- Article list page (
/articles
)-
Users should be able to clearly make out the whole list of articles including article id, (full) article title, and author name in this page.
-
Also, user must be able to go to article create page (
/articles/create
) by hitting:JSX Tag type id button create-article-button -
Upon clicking on the article title, users should be able to access the article's detail page (
/articles/:id
). These article titles must bebutton
but notlink
.
-
- Article write(create) page (
/articles/create
)-
You must have the following fields in Write tab:
JSX Tag type id input or textarea article-title-input input or textarea article-content-input button back-create-article-button button confirm-create-article-button button preview-tab-button button write-tab-button -
Also, you must have the following fields in Preview tab:
JSX Tag type id any plain text (like h1, h3, p, …) article-author any plain text (like h1, h3, p, …) article-title any plain text (like h1, h3, p, …) article-content button back-create-article-button button confirm-create-article-button button preview-tab-button button write-tab-button -
When users fill up the title and contents under Write tab and hit the confirm button (either in Preview tab or Write tab), a new article having the given title and contents should be posted.
-
The created article, of course, should be tagged with your own author id.
-
After creating the article, the user should be redirected to the created article's detail page (
/articles/:id
) -
While creating the article, the user should be able to preview the contents (under the Preview tab by hitting
preview-tab-button
), in the way that it will be shown in the details page. The user should stay in/articles/create
page while seeing the preview. -
After checking the preview, the user should be able to resume writing (under the Write tab by hitting
write-tab-button
). The user should stay in/articles/create
page after hitting thewrite-tab-button
. -
If the title or content input are empty, the confirm button should be disabled.
-
The back button will go back to the article list page (
/articles
) (also without any alert).
-
- Article detail page (
/articles/:id
)-
You must have the following fields:
JSX Tag type id any plain text (like h1, h3, p, …) article-author any plain text (like h1, h3, p, …) article-title any plain text (like h1, h3, p, …) article-content input or textarea new-comment-content-input button confirm-create-comment-button button edit-comment-button button delete-comment-button button edit-article-button button delete-article-button button back-detail-article-button -
Users should be able to clearly make out the title, contents, and author name of the article.
-
Also, users should be able to see the whole comments for the corresponding article including the author name and contents of each comments.
-
Simple comments functionalities (Create for everyone / Edit & Delete for the comment author through the buttons) should work.
- When a user hits the
confirm-create-comment-button
, a new comment with the contents provided throughnew-comment-content-input
and the author's name should be added to this detail page (without any alert). However,confirm-create-comment-button
should be disabled when thenew-comment-content-input
is empty. - When a user hits the
edit-comment-button
, aprompt
taking some string input should be popped up (by using Javascriptprompt
command) and initial value of the prompt should be same as current comment's content- When the user fill the prompt input with new contents and confirm the pop-up, the contents of the comment should be updated with the new contents.
- When the user confirm the pop-up with empty content, the contents should not be modified (consistent to
user cannot create empty comment
) - When the user canceled the pop-up, the contents should not be modified.
- When a user hits the
delete-comment-button
, the comment should be deleted without any alert. - The edit and delete button for each comment must be visible for the author only.
- When a user hits the
-
Edit & Delete button for the article should work.
- These buttons must be visible for the author only.
- When a user hit the
edit-article-button
, the user should be redirected to the edit page (articles/:id/edit
) - When a user hit the
delete-article-button
, the user should be redirected to the article list page (articles/
) and the article should be deleted without any alert.
-
When a user hits
back-detail-article-button
button, the user should be redirected to the article list page.
-
- Article edit page (
/articles/:id/edit
)-
You must have the following fields in Write tab:
JSX Tag type id input or textarea article-title-input input or textarea article-content-input button back-edit-article-button button confirm-edit-article-button button preview-tab-button button write-tab-button -
Also, you must have the following fields in Preview tab:
JSX Tag type id any plain text (like h1, h3, p, …) article-author any plain text (like h1, h3, p, …) article-title any plain text (like h1, h3, p, …) article-content button back-edit-article-button button confirm-edit-article-button button preview-tab-button button write-tab-button -
Users should see similar stuffs with article create page: Write tab and Preview tab. All requirements for the plain texts and tab buttons are identical to the create page (except the url).
- However, the
article-title-input
should contains current article's title andarticle-content-input
should contains current article's content
- However, the
-
When a user hits
confirm-edit-article-button
, the user should be redirected to the article detail page (articles/:id
) and the edited title and contents should be saved. Any comment for the article should not be modified or deleted by this process. -
When a user hits
back-edit-article-button
, the following features should be supported:- If the title and contents have not been modified yet but are the same as the title and contents before editing, just go back to the detail page without any alert.
- If the title or contents has been modified modified, you should make a confirmation pop-up (through Javascript
confirm
command) with messageAre you sure? The change will be lost.
- If the user accept the confirmation, the user should be redirected to the detail page and the title and contents of the article should not be modified.
- If the user dismiss the confirmation, the user should just stay on the edit page and be able to resume editing.
-
If the title or content input are empty, the confirm button should be disabled (consistent to
/create
).
-
- Common things for all pages:
-
If the user is logged-in, the user should be able to log-out from any of the pages by clicking
logout-button
. Upon logging-out, the user should end on the initial Log In page (shown as dotted lines on the storyboard). -
The
logout-button
should not be displayed before the login.JSX Tag type id button logout-button -
Each user should be able to update or delete articles and comments only which they have created.
-
All pages/components should have proper unit tests to test its functionalities, using Jest and Enzyme that are covered in the practice session. Your tests are expected to cover all of your code, and we will give credits according to your coverage results. You can see the coverage information of your application by using
npm test -- --coverage
. Also, all of your tests must pass.
-
We provide a simple json-server backend with our skeleton code (skeleton/api
).
Due to its simplicity, we do not go over too much into authentication and security for now, but later on (with HW4 and your project), it should be considered.
NOTE: For Windows users
To run the mocked json server in Windows environment, please change the following line in skeleton/package.json
.
From:
"backend": "cp api/db.json api/_db.json && json-server --watch api/_db.json --routes api/routes.json --port 8000"
To:
"backend": "copy /y api₩₩db.json api₩₩_db.json && json-server --watch api₩₩_db.json --routes api₩₩routes.json --port 8000"
To run the server, just type following command at the root of the project
$ yarn install (only for the first time)
$ yarn run backend (or npm run backend)
You should be able to implement your redux action creators by sending appropriate http requests to the following URLs:
API | GET | POST | PUT | DELETE |
---|---|---|---|---|
api/user |
Get user list | X | X | X |
api/user/1 |
Get user information containing whether or not the user is logged_in | X | Update user's logged_in value to log-in/log-out |
X |
api/articles |
Get article list | Create new article | X | X |
api/articles/:id |
Get specified article | X | Edit specified article | Delete specified article |
api/comments |
Get comments | Create new comment | X | X |
api/comments/:id |
Get specified comment | X | Edit specified comment | Delete specified comment |
Articles should have an id
(number), author_id
(number), title
(string), and content
(string).
Comments should have an id
(number), author_id
(number), article_id
(number), and content
(string).
Users should have an id
(number), email
(string), password
(string), name
(string), and logged_in
(boolean).
Each field names are as specified above. You should be able to implement the pages required with these APIs.
Files that are created inside the skeleton
(root) and src
folder have been already discussed during the practice session (contents in this link). As we have done so in our practice sessions, you are expected to add proper components, containers, redux-store (actions, reducers) under the src/
directory freely, according to your needs. Nicely refactored code will result in better readability and is recommended.
The skeleton/api
directory is added to provide simple backend for you to test out your application, and serves as specified above. Please do not modify this directory. You are expected to create store
that manages redux-store by communicating using HTTP, and containers
and components
that produce each pages' requirements. The existing App.js
is expected to be the root component of the entire application.
Also, please do not make any un-requested alerts. It will largely harm the e2e test result.
We will test your code after conducting yarn install
, so you can import other libraries through package.json
. However, you should not change the version of already imported dependencies.
- Most of things have been covered in the tutorial during the lab session. Please look carefully through the slides and the tips provided.
- It might be useful and more pleasing to the eyes by using a CSS framework like Bootstrap-React and SemanticUI-React. However, this is optional, please proceed on your own willings. You might be needing them for your projects ahead, so it would be nice to have some head start.
This assignment is composed of a total of 80 points. We will score your feature implementation (lastest commit before 4 October 6:00 PM) with our e2e test code, having 55 test cases that reflects the requirements given above. You will get 1 point for each passed test case. Also, we will check your unit test coverage (latest commit before 12 October 6:00 PM), which is 25 points in total. Grading details are shown below.
The e2e test consist of cases about:
- Log in page features (4 points)
- Article list page features (5 points)
- Article create page features (10 points)
- Article detail page features when the user is the author of the article (14 points)
- Article detail page features when the user is not the author of the article (13 points)
- Article edit page features (9 points)
Your unit test score will be given based on both test coverage and completeness of your feature implementation.
This is to make sure that your test code is faithful to the feature requirements.
To be more precise, your unit test score will be given as follows:
(scorefeature denotes your feature implementation score)
Coverage | Points |
---|---|
90% and above | 25 * (scorefeature / 55) |
80% and above | 20 * (scorefeature / 55) |
70% and above | 15 * (scorefeature / 55) |
60% and above | 10 * (scorefeature / 55) |
below 60% | 0 |
Note: All your test cases must pass
Since we will automatically score your homework, please make sure that you follow the features specification (especially, the Tag type and id of JSX fields).
Also, if some basic features are not implemented properly, many other test cases can fail. For example, if the logging-in process works badly, most of the cases above will fail. We'll try to give some partial points in this case, but it might not be enough.
It's a good idea to start with the log-in page, and then implement routing features, article list pages, and other features in order.
Finally, since you have to implement many features, start early!
Due: (These are hard deadlines)
- Feature Implementation Due: 10/7 (Wed) 18:00
- Testing Implementation Due: 10/15 (Thu) 18:00
We will check the snapshot of the master branch of your Github repository at the deadline and grade it.
Please name your repository as swpp-hw3-YOUR_USERNAME
, and replace YOUR_USERNAME with your own GitHub username. Please note that USERNAME is case-sensitive.
Refer to HW1 to create another private repository.
Also, make sure to add TA(kdh0102
) as your collaborator in the repository settings.
We automatize the grading process, so your homework may not be graded properly if your directory hierarchy doesn't look like this:
repository_root/
api/
public/
src/
App.js
App.test.js
index.js
...
package.json
...
Also, please include proper .gitignore
file so redundant items are not be pushed to your repository (like node_modules
).
You can use skeleton code's .gitignore
file.
Also, make sure to push your work on Github on time. You won't need to send us an email for submission, but we will pull each repositories at the time specified.