Visit UNICEF Global
This document is an interview template for needs assessments with UNICEF Venture Fund cohorts in Open Source induction calls. The needs assessment is a tool to collect background and context for each teamβs experience and familiarity with open source. It also builds understanding for participation in existing open source communities. This template provides structure and guidance on what to ask to any team at the beginning of an Open Source Mentorship program.
This section helps us understand where each team is at the moment.
What current milestones is the team working towards? Can be development and/or business.
How much of your project source code is already on a git hosting platform, e.g. GitHub / GitLab? Either public or private is okay.
Based on what you know about Open Source today, what challenges or concerns do you have about Open Source specifically?
Is there any prior Open Source development experience on your team?
Do you have an existing user community?
Does your project source code extend or make improvements to an already-existing Open Source project? (a.k.a. upstream)
These questions explore project management and any tools or processes that are already in place.
Is your team fully remote, partially remote, or all in-person?
Does your team use a project management methodology? (e.g. agile, scrum, waterfall)
How often does your development team meet?
What project management tools are you already using? (e.g. Trello, Asana, GitHub Projects, JIRA, etc.)
These questions explore development best practices and how the team produces source code. It covers a range of periphery activities around development, such as unit testing, static analysis, automation, and more. The goal is to understand where the team is currently, and where Open Source Mentorship will focus initially. This intersects with other topics like Continuous Integration.
Does the current project source code have ANY unit, functional, and/or integration tests?
If yes: Estimate a percentage of how much code is currently tested.
If yes: What testing frameworks are used?
Do you already use any static analysis or code health-checking tools?
Are any automation tools already in use? (e.g. Ansible, Chef, Docker containers, GitHub Actions, etc.)
Is any developer on the team able to add code directly to the product, or are contributions peer-reviewed before merging?
These questions explore documentation culture. Some teams may do this better than others at the start, but the goal is to establish a baseline.
READMEs: Do core repositories have a README file that explains what the repo is, how it works at a high-level, and how that single repo integrates into your overall product?
Developer documentation: Is any documentation already written about how to set up a local development environment for any of your projects? Does not have to be stored in git.
These questions explore Open Source vision. It gets the team thinking about where we are going and what the next steps might be in reaching that vision.
What does success look like in a world in 12 months when you have launched your Open Source projects?
Name one thing that needs to change today on your team in order to accomplish this vision. (suggestion: everyone on the call should answer this one!)
These questions were once included in the needs assessment, but are no longer asked. This is because the answers to these questions are either documented elsewhere, or they are better answered asynchronously.
Updated on 19 Sep 2022