FWIW I support the move for the reasons Mariusz outlines. Everyone will, of course, have their own perosnal preferences based on expeirences, etc (I for one am a HUGE fan of Gerrit over any other review system). An important thing to keep in mind is that course correction is always possible and it can be hard to predict how changes may or may not play out well without taking some risks. Now, not making attempts to improve communcations and quality (given of course that opinions will vary and all of them matter) I think is a recipe for stagnation. Just my 2 cents :) -Paul On Fri, 26 Apr 2024 15:59:09 +0200 Mariusz Tkaczyk <mariusz.tkaczyk@xxxxxxxxxxxxxxx> wrote: > Hi Paul, > I will disable "Discussions" panel on Github. That make sense to ask > people to direct question to ML. I will try to keep "Issues" related > to mdadm only. Otherwise we will redirect people to ML. For example, > in case when someone is looking for help how to recover array it > should be directed to ML not Github. > > I think that sending notification about new pull request will be > enough for interested folks to take a look and eventually comment. So > I still would like to do review outside ML but if there is a need to > consult feature/bugfix it can be sent to ML as RFC to get wider > community support. > > It is not one way move, we have to do what is reasonable and > necessary for mdadm to grow. It is not that we are moving to github > and abandoning ML. It is and always will be a part of mdadm and can > be used if needed. > > More detailed answers below. > Thanks, > Mariusz > > On Fri, 26 Apr 2024 11:52:05 +0200 > Paul Menzel <pmenzel@xxxxxxxxxxxxx> wrote: > > > Dear Mariusz, > > > > > > Thank you for your quick reply. > > > > Am 26.04.24 um 10:36 schrieb Mariusz Tkaczyk: > > > On Fri, 26 Apr 2024 08:46:18 +0200 Paul Menzel wrote: > > > > >> Thank for bringing this topic up for discussion. Unfortunately, > > >> I have to reply with negative comments. > > >> > > >> Am 19.04.24 um 03:48 schrieb Mariusz Tkaczyk: > > >>> Thanks to Song and Paul, we created organization for md-raid on > > >>> Github. This is a perfect place to maintain mdadm. I would like > > >>> announce moving mdadm development to Github. > > >>> > > >>> It is already forked, feel free to explore: > > >>> https://github.com/md-raid-utilities/mdadm > > >>> > > >>> Github is powerful and it has well integrated CI. On the repo, > > >>> you can already find a pull request which will add compilation > > >>> and code style tests (Thanks to Kinga!). > > >>> This is MORE than we have now so I believe that with the change > > >>> mdadm stability and code quality will be increased. The > > >>> participating method will be simplified, it is really easy to > > >>> create pull request. Also, anyone can fork repo with base tests > > >>> included and properly configured. > > >>> > > >>> Note that Song and Paul are working on a per patch CI system > > >>> using GitHub Actions and a dedicated rack of servers to enable > > >>> fast container, VM and bare metal testing for both mdraid and > > >>> mdadm. Having mdadm on GitHub will help with that integration. > > >> > > >> Improved testing sounds good. Thank you. I do not think though, > > >> that using GitHub is a requirement for that, and there are a lot > > >> of bots on the Linux kernel mailing list doing this without > > >> GitHub. > > > > > At some point Paul Luse and Song Liu decided that they will > > > choose Github for MD CI and Paul is busy working on creating > > > dedicated Github runners for MD CI. Moving mdadm development then > > > is a logical next step as I want to reuse the prepared hardware > > > resources simple way. > > >>> As a result of moving to GitHub, we will no longer be using > > >>> mailing list to propose patches, we will be using GitHub Pull > > >>> Requests (PRs). As the community adjusts to using PRs I will be > > >>> setting up auto-notification for those who attempt to use email > > >>> for patches to let them know that we now use PRs. I will also > > >>> setup GitHub to send email to the mailing list on each new PR > > >>> so that everyone is still aware of pending patches via the > > >>> mailing list. > > >> > > >> In my experience, using GitHub for code review is far inferior > > >> to using mailing lists or Gerrit. First, you cannot comment on > > >> the commit message. As a result, projects using GitHub have a > > >> really low-quality git history. Also, you only cannot comment > > >> single parts of a line in the diff. > > > > > > These are known limitations. I understand your objections here. > > > > It would be nice, if you listed them in your proposal with > > solutions how to address them. That would have avoided them. > > This particular problem (commit messages quality) must be addressed > by review process itself so nothing fancy to list. We are responsible > for the commits which are comes to repository, wherever they are > reviewed. At minimal, checkpatch action will be done on each commit > in PR, you can see it proposed here: > https://github.com/md-raid-utilities/mdadm/pull/2 > > For the Github review GUI limitations, we have to accept them. It > will be reviewer task to make comment clear to help author move this > forward. You can copy part of the commit message to comment and add > link to it and say what you want. Github has nice markdown support > reviewer should use it to make it easier to follow. For example, this > is my comment in different project: > https://github.com/intel/ledmon/pull/193#issuecomment-1941462964 > Isn't it clear? > > > > > > We have to accept them. > > > > I do not think so. Why? > > Because I think that what Github offers if enough to develop mdadm. > I don't want to reinvent the wheel because we sticked to different > work model. As I want to take this step I'm going to take what makes > sense, what gives a value and what makes developer participation > easier. > > That should work for 90% of patches. If we are in doubts we can > always send RFC to ML to get support. > > > > > > Commits will be as good as maintainers cares about them. Please > > > keep in mind that except Intel, the activity around mdadm is low. > > > I'm receiving 1 patchset within 2 weeks. I can deal with those > > > limitations and I don't need customized and advanced solution with > > > huge maintenance cost (at least for now). If that will be > > > changed- we will propose something else. > > If it is that low, then I do not understand, why the infrastructure > > needs to be changed at all. > > Because we want to add real CI testing and avoid maintaining it. We > will have just Github, nothing more than that. Simple development > process, everyone can contribute. It does not require to be > familiarized with ML in standard cases (for example to fix > compilation issue). > > > > > > There are many Github actions we can setup to help us with > > > review. > > > > Can you please give example projects, that have implemented that on > > GitHub? > > https://github.com/md-raid-utilities/mdadm/pull/2 > Above you have pull to mdadm which provides base testing: > - default gcc checks with various CXFLAGS > - checkpatch checks > Next, real tests will be added (we will start with enabling mdadm > tests) but to make that we need custom GH runners. > > You can see well developed checks in dracut project: > https://github.com/dracutdevs/dracut/pull/2643/checks > > > > > >> The “one thread” discussion model is also a pain, as most people > > >> using Web forms do not correctly cite and quote, and with more > > >> than three answers you loose the overview. For some reason > > >> people think more about their reply, using mailing lists than > > >> Web forms. > > > > > > We cannot ban less experienced users from participating. I want > > > to make mdadm development more attractive. I know that generally > > > folks here are well experienced in Linux netiquette, having > > > github will change that. > > > > Has this claim ever been proven, now that a lot of projects made > > the switch. Did participation actually increase? > > For sure moving ledmon from sourceforge to github increased its > visibility. I know because I was in the team at this time: > https://github.com/intel/ledmon > > However, I'm not sure if that is example you are looking for. I think > that dracut matches better here. You can see that development on > github is really active but I don't know how it was in the past. For > sure, it didn't kill dracut. https://github.com/dracutdevs/dracut > > > > > > It is another trade-off I agree to take. > > > > > >> Using different forums for discussions should also not be > > >> allowed. People should just subscribe and monitor one forum. > > > > > > For young developers Github is natural work environment. If they > > > want to to file issue (as they do for thousand other projects) - > > > they can. If github mdadm maintainers cannot support them, we > > > will redirect them to mailing list for wider audience. > > As written, I do not think splitting forums (for a small project) > > is a good idea. > > On github I can enable issues, discussions and wiki tabs. I can also > create dedicated github.io site: > https://pages.github.com/ > > This all waiting and we can use that but we don't have to. I totally > agree now that it is better to keep discussions and support in one > source, so here is my proposal: > - issues will be used to report bugs for mdadm. *For bugs*, not for > reaching help with failed scenarios, suggestions etc. > - discussions - I will disable it because it should take place on ML. > - wiki - we have raid wiki so for now I will disable it, unless we > would like to start noting some mdadm related information (know > issues in mdadm, low level tasks for new developers to participate, > how to compile, development tricks etc.) only mdadm development > related things. > > Anything else, goto ML. > > What do you think? Can it work? > > > > > >> So, I strongly oppose this move, but I am also aware, that I am > > >> not doing a lot of development contribution. > > > > > > The truth is that mdadm is a small and "simple" userspace project. > > > There is not a tons of development around it. Please help me keep > > > simple things simple. > > As written above, if that is true, I do not understand the effort > > put into changing the infrastructure. The effort could have gone > > into writing the CI infrastructure for a mailing list process. > > Other Intel departments seem to do it already, so work would not > > need to be reinvented? > > Are you asking about lkp@xxxxxxxxx kernel test robot? This robot is > kernel only > - I asked them in the past. > > I think that Paul Luse can comment here more but I think that > removing mdadm patches from ML will make an effort of creating CI for > MD simpler because there will be no patches related to other project, > kernel only. > > Whatever requires maintenance on any side increases complexity and I > think that mdadm is not enough big to increase complexity. We can > just use github only and reuse runners, initially created for MD > testing. Any script, or daemon working in background must be hosted > somewhere (and someone needs to care about it). I don't want that > because I think that it is not necessary. > > > > > > We can achieve CI, (probably) "sufficient" review system and > > > simplified well known on market participating process in few > > > clicks. Maintenance of review solution will not belong to us > > > (expect custom GH runners). > > > > Sorry, I do not understand. > > I meant that on Github we can simply achieve review and CI systems > with no additional work. The one change is only where mdadm patches > are sent. > > From developer perspective Github workflow is easier. > > > > > > For these reasons, I see it a natural next step to grow but I'm > > > also familiar with Github limitations. I have to deal with them > > > in other projects I'm maintaining or participating. > > > > I am not convinced the theoretical more participants are > > outweighing the cost for the existing folks being happy with the > > current infrastructure. > > You and I are reviewers of mdadm patches mainly. Comments from other > people are sporadic. Thank you for all work but it is not enough. I > need to try building mdadm developers community and here we are > shadow of MD. > > Mdadm has other problems, people here are rarely interested in fixing > them. > > But still some RFC's for mdadm would be send here - we can always > request that on Github. As a reviewers we need to ensure that the > change is good so if we are not sure, reaching mailing list would be > crucial. > > Does it work for you? > > > > > > I also know that I can count of support from Linux Foundation in > > > case of special needs (like additional resources). That is also > > > great. > > > > Sorry, I also do not understand this statement. Is the Linux > > Foundation only supporting projects using a GitHub based workflow? > > > > No, I meant that if there will be a need to they can help me reach > Microsoft to get more resources, but since we have create make our > own runners then probably this point has no sense. Sorry! > > Thanks, > Mariusz >