Skip to content

AlexandraFaria/HabitTracker

Repository files navigation

Habit Tracker


A simple habit tracker that allows you to track your habits and analyze them to see how well you're doing.

Table of Contents


-Why is the Habit Tracker beneficial?

-What can the Habit Tracker do?

-System Requirements

-Installation

-How to use the Habit Tracker:

-How to use Test Data and Pytest

Why is the Habit Tracker beneficial?


The Habit Tracker is a beneficial lifestyle application, because it can help to implement positive lifestyle changes that are important to the user.

Psychologically, the user is motivated to continue their habits, so they don't BREAK their longest streak.

What can the Habit Tracker do?


Functionality


The Habit Tracker can log habits:

  • Create a habit
  • Delete a habit
  • Complete a check-off event for a habit
  • View a list of all habits
  • View a list of daily habits
  • View a list of weekly habits
  • Reset a habit by deleting all previous check-off events and select a new start date

The Habit Tracker can analyze habits:

  • Calculate Current Streak per habit
  • Calculate Longest Streak per habit
  • Total check-off events per habit in a selected month
  • Calculate the habit with the longest streak of all habits in the specified frequency (daily or weekly)

System Requirements


  • Python 3.10 +

Installation


Once Python is installed, you will also need to install the following packages using the commandline.

  • Questionary
pip install questionary
  • Pytest
pip install pytest

How to use the Habit Tracker:


  1. Open the terminal of your preferred IDE (Integrated Development Environment) or command line. (For reference I used Pycharm)

  2. Navigate to the directory where the Habit Tracker is located.

  3. Decide whether you would like to use the test data or not. (If you would like to use the test data please proceed to How to use Test Data and Pytest section.) Or proceed to the next step.

  4. Set database to "main.db" by following the steps below:

    • Open the habit.py file and change the database to "main.db" by changing the code in line 10 to the following:
      • Database = "main.db"
  5. Run the Habit Tracker by typing the following command in the terminal:

python main.py
  1. Use the Habit Tracker by selecting which option you would like to use from the main menu.

Note: You can select an option using the arrow keys on your keyboard and pressing enter to select the option you want to use.

  1. Follow the prompts to complete the action you have selected.

-Main Menu:

img.png

- Create Habit

img_1.png

- Check Off Habit

img_2.png

Note: For habit consistency the check-off event is only available for the current date. This does not allow the user to go back in time and complete a check-off event for a previous date. (This is only allowed with the test data.)

- Show List of Habits

img_3.png

All:

img_5.png

Daily:

img_6.png

Weekly:

img_7.png

- Analyze Habit

Longest Streak of All Habits:

img_8.png

Check-off Events for a Specific Month:

Enter a value from 1-12 that corresponds to the month you would like to analyze.

img_11.png

Note: This function allows the user to see the total number of check-off events for each individual habit being tracked for a specific month. (If the habit was not tracked at the time, the total will be 0 for that habit.)

The habits are in ascending order, so the user can see which habit they struggled with the most for any given month.

Current Streak for a Habit:

img_12.png

Longest streak for a Habit:

img_13.png

- Delete Habit

Select the habit you would like to delete from the list:

img_15.png

The habit will then be deleted from the CLI and the database.

img_14.png

- Reset Habit

Resetting the habit allows the user to delete all previous check-off events and select a new start date for the habit. This is useful if the user has not been using the Habit Tracker for an extended period of time, but they are still working on improving that habit.

They may want to reset all the data to get a more accurate representation of their progress.

There are 3 options for resetting the habit:

img_16.png

Note: The user is notified of the current start date for reference to inform their decision of how to modify their start date.

img_17.png

- Exit

The exit function in the Main Menu allows the user to close the Habit Tracker.

img_19.png

Otherwise, the option to Exit throughout the Habit Tracker in all other menus will return the user to the main menu.

img_18.png

How to use Test Data and Pytest

  1. Open the terminal of your preferred IDE (Integrated Development Environment) or command line.
  2. Navigate to the directory where the Habit Tracker is located.
  3. Make sure the habit.py file has the database set to--> Database = "test.db"
  4. Run pytest by typing the following command in the terminal:
pytest.exe

Note:

The conftest.py includes all test fixtures including:

-5 predefined habits (3 daily and 2 weekly)

-4 weeks of check-off events for all 5 habits

  1. After running pytest, the test.db file will be created with the test data. The last two functions in test_habit.py are currently being skipped, so that the user is able to interact with the data from the test.db file while running the main.py file.

  2. Run the Habit Tracker by typing the following command in the terminal:

python main.py
  1. If you would like to run pytest again, I would recommend manually deleting the test.db file after you have used the test data in the main.py file.

To delete the test.db file manually, type the following command in the terminal:

del .\test.db
  1. Then comment out the two fixture notes @pytest.mark.skip in the test_habit.py file. This permits the last two methods to run and deletes all data in the test.db file.

About

Simple Habit Tracker using Questionary as CLI

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages