-
Notifications
You must be signed in to change notification settings - Fork 31
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Rename "core team" to "JupyterHub council" #497
Comments
+1 from me - one question is whether we change the structure of "red team", "blue team", "green team". It sounds like the "red+blue" teams would be the council? Or just the red team? (happy to discuss simplifying this if it is too much complexity) |
I would be okay with either approach. I think including both makes the most sense right now. |
I noticed that the jupyter-server team put together a similar "core team" model, but opted to remove the distinction of team color. Instead they just have "active and inactive team members". Some discussion here: jupyter-server/team-compass#5 (comment) Currently, the "blue" vs. "red" distinction is only defined in the Binder governance docs (not the JupyterHub docs). Moreover, it doesn't seem like we are strongly enforcing the (somewhat implicit) responsibilities and expectations listed in there. Given that, my feeling is that we should do one of these two things:
My feeling is that the first bullet is simplest, since it matches the informal practices that this team follows already (AKA, in practice we do not already make strong distinctions between blue and red, it is more a way for people to signal what kind of stuff they do, and this is also already captured in the "all contributors" emoji people attach to their images). What do you think? it might also be helpful to hear from @Zsailer about the rationale behind not using team colors, and how that has worked out for y'all so far! |
I've got a vague recollection of discussing this in the past, can't remember where, when, or what we decided! If we get rid of the colours we can still use the emojis (which I only discovered today) to highlight people working on BinderHub. |
(just a note that if this has already been discussed and decided, I also don't feel very strongly about this, so if we just wanna move forward with @minrk's proposal and keep both colors but lump them under a council, that's fine with me!) |
It's on the agenda for tomorrow's team meeting. |
As part of the bootstrapping process, there might be interest from Steering Council members to be part of the Hub Council. Since the core team is already well-formed here, maybe one additional steps would be to invite those SC memebers who are interested. I think @Carreau might have information about the ones who are interested. |
We discussed this in the March 2022 meeting. I think that the general idea was "yes, it's fine to re-define as council, but we also need a way to give people permissions in the repositories without such a high barrier to entry". So to move this forward I'd like to make a proposal and see what folks think: ProposalDefine 4 groups of people in the JupyterHub team, partially inspired by Matt Rocklin's definition of being a maintainer:
and a special "working group"-style team:
|
I think this is a good start, and represents the current setup. However I think in future it'd be nice if we could move away from using GitHub privileges as a mark of status within JupyterHub for a couple of reasons:
The ideal situation would be a structure that supports having someone on the JupyterHub Steering Council with no GitHub write access at all, for example a community manager. However since that's not the case at the moment I've got no objection to going with your current proposal now, then adapting the it later after we've had more time to think. One easy change could be to say The JupyterHub Team is anyone with membership of the JupyterHub GitHub orgnisation. If we change the default privileges of org members to read-only, then there are no concerns about people having write access to any/other repos. This for example allows us to add issue triagers to individual repos without giving push access, or if we have a future team member who won't be interacting with GitHub they can have a account with no write privileges. |
I'd be fine just defining teams in the GitHub org and using that as the definition of team membership. The main reason I mentioned GH permissions above was to make explicit what privileges should come with various team memberships. |
I'm fine with #497 (comment). The way I understand it is that the three levels (team member, maintainer, SC) represent a hierarchy that a person can climb? You start out as a JH team member and over time and with interest and effort you could become a SC member? Why special case the mybinder.org people? Aren't they "just" maintainers of the mybinder.org-deploy repo? From the description of the maintainer role it sounds like it is what I'd expect you to do when helping run mybinder.org. Could you clarify what the difference is between a JH Team member and a Maintainer? Asked differently, if not helping to maintain one or more repositories what does a JH Team member do/what do I have to do to become one? |
I think that's a great proposal.
Unlike everything else, this team operates a service. If we operated other services, it might make sense for additional teams.
I think it's about commitment/expectations. Lowering the bar for commit rights to not necessarily imply putting in a certain amount of time. Maintainers are expected to be available to a certain degree, whereas 'members' may not. I do think it's a useful question to ask, because we often fall into de facto maintainers, and there may not be an obvious time to transition someone across this boundary. |
Yep - they should have increasing levels of responsibility and privilege, and an increasing bar to attain.
Good question - I wasn't sure on this either. My quick thought is that operating, paying for, and running a live service has a different set of expectations than a typical open source maintainer role, which is why I imagined giving those people credit specifically for that extra work.
Yep exactly. I didn't want "would you like commit rights to this repository?" to also require "are you willing to serve in a maintainer role for this repository?" because the latter seems like a much higher bar to ask of somebody, and the former is useful just to provide extra fluidity and keep things moving along. In my mind, you'd first get commit rights to a repo by asking or someone offering, and as long as you meet a minimum bar of trust we should be willing to do this. That makes you a team member and you can now merge PRs. Over time, if you are a regular contributor that reviews, engages in issues, and potentially merges PRs yourself, then you may gain the status of "maintainer" which gives you the ability to add/remove other people, and perhaps a higher degree of responsibility and prestige as well. Another reason for this is that "emeritus" maintainers are no longer maintainers, but I'd still like to consider them "team members" :-) |
Thanks for the clarifications. Maybe we can add examples of things you can do to be a team member. For example triaging issues, responding to issues and helping out on the forum. Depending on the repository (mostly how mature/old/widely used it is) I have different feelings about having people merge changes without also having signed up to maintaining the repository as a whole. This is mostly tied to me thinking of a maintainer as the person who performs all the important tasks that are required for the contribution experience to be great. Mostly because these aren't tasks people choose to work on if they are (casual) contributors. So I think I support making our levels as much as possible independent of repository access rights (the "can commit" test seems incredibly out of date/old school, from back when people still believed that committing code was 99% of what it took to create a successful project). Instead describing what you can do in terms of tasks/responsibilities across all the places the JupyterHub Team is active (eg the forum has no "commit bit"). |
That is a good point! Hmm maybe we can brainstorm some examples (3 or so) for each? I could make a team compass PR and we can iterate on language there? |
Update: draft PRHey all - I gave a shot at updating some of these docs over in this PR: It has a lot of changes in there because I ran into some docs roadbumps that I fixed along the way as well. I've tried to explain in that PR where the major areas to look are...happy to iterate there if folks like |
Thanks @choldgraf for updating the descriptions! I think the next step is to send the invitations to re-establish membership. Here's a draft text we could send to all team members listed here:
(edits welcome) We could also use different text for folks we believe to be inactive already, if people think that's appropriate. |
Sounds fine to me, though could probably just use a GitHub issue and only follow-up non-responding individuals? |
Good point. |
I'll open that Issue today. Can we say 1 week+, so next Tuesday as a deadline? I can send an email to folks who haven't responded by Friday. |
Sorry for quoting myself here, but I do not see in #566 people interested to be bootstrapped from the current Jupyter SC actually being bootstrapped as suggested by the governance document linked at the top comment. Could that be the case? |
@damianavila Sorry, I missed that comment the first time. Since we already have teams and governance, I don't believe the bootstrapping process applies except as a reference (there's no initial team to seed because we already have a team). I'm sending an email to the SC. I'm happy to nominate SC members, but I think they should be approved by the existing team first. |
For sure! |
I think our council is updated (PR coming momentarily). There's still more to do after #566 because we haven't explicitly specified membership of any other teams.
And these folks are on jupyterhub github org (some on teams, some not) without being on the currently listed team members page:
|
As the new Jupyter governance is getting put together, it might be good to have common terms with other Jupyter subprojects.
There is a bootstrapping process, to be called "$Subproject Council". However, we already have an analogous structure in our 'core team', so I don't think we need to bootstrap from scratch. I propose we:
I'm not sure there are any other updates to make.
The text was updated successfully, but these errors were encountered: