Team Lead is a ❄️, because in each company they are unique and distinct.
The concepts of "Team Lead", "Tech Lead", "Tech Manager" and others are very stretchy. Companies solve different tasks, these roles have different responsibilities. Besides, various leadership styles, differences in personal skills, and much more are put in the picture. But isn't that what happens to the developers? Different companies, different tasks, again, different nature of tasks and responsibilities.
We interviewed several dozen large and small companies, found out what they expect from Team Leads and how they interact with them. As a result, we were able to form a single model of basic teamwork competencies that covers all the cases studied.
This model can be used in any way you like - to come up with your development plan, to define duties and responsibilities, to write a job description or to conduct interviews. Keep in mind it is likely you don't need all the branches of potential development - and this is fine.
🚨 Important: Depending on a company, the Team Lead needs to work on different branches and responsibilities. We don't think that the goal should be to develop all the areas of the roadmap. It's important to focus on the problems and needs of your workplace, first of all.
The work is still in progress, so feel free to publish an Issue or open a Pull Request.
- Download the MindMap(Russian-only for now) with the full Team Lead model.
- Go through all branches of the Team Lead responsibilities. Remove those that are not required by your company or are already being performed by someone else.
- Form from the resulting map the artifacts you need: a profile to hire, a description of role expectations, a development plan.
- Use our knowledge base to go deeper into any of the branches. For each of the branches we describe in detail its meaning, motivation to use, examples of good and bad behavior, ways of development in practice and theory.
- Download the MindMap(Russian-only for now) with the full Team Lead model.
- Mark on it the competencies you already have and those you need for further growth within the company. To give you a hint, look at what your manager or colleagues are doing. If there are still some difficulties, feel free to ask a question in Issues.
- Make a list of competencies that separate your current profile and your target profile.
- Using our knowledge base, create a development plan for each of the competencies, which includes both theory and practical application.
- Show your development plan to your manager and ask for assistance.
The roadmap consists of two sections:
- Roles and responsibilities. A list of high-level work roles and more specific responsibilities.
- Personal Skills. Personal skills and qualities that are necessary for certain roles and responsibilities.
Each of the map's leaves will eventually become a large entry in the knowledge base with a description, examples of behavior, and ways to develop the skill.
The easiest way to open a mm
file is to use Freemind (free and simple), MindNode (expensive and premium) or MindMeister (freemium and online). Other MindMap editors are also likely to work, but we haven't tested them.
We've prepared a few common Team Lead models. With their help, you can see how to work with the roadmap, or you can just bring them to your company as examples:
The current roadmap is an alpha version that has a common teamwork structure and partially describes the first major role, Resource Manager. We are looking forward to your participation in the project. The contribution process is described in depth in CONTRIBUTING.md
.
The base is gradually filled with Stas Tsyganov, Egor Tolstoy and the community. Our final goal is to describe each of the directions according to the following template:
- Description (what we are talking about)
- Why this branch is important
- What happens if you don't work on it
- To whom it can be delegated
- Examples of good and bad behavior
- Development techniques: skills, practices, consulting, theory
If you don't agree with any of the existing descriptions or think you can improve it, feel free to send your pull request. If you have any questions about the structure itself, you are welcome to join our chat room, RU or discuss it directly via a pull request.
- Human management
- Team management
- Technical Brand Development
- Product understanding
- Market knowledge
- Competitors
- State
- Market specifics
- Product knowledge
- Product Vision
- Product Strategy
- Product Metrics
- Value streams
- User knowledge
- Target audience
- User pains
- Market knowledge
- Making product decisions
- Target setting
- The goal-setting process
- Ready-made approaches
- Product backlog management
- Backlog element generation
- Backlog prioritization
- Target setting
- Business knowledge
- Corporate culture
- Company structure
- Product quality assurance
- Code Review
- Testing
- Test model
- Test plans
- The Pyramid of testing
- Optimizing the amount of testing
- Work on bugs
- Incident management
- Metrics and monitoring
- Non-functional requirements
- Technical quality assurance
- Unit tests
- Pure code
- Refactoring
- Technical Debt Management
- Technology knowledge
- Writing code
- Technological stack
- Selecting technologies and control of their stack
- Development cycle automation
- VCS
- CI
- Release Automation
- Knowledge management
- Knowledge sharing
- Technical documentation
- Architecture
- Technical requirements elicitation
- Design
- Architectural Reviews
- Evolution
- Capacity Management
- Building the development cycle
- Getting tasks
- Development
- Methodology design
- Description
- Evaluation
- Execution
- Control of execution
- Ready-made approaches
- Scrum
- Lean
- Methodology design
- Issue of tasks
- Acceptance
- Rolling out
- Project management
- Methodology design
- Ready-made approaches
- PMBoK
- PDCA
- Stakeholder
- Ability to learn
- Reflexion
- Making habits
- Empathy
- Emotional intelligence
- Understanding the value of differences
- Systemic thinking
- Strategic vision
- Decision-making
- Facilitation
- Cooperation
- Conflict management
- Giving and receiving feedback
- Networking
- Public appearances
- Working with text
- Setting personal goals
- Time management
- Priority management
The following people contributed to the development of the map: Anatoly Panov, Roman Ivliev, Nikolay Krapivny, Georgy Mogelashvili, Yulia Rakhmanova, Nikolay Balakirev, Alexander Minenok, Pavel Antonov, Vitaly Sharovatov, Alexander Svetkin, Marat Chukmarov.
Translated doc version: commit