Hi all, Earlier this spring Julian RĂ¼th and I sat down and created a mirror of Sage's repository over at GitLab:
https://gitlab.com/sagemath/sage This is in addition to the existing mirror at GitHub, for which we have no immediate plans except to have it link to the GitLab mirror. The reasons for this are several--in particular, Julian has put considerable work into a new advisory continuous integration system for Sage built on top of GitLab's CI pipeline system. It's quite nice, as the result of each built is a Docker image which can be run and tested in mybinder.org. With the exception of testing on unusual platforms, this means that proposed changes in tickets--if they indeed build successfully--will be easy to manually try out and play with without having to build them one's self. I will let Julian say more about that when he's ready to. I am bringing up the GitLab mirror for a different, but related reason, which is that I would like to start allowing submissions to Sage to be made via "merge requests" on GitLab (a.k.a. pull requests in GitHub parlance). Why GitLab? In short, we felt it would likely be more acceptable to most members of the Sage community; this was a feeling we had even before the Microsoft's acquisition of GitHub was announced. First of all, GitLab is open-core, meaning that the majority of their software is open source, but for paying customers there are additional features that are not made open source. This, in addition to providing higher level of support to paying customers, is the basis of their business model. But IMO it is more inherently open source-friendly than, say, GitHub. Second of all, while we are currently using the free hosting providing by gitlab.com, which frees us from both the cost in money and time of having to maintain our own GitLab server, GitLab makes it quite easy (I have done it myself) to self-host a GitLab server. So should anything ever go awry with gitlab.com, we can always export the project to a self-hosted server as we do currently with Trac. A second clarification to make is that we are not currently proposing to do away with Trac for Sage's ticket database, and we do not intend to open up the full issue tracker on GitLab. Instead, we only want to be able to accept merge requests, as we believe that enabling the popular "GitHub-style workflow" will make it easier and friendlier for new contributors to submit changes to Sage. For an immediate use case of this that I have in mind, I would like to make it easier for users to submit documentation fixes: https://trac.sagemath.org/ticket/25914 In order that this does not overly disrupt the existing workflow, I have created a bot that automatically syncs GitLab merge requests to a Trac ticket, including synchronization of the branch being proposed for merging. This would allow Volker to continue merging positively reviewed tickets as usual, and (in theory) never even have to touch GitLab. You can see an example of any auto-generated ticket attached. If there are suggestions as to how exactly the auto-generated tickets are formatted I'm open to them--I know it's not exactly perfect as-is. But those are details. The only major downside I see is fragmentation of the discussion of a merge request: Comments can be made either on GitLab itself, or in the auto-generated Trac ticket. I do not yet have a specific recommendation for that in mind, and we may need to experiment. I considered having the bot synchronize comments as well, but that could get even more confusing. One thing I will say though, is that GitLab merge requests will give us superior code-review tools, such as the ability to leave comments inline with the diff. I'd like to just try it and see how it goes, but I'm also open to suggestions. There is also precedent for this model in other projects with legacy issue trackers. Most notably, of late, CPython itself, which started accepting pull requests through GitHub. I haven't seen too much complaint about the discussion being fragemented. For the most part discussions about the details of issues and what to do about them stay on the issue tracker, while discussions about code details (i.e. code review) stay on GitHub, though this is not cut-and-dry. A recent informal poll of the CPython developers as to how this workflow is going was almost entirely positive: https://mail.python.org/pipermail/python-dev/2018-February/152200.html Some of you may remember this is not a first for Sage either: some time ago there was a similar experiment done with GitHub, but it fell unmaintained. If anyone has any lessons learned from that time, please add them. What does everyone think? Is there anyone opposed to going ahead and opening up merge requests? -- You received this message because you are subscribed to the Google Groups "sage-devel" group. To unsubscribe from this group and stop receiving emails from it, send an email to sage-devel+unsubscr...@googlegroups.com. To post to this group, send email to sage-devel@googlegroups.com. Visit this group at https://groups.google.com/group/sage-devel. For more options, visit https://groups.google.com/d/optout.