Skip to content

Conversation

@anika-sw
Copy link

No description provided.

Copy link

@yangashley yangashley left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice job on task-list-api! Let me know if you have questions about my comments.

from app.models.goal import Goal
from app.models.task import Task

goals_bp = Blueprint("goals", __name__, url_prefix="/goals")

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This can just be called bp since you've only got one blueprint in this file and you have routes for each model in their own file.


goals_bp = Blueprint("goals", __name__, url_prefix="/goals")

def validate_complete_request(request_body):

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice error handling here, we can't expect users to always give us valid data and need to handle those scenarios afccordingly

Comment on lines +18 to +21
new_goal = Goal(
title=goal_data["title"],
)
return new_goal

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

2 notes:

  • You can use the cls keywork here instead of Goal
  • You can also directly return a dictionary literal without creating the new_goal variable:
return cls(
    title = dict_data["title"],
)

"title": self.title,
"description": self.description,
"is_complete": True
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Notice in to_dict_get_patch, you have several lines of code repeated in each dictionary literal you're returning. What if you used a variable and built up a dictionary using conditional logic and return the dictionary at the end of the function to avoid repetition?

This example flips the logic a little bit but you can see how we build up updated_task so we don't need to repeat a bunch of dictionary literals.

updated_task = {
    "id": self.id,
    "title": self.title,
    "description": self.description
}

if not self.completed_at:
    updated_task["is_complete"]: False
    if self.goal_id:    
        updated_task["goal_id"]: self.goal_id
 
# more logic here to add whatever key/value pairs are needed for updated_task

    return updated_task

Comment on lines +50 to +51
if title_query:
goal_query = Goal.query.filter_by(title=title_query)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👍


tasks = []
for task in goal.tasks:
tasks.append(

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider validating task before appending it to tasks, like:

for task in goal.tasks:
        task = validate_model_id(Task, task.id)
        tasks.append(task)

then you don't need to write out the dictionary literal that represents a task because validate_model_id returns an instance of task.

"goal_id": task.goal_id,
"title": task.title,
"description": task.description,
"is_complete": False

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we're getting all tasks associated with an goal, do we need to hard code is_complete to False? Could a goal have a list of tasks where some are completed and some are not?

Comment on lines +143 to +144
for task in goal.tasks:
task_response.append(

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we just want to get a specific task by id, then we don't want to go through all the tasks in goal.tasks because then we'd end up with a list of all the tasks associated with the goals.

This route repeats the logic in task_routes.py on lines 72-79 where you get a task by id. Here you nest the route under goals. It's up to the developer to decide if you want to have the request to get a single task by ID nested under goals/goal_id/tasks/task_id or if you can just a route that is /tasks/task_id


@tasks_bp.route("", methods=["GET"])
def get_all_tasks_sort_asc():
task_query = Task.query.all()

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here, we should have task_query = Task.query without all() because we dont actually want to go query everything yet. We want to see which request params were provided to the request and then filter or order accordingly. Finally if no request params were provided then we'd want to query for all tasks near the end of this method.

if sort_query == "desc":
task_query = Task.query.order_by(Task.title.desc())

tasks = task_query

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here is where we'd want to query for all tasks if not query params were provided so line 64 should be

tasks = task_query.all()
# rest of logic 

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants