Project management
Git is a distributed version control system that enables you to track changes in your code over time. Platforms like GitHub, GitLab and Bitbucket extend the features of git by providing a centralized location for storing repositories, collaborating, and providing powerful tools to plan, organize, and track your work efficiently.
Version control platforms
The choice between GitHub, GitLab and Bitbucket depends on your required features, privacy and other preferences, but all are Git-based platforms for version control. While numerous detailed comparisons exist online, here we will focus on GitHub.
Similarly, whether you are using a version control system through your terminal or Integrated Development Environment (IDE), or using a GUI like GitHub Desktop, the core functionality remains the same.
GitHub issues
GitHub issues help you keep track of tasks, bugs, feature ideas in your project. They are like a to-do list items that everyone on your team can see and update.
How to use issues effectively:
- Use descriptive titles: Write short, specific titles that make it easy to understand what the issue is about.
- Provide detailed descriptions: Include all relevant information, steps to reproduce (if reporting a bug), and expected outcomes in the issue description. This ensures that anyone working on the issue has all the necessary context.
- Use labels: Labels act like tags to help you organize and prioritize tasks.
- Assign people: By assigning someone (or yourself) you let others know that you are picking up and working on this issue.
- Link related issues: Connect related work by linking issues to provide context (add
#issue_number
to reference an issue).
GitHub Issues make it easier to manage your project, collaborate with others, and keep track of progress. As your project grows, you can use additional tools like milestones and project boards while still benefiting from well-organized issues.
Project boards
Project boards on GitHub are designed for planning, organizing, and tracking work within a project. They serve as visual management interfaces that integrate directly with GitHub issues and pull requests. Project boards can be configured as Kanban boards, tables, or roadmaps, offering various layouts to suit different project management needs. Project boards can be particularly useful for visualizing the overall progress of your project and identifying bottlenecks in your workflow. They provide a high-level view that complements the detailed tracking offered by issues.
Milestones
Using milestones you can break down large projects into smaller, more manageable parts. While project boards offer a visual, dynamic interface to manage and track your tasks, milestones serve as structured markers that help you monitor progress toward key project phases/goals.
Managing projects on GitHub
When managing your project on GitHub, we recommend two approaches:
- a simplified approach using only issues, or
- a more structured approach using milestones and project boards.
Both methods have advantages, and the choice depends on the size of the project, its complexity, and your preferences.
You can use a simplified approach and just track your progress in the form of issues and work without defining milestones or using a project board. This can be particularly useful for smaller projects or when you are just starting out with GitHub.
In this approach, you would:
- Create issues for each task or feature you need to work on.
- Optionally, use labels to categorize and prioritize your issues.
- Assign issues to yourself or team members/collaborators.
- Use comments to update progress and discuss any challenges.
- Close issues as you complete them.
This method allows for a flexible workflow while still maintaining a good level of organization and transparency in your project. If your project grows or becomes more complex, you can always adopt milestones and project boards for more structured project management.
When working on a big project, it’s helpful to create a roadmap - a simple plan that outlines what needs to be done and when. A roadmap gives you and your team a clear view of what’s happening now and what’s coming next.
To create a roadmap, it is useful to map out the key milestones and the tasks needed to accomplish the milestones. You can then use GitHub milestones and project boards to track progress and manage your project:
- Define key milestones.
- Create a milestone in GitHub
- Add related issues to your milestone.
- Set up a project board.
- Add issues to your project board.
- Use task lists in your issues to break down the work.
- Assign tasks to team members.
- Linking milestones, issues and pull requests to track progress.
GitHub benefits for researchers and organisations
Researchers at TU Delft are eligible to receive GitHub Educational benefits, which includes
- GitHub Team plan at no cost (check out the benefits)
- GitHub codespaces
- GitHub pages for private repositories
- And more!
To qualify for the benefits, you must:
- Have a GitHub account
- Be an educator, faculty member, or researcher at a recognized educational institution
- Be able to provide documentation from your institute demonstrating your employment