USE CASE AGILE (en)
TRELLO
# Exercise: Agile Project Management - Nutrition App for CPAM
Project Context
The CPAM (French Health Insurance) wants to develop a nutrition application to help its beneficiaries adopt a healthier diet and prevent nutrition-related diseases (diabetes, obesity, etc.). This application will offer personalized recommendations, meal tracking, health challenges, and food composition information.
Objective of the Exercise
Practice Agile project management principles by organizing and planning the development of the application using the Scrum methodology.
π Use Trello for this exercise.
1. Team Formation and Roles
- Divide the class into several teams (4 to 6 students per team).
- Each team must define the following roles:
- Product Owner (PO): Defines user needs and prioritizes features.
- Scrum Master (SM): Facilitates team work and ensures Agile principles are followed.
- Developers: Work on implementing the defined features.
- Testers (if applicable): Verify the quality and compliance of developments.
2. Definition of the Product Backlog
Each team must:
- Identify the key features of the application (e.g., user registration, nutritional recommendations, meal tracking, integration with connected devices, etc.).
- User registration and authentication.
- Generation of personalized nutritional recommendations.
- Meal tracking with manual input and image recognition.
- Integration with connected devices (scales, smartwatches, etc.).
- Implementation of health challenges and personalized reminders.
- Dashboard for progress tracking and meal history.
- Access to a database of healthy recipes tailored to the user's needs.
- List of food items with their composition.
- Write User Stories following this format: "As a [user], I want [action] so that [benefit]."
- "As a user, I want to create an account and log in so that I can access my personalized data."
- "As a user, I want to receive tailored nutritional recommendations so that I can improve my diet."
- "As a user, I want to record my daily meals so that I can track my nutrition and receive personalized advice."
- "As a user, I want to synchronize the app with my smartwatch so that I can automatically integrate my health data."
- "As a user, I want to participate in nutrition challenges so that I can stay motivated and improve my eating habits."
- "As a user, I want to access a database of healthy recipes so that I can easily prepare balanced meals."
- "As a user, I want to know the composition of food items."
- Prioritize these User Stories based on their value to the user.
- High Priority: Registration/authentication, nutritional recommendations, meal tracking.
- Medium Priority: Synchronization with connected devices, health challenges.
- Low Priority: Recipe database, detailed meal history.
3. Creating a SCRUM Board
- Columns should be filled progressively as work advances.
- create the story cards
- Example of a Story Card
π Title: Meal Logging in the Application
π User Story:
βAs a user, I want to log my meals so that I can track my nutrition.β
β Acceptance Criteria to consider the Story as completed:
- The user can enter the meal name, quantity, and date.
- The application validates the data before saving.
- Meals are stored and displayed in the history.
π― Priority: High
β³ Estimation: 5 points
π Dependencies: Requires the meal database.
π¬ Notes: Verify error handling in case of incorrect input.
- Example of a Story Card
Scrum Board Example:
Product Backlog | Sprint Backlog | To Do | In Progress | To Test | Done | β Blocked | π Code Review |
Nutritional recommendations | User interface | Meal API | API for connected devices | Test meal display | Registration UI β | ||
Meal tracking | Notification system | Tracking statistics | Food database integration | Mobile compatibility check | Dashboard UI β |
- Blocked (β): Tasks pending resolution (e.g., a critical bug).
- Code Review (π): Tasks requiring validation before testing.
π The Sprint Backlog contains the User Stories selected for the sprint.
β‘ Important: A User Story is too broad to be completed at once β break it down into tasks.
π The "To Do" column contains the technical tasks necessary to complete the User Stories.
Incremental
The incremental approach in Scrum means that the application evolves gradually with each sprint by delivering features usable by the end user. Here's how we see this incremental aspect in the exercise:
1. Defining the Increment in the Exercise
πΉ In each Sprint, the team develops a functional part of the product.
πΉ Each sprint ends with a usable deliverable (e.g., an interface, a working API).
πΉ The application progressively expands over the sprints with new features.
β Each sprint adds a functional block that improves the product.
β We don't build an entire product in six months, but we deliver usable parts every two weeks.
β We continuously improve instead of planning everything upfront.
Iterative
Iterative β We improve existing features by incorporating user feedback.
Concrete example in our project:
- Sprint 1: First version of meal entry. β
- Sprint 2: Adding synchronization with connected devices (incremental). β
- Sprint 3: Improving the meal entry design and fixing bugs (iterative). β
3. Sprint Planning
- Define a 2-week Sprint.
1οΈβ£ Sprint Planning:
- The team selects User Stories and places them in the Sprint Backlog.
- Each User Story is broken down into tasks, which are placed in the To Do column.
- A User Story is broken down into tasks.
Example:
User Story: "As a user, I want to record my meals so that I can track my nutrition."
Associated Tasks:
β Design the user interface for meal input.
β Develop the API for saving meals in the database.
β Create the meals database.
β Implement field validation (e.g., ensure correct input quantities).
β Write tests to verify module functionality.
- π₯ Who decides on the tasks?
β’ Developers: They are the ones doing the work, so they define the necessary technical tasks.
β’ Scrum Master: Ensures that the planning is realistic and smooth.
β’ Product Owner (PO): Steps in if clarification on the user needs is required.
- Example of a Task Card
π Title: Develop Meal Logging API
π Description:
Create a REST API to log a meal in the database with a name, quantity, and date.
β Acceptance Criteria:
β Accept POST requests with valid fields.
β Store data in the database.
β Return a confirmation or error message.
π€ Assigned to: Alice
β³ Estimation: 3 points
π¦ Status: To Do
π Dependencies: Requires the creation of the meal database.
π¬ Notes: Verify user input validation.
- A User Story is broken down into tasks.
- A 2-week sprint provides a good balance between flexibility and tangible progress.
- The goal is to have an incremental version of the product usable at the end of the sprint.
- Select the User Stories to be developed in the Sprint Backlog.
2οΈβ£ Sprint Execution:
- Developers pick tasks from the To Do column and move them to "In Progress".
- Once completed, they move to "Testing", then "Done".
3οΈβ£ Sprint Review:
- Once all tasks of a User Story are completed, the team demonstrates the delivered functionality.
- Choose a set of User Stories that can be completed within 2 weeks.
- Prioritize those that provide immediate value to the user.
- Break down User Stories into smaller, achievable tasks.
- Estimate the associated tasks using a method like Planning Poker.
Planning Poker Estimation
- Each team member assigns an estimate in complexity points (e.g., Fibonacci: 1, 2, 3, 5, 8...).
- The team discusses estimation discrepancies and adjusts if necessary.
- The goal is to have a realistic estimation of the work achievable in 2 weeks.
What is Planning Poker?
Planning Poker is an Agile estimation method used to assess the effort required to complete a User Story. It helps the team reach a consensus on task complexity while avoiding individual biases.
1. Objective of Planning Poker
β Obtain a collective and consensual estimation of a User Story's complexity.
β Prevent a single person from influencing others with their estimation.
β Encourage discussion and understanding of tasks.
2. How Planning Poker Works
π‘ Materials: A set of Planning Poker cards (or an online tool). Each card represents an effort value based on the Fibonacci sequence:
1, 2, 3, 5, 8, 13, 21, 34, β¦ (sometimes including β and ? for uncertainty).
π Step 1: Presenting the User Story
- The Product Owner explains the User Story to the team.
- The team asks questions to fully understand what needs to be done.
π Step 2: Choosing Estimations
- Each team member secretly selects a card representing their effort estimation.
- Estimates consider:
πΉ Technical complexity.
πΉ Development effort.
πΉ Possible uncertainties and risks.
π Step 3: Revealing the Cards
- All members simultaneously reveal their chosen cards.
π Step 4: Discussing Discrepancies
- If everyone votes the same value, it is confirmed.
- If there are large differences (e.g., a 3 and a 13), a discussion follows:
- Why do some think it's easy?
- Why do others think it's difficult?
- Are there underestimated technical challenges or dependencies?
π Step 5: Re-estimation (if necessary)
- After discussion, the team votes again until reaching a consensus.
π Step 6: Assigning the Final Estimation
- The final estimation is recorded in the Sprint Backlog.
3. Examples of Planning Poker in Action
Example 1: Easy Estimation
πΉ User Story: "As a user, I want to change my password."
πΉ Team votes: All vote β2β.
β Immediate consensus β The story is estimated at 2 points.
Example 2: Disagreement on Estimation
πΉ User Story: "As a user, I want to receive recommendations based on my meal history."
πΉ Team votes:
- Dev A β 5
- Dev B β 8
- Dev C β 13
- Dev D β 5
πΉ Discussion:
- Dev C explains that the AI system is more complex than expected.
- Dev A assumed it was just a simple SQL query.
- After discussion, the team agrees on 8. β
πΉ Examples of User Stories estimated using Planning Poker:
User Story | Initial Estimation | Discussion | Final Estimation |
Log a meal | 5 - 8 - 5 - 3 | API already exists, simplification possible. | 5 |
Generate nutrition recommendations | 8 - 13 - 21 | Algorithm complexity needs review. | 13 |
User login and registration | 2 - 3 - 3 - 2 | Simple with Firebase. | 3 |
How Does a Break Card Work in Planning Poker?
πΉ Each team member has a Break Card in addition to number cards.
πΉ During voting, a member can play this card instead of a number.
πΉ If one or more Break Cards appear:
- The team takes a short break (5-10 min).
- The User Story is re-discussed to clarify uncertainties.
- The team can then re-estimate after the break.
4. Simulation of Scrum Events
During the exercise, each team will simulate Scrum ceremonies:
Daily Stand-up (5 minutes per team)
Each member shares their progress, blockers, and goals for the day.
- Introduce a change during the Sprint to simulate an evolving customer need.
- Add a technical or budgetary constraint to force backlog adaptation.
- Perform tasks (on paper) and note successes, failures, difficulties, and needs.
- Add a new requirement:
- Example: AI needs for image recognition.
β‘ Action: The Scrum Master organizes a discussion with the team and the PO to determine if:
- The team can train internally.
- They need to hire an expert or purchase a third-party solution.
- They can work around the issue with a simpler solution.
- π¬ A developer: "We need access to CPAM databases, but we donβt have permissions yet."
- β‘ Action: The PO contacts CPAMβs technical lead to expedite access.
- Example: AI needs for image recognition.
When to Report a Need?
π‘ As early as possible to avoid delays:
β During a Daily Scrum: If a developer discovers a technical gap blocking progress.
Who Should Be Notified of a Technical Need?
πΉ Scrum Master: To assess if itβs a blocker and facilitate team discussions.
πΉ Product Owner (PO): To discuss the impact on the backlog and product value.
πΉ Development Team: To determine if an internal solution can be found.
Step | Responsible | Actions |
π Need Identification | Developer | Reports it during Daily Scrum or directly to Scrum Master/PO. |
π Impact Analysis | Scrum Master + Team | Evaluates if the team can handle it internally or needs external expertise. |
π° Cost & Resource Decision | Product Owner + Stakeholders (Finance, CTO, Managerβ¦) | Assesses budget impact and decides whether to invest or adjust project scope. |
π Solution Implementation | Development Team | Can suggest internal training, tool purchase, or expert recruitment. |
Sprint Review
Presentation of completed developments.
- Happens right after the Sprint ends (e.g., if the Sprint lasts 2 weeks, the Sprint Review takes place on the last day of the second week).
- The duration depends on Sprint size but typically lasts 30 minutes to 1 hour for a 2-week Sprint.
Typical Sprint Review Flow:
- Presentation of completed work: Demonstration of new features or improvements.
- Stakeholder feedback: Discussion on alignment with user needs and expectations.
- Discussion on product evolution: Possible adjustments to the Product Backlog based on feedback.
- Preparation for the next Sprint: Adjusting priorities for the next phase of the project.
Sprint Retrospective
Discussion on what worked well and what could be improved.
- Takes place before the next Sprint starts, so improvements can be applied immediately.
- Duration varies by Sprint length, but usually 30 minutes to 1 hour for a 2-week Sprint.
Typical Sprint Retrospective Flow:
- What went well? π
- Identify positive aspects and Sprint successes.
- What could be improved? π
- Discuss difficulties and obstacles encountered.
- What actions should be implemented to improve? β
- Define concrete actions to apply in the next Sprint.
Different Objectives
β Sprint Review β Product-oriented
β Sprint Retrospective β Team and process-oriented
1. Where to Document Sprint Review Feedback? π
π In a shared tracking document or space (e.g., Notion, Confluence, Google Docs, Trello, Jira).
π Directly in the Product Backlog if adjustments are needed.
π In a Sprint Review Report.
A good way to track retrospective feedback is to use a continuous improvement board, for example, in Trello or Notion:
π What Worked Well | π What Can Be Improved | β Actions to Implement |
Good team communication | Too many technical meetings | Limit meetings to 30 minutes |
Deployment without major bugs | Lack of automated tests | Add tasks for writing tests |
6. Learning Objectives
- The relevance of User Stories and their prioritization.
- Sprint management and Scrum ceremonies.
- The quality of deliverables and the clarity of the demonstration.
- Experiencing Agile project management in a real-world scenario.
- Working as a team.
- Understanding the challenges of iterative and collaborative development.
- Understanding and applying Agile project management.
- Experimenting with Scrum roles and ceremonies.
- Learning to work in a team and organize the development of a digital product.
Learning Objectives:
- Understand and apply Agile project management.
- Experiment with Scrum roles and ceremonies.
- Learn to work in a team and organize the development of a digital product.