This is the link to the deployed webpage/URL.
This is the link to the GitHub repository for this project.
-
To be able to use the application you first need to register an account - you will be asked to enter a username and a password.
-
When the login is successful, then you are redirected to the "main application". But for a newly created account, there are no tasks created yet.
-
You need to create a task by clicking the button that says "add a task". This will redirect you to a page where you can create a task by giving it a title, description and a check or un-check status. For starters it's maybe relevant that the task is not yet done - so leave it unchecked.
-
After submitting the task, you are redirected back to the task-list where you should see your newly created task.
-
when the task is completed you can edit the task by clicking on the "gear"-icon and edit the task by either adding more info to it or marking it as completed. If you mark it as completed, and re-submit, then you will be redirected back to the task-list and the task is updated with a check-icon, signaling that the task is completed.
-
If you wish to delete a task totally that is possible. Just click on the "trash-bin"-icon next to the task you want to delete, and you will be redirected to a confirmation page where you can either click on "delete task" or you can go back to the "main" task page again.
-
All pages should prioritize good UX by ensuring that users never have to rely on the browser's 'back' button to navigate to a previous page. Instead, each page should provide a clearly labeled link for this purpose, contributing to a seamless user experience.
-
All the pages have a "home" button that takes the user back to the homepage - except the "delete-task"-page - that page only haves a "go back to task list" button that can take the user back to the full-task-list.
- The loginpage has input for users that already has registred themself - they can input username and password and after that klick the "login"-button. But incase they have not registrered themselfs as users, they are promted by a text saying "Are you a new user and need to create an account?" and then a button that takes the user to the register-user-page.
- The same as above, but for the register-user-page. There is a form that the user can fill out with username and then a password and a re-type for the password - and of course a button that says "register". But under that form, there is a text promting already created users with the text "Do you already have an account?" and then a login-button that takes the user to the login-page so that the user can login instead.
- When a user has logged-in successfully - then the user is redirected to their task-dashboard. Here they can view all their tasks.
- They can click on the button "Add a task" to create a new task which will take the user to the create-task-page. Here the user can create a task by giving the task a title, a description (or not) and then uncheck or check the "completed" check-input.
- Once the user clicks on "Create" then the user is re-directed back to the task-list and they can now see their task they just created.
- When a user is at the dashboard (task-list), they can also delete and edit the task. To be able to edit a task the user can click on the button next to the task (settings-icon) and then the user is redirected to the task and the form for that specific task. The user can edit any of the field and re-submit/edit the task. They can for example klick on the "completed" check-box and then resubmit and then the user is redirected to the dashboard and now the user can see a "tick"/check next to the task which is giving a visual sensation of completion which is a choise for a good UX.
- The user can also delete tasks by clicking on the "trash-bin-icon" next to the task - this will redirect the user to a confirmation-page where the user is given a question if the user wants to delete the task - if the user clicks on the delete button, then the user is redicted back to the task-list with a succesful deleted task. On the delete-confirmation page, there is also a way for the user to "go back to task-list" incase the user regretted their choise - which is part of good UX aswell.
-
The user can whenever they want logout from the dashboard which takes the user back to the login-page.
-
On the homepage there is text that gives information about the application and also reassures the user that their personal information is secretley and kept private and safe - this gives the user trust for the service and application. Under that section, there is a carousel giving a "high-tech" feeling towards the appliction - the pictures are not of the application itself but just placeholder images that gives a good design and modern feeling towards the webpage/application.
- Under the bootstrap carousel, there are two cards - one is prompting the user to login if they already have accounts and one is promting the user to create or register an account incase they have not already done that.
- Under this section comes the footer - here is a copyright promt and two icons - one for my personal GitHub nad one for my personal LinkedIn profile.
The UX design of the Django ToDo App focuses on simplicity and ease of use. Here’s a brief overview of the key design elements:
The app is designed to include only the essential features needed for managing tasks. This keeps the interface clean and straightforward, making it easy for users to navigate and manage their tasks without unnecessary distractions.
We carefully selected colors to ensure good contrast between text and backgrounds, making the app easy to read and accessible to all users. This enhances the overall user experience, especially for those with visual impairments.
Fonts were chosen for their clarity, ensuring that text is easy to read on any device. Icons are intuitive and guide users through the app, making actions like editing or deleting tasks simple and understandable.
The app was built with a mobile-first approach, ensuring that it looks and works great on both mobile devices and desktops. The layout adapts smoothly to different screen sizes, providing a consistent experience across all devices.
The app provides clear feedback on user actions, such as marking tasks as complete with a checkmark. Navigation is straightforward, with all pages including links to return to the task list or homepage, so users never have to rely on the browser’s back button.
In summary, the UX design of the Django ToDo App prioritizes simplicity, clarity, and accessibility, making task management easy and enjoyable for all users.
- This is the initial mockup for the application and it shows a user hich is not logged in or authenticated - then the user is taken to the homepage and only gets displayed the homepage, which only leads to the loginpage or the signup/register page. - This mockup shows a user who is authenticated or logged in - the user gets to see their tasks that are savedto the database. From this initial mockup the user can navigate to the homepage again and also log itself out. To the actual project, we added the delete functionality here and also a text displaying to the user how many incomplete tasks the user currently has. - On this page, the use can edit or create a task. The user can also get the ability to mark a task as completed.The Task Management application includes two key database models that define the structure and relationships of the data. Below is an overview of each model and how they are connected.
Purpose:
The User
model is the default model provided by Django's authentication system. It represents the users of the application, storing essential information such as username, password, and email.
Fields:
id
: The primary key for the user, automatically generated by Django.username
: The username chosen by the user for logging in.- Other Fields: The
User
model also includes other standard fields likeemail
,password
, and more, as managed by Django.
Relationships:
- The
User
model is linked to theTask
model via a foreign key, establishing a relationship where each user can have multiple tasks.
Purpose:
The Task
model represents individual tasks that users can create and manage within the application. Each task includes a title, description, completion status, and a timestamp indicating when it was created.
Fields:
user
: A foreign key linking each task to a specific user. This allows tasks to be associated with a particular user.title
: A short title for the task, limited to 200 characters.description
: A more detailed explanation of the task. This field is optional, meaning it can be left blank or null.complete
: A boolean field that indicates whether the task has been completed. By default, this is set toFalse
.created
: A timestamp that records when the task was created. This is automatically set when a new task is created.
Relationships:
- Each
Task
is linked to one user via a foreign key (user
). This establishes a many-to-one relationship where a single user can have multiple tasks, but each task is associated with only one user.
- The User model is at the center of the application, with each user being able to create and manage multiple tasks.
- The Task model holds information about each task, including which user it belongs to, its title, description, completion status, and when it was created.
These models form the core of the Task Management application, allowing users to manage their tasks effectively while maintaining a clean and scalable database structure.
- Database schema:
Field | Type | Description |
---|---|---|
id | Integer | Primary key, auto-generated by Django |
user_id | Integer | Foreign key referencing the User table (nullable) |
title | CharField | Stores the title of the task |
description | TextField | Stores the description of the task (nullable) |
complete | BooleanField | Indicates whether the task is complete or not |
created | DateTimeField | Timestamp of when the task was created |
-
A search function so that the user can search after items after they have created them.
-
A due-date, so that the user can prompt a "end date" or "date to finish" the task to.
-
A way for a user to be able to delete their whole account - both the account and their created tasks.
-
Instead of using a username, the user could be required to enter both their first and last names in the registration form. Then, use the entered first name to greet the user in the tasklist. Currently, the greeting is based on the username, which may not necessarily reflect the user's actual first name. This can be confusing if a user enters a name that is not their first name, and then the page greets them using this potentially unrelated username.
This project has been thoroughly tested across various web browsers to ensure full compatibility and a consistent user experience. Below is a table that details the browsers that were tested, along with the versions and the results.
Browser | Version | Tested | Status |
---|---|---|---|
Google Chrome | 113.0 and above | âś” | Works without errors |
Mozilla Firefox | 102.0 and above | âś” | Works without errors |
Microsoft Edge | 112.0 and above | âś” | Works without errors |
Safari | 16.0 and above | âś” | Works without errors |
- A mobile-first design approach has been implemented throughout the project.
- The design has been thoroughly tested on mobile versions of the browsers listed above.
- The user interface adapts seamlessly across different screen sizes, ensuring an optimal experience on both mobile and desktop devices.
- The project has been tested on the latest stable versions of each browser listed above.
- No issues or errors were encountered during testing across all listed browsers.
- Performance: 92%
- Accessibility: 100%
- Best Practices: 91%
- SEO: 92%
- Description: Under the development environment with DEBUG=True, the Django application raised a TemplateDoesNotExist error for base/task_list.html.
- Solution: Created a templates folder and nested a base folder within it. Added task_list.html inside base with content. Refreshed the browser to confirm resolution, leveraging Django's debug mode (DEBUG) for assistance.
- Description: Declared context_object_name as todo-tasks, causing a TemplateSyntaxError.
- Solution: Renamed todo-tasks to todo_tasks to adhere to Python variable naming conventions, resolving the issue promptly.
- Description: Received an ImproperlyConfigured error on create-task/ due to a typo (fields = 'all').
- Solution: Corrected the typo to fields = 'all' in views.py, resolving the error swiftly.
- Description: Faced a 403 Forbidden error with "CSRF token missing" after submitting a form.
- Solution: Added {% csrf_token %} to the form template. Resubmitted the form, successfully adding the task to the database.
- Description: Encountered a TemplateSyntaxError related to a missing URL template tag ({% url 'tasks' %}).
- Solution: Corrected the URL template tag by adding {% %} around url, resolving the error promptly.
- Description: Discovered an error due to an incorrect href path when adding a back button.
- Solution: Rectified the href path, resolving the issue and enabling correct page loading.
- Description: Users gained unintended access to all tasks in the database, leading to data privacy and access control issues.
- Solution: Implemented data access controls using get_context_data to restrict task access to authenticated users only, ensuring privacy and control over user-specific tasks.
- Description: Encountered a ModuleNotFoundError in Heroku due to a misconfigured directory structure (todo_app.wsgi not found).
- Solution: After extensive debugging and restructuring, resolved the issue by adjusting the directory structure, removing unnecessary nested folders, and redeploying the project on Heroku, successfully resolving the deployment error.
- So far there are no known unsolved bugs - all bugs tht have been encountered during deployment and production phase have been solved succesfully.
-
CSS: No warnings or problems to show - CSS code validated using W3C CSS Validator and JigSaw.
-
HTML: The HTML code passed the W3C validator with no warnings - "Document checking completed. No errors or warnings to show."
-
JavaScript: The JavaScript code for this project passed and got validated using the JSHint with no warnings or errors.
-
Python code passes Linter with "All clear, no errors found". Python code passes PEP8 without issues.
This project was created using the following languages and frameworks:
- Django as the Python web framework.
- Python as the backend programming language.
- HTML as the markup language and templating language.
- CSS as the style sheet language.
- Bootstrap 5 as the CSS framework.
- JavaScript to create footer element that changes
- SQLite to store user data (Relational database)
Test Scenario 1: Verify homepage content and layout
Test Case ID | Test Steps |
---|---|
TC01 | Open the homepage and verify the presence of the title "The Todo App" and the subtitle "Take Control of Your Tasks - Create, Organize, and Accomplish Your Todos with Ease". |
TC02 | Verify that the benefits section contains the correct text and icons for data security, task tracking, and accessibility. |
TC03 | Ensure the carousel displays images correctly and the navigation buttons function as expected. |
TC04 | Check the "Login" and "Register" buttons navigate to the correct pages. |
Test Scenario 2: Verify login functionality
Test Case ID | Test Steps |
---|---|
TC05 | Open the login page and verify the presence of the login form. |
TC06 | Enter valid credentials and submit the form. Ensure successful login and redirection to the task list page. |
TC07 | Enter invalid credentials and submit the form. Ensure appropriate error message is displayed. |
TC08 | Verify the "Register here!" link navigates to the registration page. |
TC09 | Verify the "Home" link navigates back to the homepage. |
Test Scenario 3: Verify registration functionality
Test Case ID | Test Steps |
---|---|
TC10 | Open the registration page and verify the presence of the registration form. |
TC11 | Enter valid details and submit the form. Ensure successful registration and redirection to the login page. |
TC12 | Enter invalid details (e.g., existing username, mismatched passwords) and submit the form. Ensure appropriate error messages are displayed. |
TC13 | Verify the "Login here!" link navigates to the login page. |
TC14 | Verify the "Home" link navigates back to the homepage. |
Test Scenario 4: Verify task creation
Test Case ID | Test Steps |
---|---|
TC15 | Open the task creation page and verify the presence of the task form. |
TC16 | Enter valid task details and submit the form. Ensure the task is added to the task list. |
TC17 | Verify the "Go back to all tasks" link navigates to the task list page. |
TC18 | Verify the "Home" link navigates back to the homepage. |
Test Scenario 5: Verify task list and operations
Test Case ID | Test Steps |
---|---|
TC19 | Open the task list page and verify the presence of tasks, including title and completion status. |
TC20 | Click on the checkbox of a task to mark it as complete/incomplete. Ensure the status updates correctly. |
TC21 | Click the settings icon of a task to update it. Ensure the task details are editable and changes are saved. |
TC22 | Click the delete icon of a task. Confirm the deletion and ensure the task is removed from the list. |
TC23 | Verify the "Add a task" link navigates to the task creation page. |
TC24 | Verify the "Logout" link logs the user out and redirects to the login page. |
TC25 | Verify the "Home" link navigates back to the homepage. |
Test Scenario 6: Verify task deletion confirmation
Test Case ID | Test Steps |
---|---|
TC26 | Open the task deletion confirmation page for a specific task. |
TC27 | Verify the presence of the task details and the confirmation message. |
TC28 | Click the "Delete" button and ensure the task is removed from the task list. |
TC29 | Verify the "Back to task list" link navigates to the task list page. |
- Valid and invalid user credentials for login and registration.
- Sample tasks for creation, update, and deletion.
This manual testing writeup aims to ensure that all critical functionalities of the Todo App are tested thoroughly. The testing will be conducted across different environments to guarantee compatibility and usability, ensuring a high-quality user experience.
To deploy this Django project, follow these steps to fork and clone the repository:
-
Go to the project's GitHub repository at this page
-
Click on the Fork button in the upper right corner of the page.
-
This will create a copy of the repository under your GitHub account.
-
Go to the GitHub repository https://github.com/markohautala/django-auth-crud-app
-
Locate the Code button above the list of files (next to 'Add file') and click it
-
choose a preferred cloning option by selecting either HTTPS or GitHub CLI.
-
Open Git Bash
-
Change the current working directory to the one where you want the cloned directory
-
Type git clone and paste the URL from the clipboard ($ git clone https://github.com/markohautala/django-auth-crud-app)
-
Press Enter to create your local clone
- Log in to the Heroku account.
- Navigate to "New" and click "Create new App".
- Choose a unique app name and click "Create app".
- Select the preferred region (e.g., Europe).
- Go to "Deploy" tab.
- Click "Connect to GitHub".
- Search for the repository name in the search field.
- Click "Search" and then "Connect" next to the right repository.
- Enable "Automatic deploys".
- Click "Deploy branch".
- In the CLI, install Django-Heroku:
pip install django-heroku
. - Install Gunicorn:
pip install gunicorn
. - Install Whitenoise:
pip install whitenoise
. - Create a "runtime.txt" file and specify the Python version (e.g.,
python-3.12.3
). - Create a Procfile and add:
web: gunicorn todo_app.wsgi
. - In settings.py, add Whitenoise middleware:
MIDDLEWARE=['whitenoise.middleware.WhiteNoiseMiddleware']
. - Also in settings.py, set
STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'
. - Add
python-3.12.3
in a "runtime.txt" file (Python version used in the project). - In Procfile, add logging:
web: gunicorn todo_app.wsgi --log-file -
. - Generate requirements.txt:
pip freeze > requirements.txt
. - Import django_heroku and os in settings.py.
- Add the Heroku app's URL to ALLOWED_HOSTS.
- Set
DEBUG=False
in settings.py. - At the end of settings.py, activate Django-Heroku:
django_heroku.settings(locals())
.
-
Additional Steps:
-
If the app has static files (JS, CSS), set config vars by adding
"DISABLE_COLLECTSTATIC"
with a value of"1"
. -
Commit the changes with an appropriate message and push to GitHub.
-
Deploy the changes on Heroku to apply the new configurations.
-
Comprehensive resource for in-depth understanding of Django class-based views: ccbv.co.uk
-
Reference materials aiding comprehension of
get_context_data
in Django: Django Forum Thread -
Utilized color schemes from Color Hunt to enhance page aesthetics.
-
Leveraged Heroku Dev Center documentation for debugging purposes.
-
Incorporated Google Fonts icons from Google Fonts for iconography throughout the application.