A simple web app to consume and create REST APIs
- Git
- Python 3.6+
- npm (Node.js package manager)
git clone git@github.com:JoshLarouche/contact-manager-app.git
cd contact-manager-app
python -m venv venv
source ./venv/bin/activate
pip install -r requirements.txt
python manage.py migrate
python manage.py runserver
cd app
npm install
npm start
- Docker
- Docker Compose
docker-compose build
docker-compose up
docker-compose down
Make sure to have the necessary prerequisites installed before following these steps.
For running the app locally, you have the option to set up a virtual environment for Python, which is recommended for isolating dependencies.
For running the app in a Docker container, ensure that Docker and Docker Compose are installed on your system.
To run the frontend tests, in the app folder,
npm test
To run with a coverage report,
npm run test -- --coverage .
To run the backend tests, in the root folder,
python manage.py test
To run with a coverage report,
coverage run manage.py test
coverage report
One of the user stories required user authentication and I have implemented that with the use of OAuth. Below are the sample user credentials.
Password | |
---|---|
admin@contactmanager.com | admin123! |
This README contains a list of test cases for the Contact Management Application based on the user stories provided.
I have implemented some executable tests in the application but due to time constraints I kept to simple examples.
- Preconditions: None
- Steps:
- Access the application link as an unauthenticated public user.
- Expected Result: The user can access the application successfully.
- Preconditions:
- The application is accessible to the user.
- Steps:
- Navigate to the contacts section of the application.
- Expected Result: The user can view a list of all 10 existing contacts, including their name, email, phone, website, and company name.
- Preconditions:
- The application is accessible to the user.
- There are no existing contacts in the system.
- Steps:
- Access the contacts section of the application.
- Expected Result: The user sees a message indicating that there are no contacts to display.
- Preconditions:
- The application is accessible to the user.
- The user is viewing the list of all existing contacts.
- Steps:
- Click on a contact's name in the list.
- Expected Result: The user is directed to a contact details page showing all information (name, email, phone, website, and company name) for the selected contact.
- Preconditions:
- The application is accessible to the user.
- The user is on the contacts page.
- Steps:
- Locate the name filter input field.
- Enter text in the name filter input field.
- Expected Result: The user is able to enter text in the name filter.
- Preconditions:
- The application is accessible to the user.
- The user has entered text in the name filter.
- Steps:
- Observe the list of contacts displayed after applying the filter.
- Expected Result: The list of contacts displayed should only include names that contain the text entered by the user.
- Preconditions:
- The application is accessible to the user.
- The user has entered text in the name filter.
- Steps:
- Locate the clear button (if available) next to the name filter.
- Click the clear button.
- Expected Result: The name filter is cleared, and the user sees the full list of contacts again.
- Preconditions:
- The application is accessible to the user.
- The user is on the contacts page.
- Steps:
- Enter text in the name filter using a combination of uppercase and lowercase letters.
- Expected Result: The filter should be case-insensitive and display contacts with names that match the provided text regardless of letter casing.
- Preconditions:
- The application is accessible to the user.
- The user is on the contacts page.
- Steps:
- Locate the "Create contact" button.
- Click the "Create contact" button.
- Expected Result: The user is able to click the "Create contact" button.
- Preconditions:
- The application is accessible to the user.
- The user has clicked the "Create contact" button.
- Steps:
- Provide the required information (name, email, phone, website, company name).
- Submit the information to create a new contact.
- Expected Result: A new contact is created and displayed along with the other existing contacts.
- Preconditions:
- The application is accessible to the user.
- The user has clicked the "Create contact" button.
- Steps:
- Provide only partial information (e.g., name and email) for creating a new contact.
- Submit the information.
- Expected Result: The system should not allow the creation of a new contact with incomplete information and should display an error message.
- Preconditions:
- The application is accessible to the user.
- The user has clicked the "Create contact" button.
- The contact information provided matches an existing contact.
- Steps:
- Provide information for creating a new contact where the combination of name and email matches an existing contact.
- Submit the information.
- Expected Result: The system should prevent the creation of a duplicate contact and display an error message.
- Preconditions:
- The user has an account.
- The application is accessible to the user.
- Steps:
- Enter incorrect account credentials.
- Attempt to log in.
- Expected Result: Authentication should fail, and the system should display an error message.
- Preconditions:
- The application is accessible to the user.
- The user has an account.
- The user is authenticated but doesn't have the necessary permissions to edit contacts.
- Steps:
- Attempt to access the "edit contact" functionality.
- Expected Result: The user, even when authenticated, should not be able to access the "edit contact" functionality if they don't have the required permissions.
These test cases provide comprehensive coverage for the main functionality described in the user stories, including various scenarios and edge cases.
I have completed all of the base criteria and bonus criteria to some degree, including setting up a CI pipeline that runs CodeQL successfully and an inital start on a docker build and push workflow.
I assumed bonus user story 2 meant that an authenticated user could update a contact, not just create one as an unauthenticated user can.
- improve commenting
- improve test coverage
- improve dockerization
- improve CI pipeline
- clean up styling