Skip to content

Commit 11decd3

Browse files
rrrutledgespier
andauthored
New Pattern: Core Team (#345)
Create core-team.md Co-authored-by: Sebastian Spier <[email protected]>
1 parent 0c5da7f commit 11decd3

File tree

1 file changed

+106
-0
lines changed

1 file changed

+106
-0
lines changed

patterns/2-structured/core-team.md

+106
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,106 @@
1+
## Title
2+
3+
Core Team
4+
5+
## Patlet
6+
7+
Even when an InnerSource project is widely needed, contributions and usage may be hindered because the project is difficult to work with.
8+
Establish a core team that is dedicated to take care of the project's fundamental items.
9+
Their work enables contributors to add and use the features that provide value to their scenarios.
10+
11+
## Problem
12+
13+
* It is difficult to contribute to the project.
14+
This could be due to things like:
15+
* Can't run the project locally.
16+
* Poor documentation.
17+
* Convoluted code.
18+
* Inadequate testing.
19+
* It is difficult to use the project.
20+
Some possible causes:
21+
* Poor documentation (again).
22+
* Frequent bugs.
23+
* Unintuitive setup.
24+
25+
## Story
26+
27+
There's a central project that everyone depends on.
28+
What a great candidate for InnerSource!
29+
Unfortunately, the project has grown organically, with various contributions and additions slapped on haphazardly.
30+
Now it's an icky, thick morass of code that no one understands and everyone is afraid to touch.
31+
It's clearly due for an overhaul (e.g. refactoring, testing, documentation, etc.), but even though everyone needs and wants that work to happen, no one takes the time to do it.
32+
33+
## Context
34+
35+
* Many teams need the project.
36+
* The project has significant tech debt.
37+
* Slow adoption and iteration on the project.
38+
* There is not a owner or maintainer who takes reponsibility for the project and contribution ecosystem as a whole.
39+
40+
## Forces
41+
42+
* Every contributing team is busy, and therefore prioritizes work that results in an immediate payoff for themselves.
43+
* As the project grows the natural trend is for it to become more difficult to use and to modify.
44+
45+
## Solution
46+
47+
Form a core team whose job it is to maintain this project in a state so that others can easily onboard and contribute to it.
48+
This core team does the work that is necessary for a healthy usage and contribution ecosystem.
49+
This critical work tends to not be prioritized as a contribution.
50+
Categories of this type of work include communication, local environment, and DevOps infrastructure.
51+
52+
Here are some specific examples:
53+
54+
* Production bugs
55+
* Documentation
56+
* Onboarding tutorials and examples
57+
* Automated testing
58+
* CI/CD
59+
* Local environment
60+
* Modularization
61+
* Versioning
62+
* Monitoring
63+
* Trailblazing new classes/categories of features
64+
65+
Each of these items is very important to a healthy product ecosystem, yet is unlikely to be prioritized as a contribution.
66+
67+
The core team may be composed of a small number of people on a full-time or a part-time basis.
68+
The choice depends on the amount of work needed, the availability of resources, and the culture of the organization.
69+
The most important consideration is to form the team in a way that allows the organization to empower and hold them accountable in the same way as any other team.
70+
71+
Due to their central role, core team members should nearly always fill the role of [Trusted Committers][tc] as well.
72+
While the [Trusted Committer][tc] role focuses mostly on facilitating others' contribution and use of the project, a core team member regularly contributes to the project as well.
73+
The core team doesn't have its own business agenda that determines its contributions.
74+
They decide what to work on based on what will help others most to use and contribute to the project.
75+
76+
A good way to continually remind the core team of this goal is to have them report regularly on:
77+
78+
* number of active teams using the project
79+
* number of off-team contributions to the project.
80+
81+
Continual focus on these metrics will naturally drive the core team to prioritize generally the right work to create a thriving InnerSource ecosystem around the project.
82+
83+
## Resulting Context
84+
85+
* It is easy to use and contribute to the project.
86+
* Many teams use and contribute to the project.
87+
* Core team has their success defined in terms of others' interaction with and response to their project.
88+
89+
## Rationale
90+
91+
Separating out a core team and tasking them in this way helps to fill the gaps that a successful project needs yet are left behind by contributors that are pursuing their own agenda only.
92+
The core team fills those gaps and greases the wheels so that the contribution ecosystem remains healthy.
93+
94+
## Known Instances
95+
96+
Nike implemented this pattern to manage the InnerSource effort around its reusable CI/CD pipelines.
97+
98+
## Status
99+
100+
Structured
101+
102+
## Author
103+
104+
[Russell R. Rutledge](https://github.com/rrrutledge)
105+
106+
[tc]: https://innersourcecommons.org/learn/learning-path/trusted-committer/

0 commit comments

Comments
 (0)