Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
Wiki Replica
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Container Registry
Model registry
Operate
Environments
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
The Tor Project
TPA
Wiki Replica
Commits
6b1ae290
Unverified
Commit
6b1ae290
authored
4 years ago
by
anarcat
Browse files
Options
Downloads
Patches
Plain Diff
gitlab policy proposal
parent
a848cb56
No related branches found
Branches containing commit
No related tags found
No related merge requests found
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
tsa/policy/tpa-rfc-5-gitlab.mdwn
+116
-0
116 additions, 0 deletions
tsa/policy/tpa-rfc-5-gitlab.mdwn
with
116 additions
and
0 deletions
tsa/policy/tpa-rfc-5-gitlab.mdwn
0 → 100644
+
116
−
0
View file @
6b1ae290
[[!meta title="TPA-RFC-5: GitLab migration"]]
Summary: the TPA team will migrate its bugtracker and wiki to GitLab,
using Kanban as a planning tool.
# Background
TPA has a number of tools at its disposal for documentation and
project tracking. We currently use email, Trac and ikiwiki. Trac will
be shutdown by the end of the week (at the time of writing) so it's
time to consider other options.
# Proposal
This document proposes to switch to GitLab to track issues and project
management. It also suggests converting from ikiwiki to GitLab wiki in
the mid- to long-term.
## Scope
The scope of this proposal is only within the Tor sysadmin team (TPA)
but could serve as a model for other teams stuck in a similar situation.
This does *not* cover migration of Git repositories which remain
hosted under gitolite for this phase of the GitLab migration.
## Tickets: GitLab issues
As part of the grand GitLab migration, Trac will be put read-only and
we will no longer be able to track our issues there. Starting with the
GitLab migration, all issues should be submitted and modified on
GitLab, not Trac.
Even though it is technically possible for TPA members to bypass the
readonly lock on Trac, this exception will *not* be done. We also wish
to turn off this service and do *not* want to have two sources of
truth!
Issues will be separated by sub-projects under the `tpo/tpa` GitLab
group, with one project per Trac component. But new sub-projects could
eventually be created for specific projects.
## Roadmap: GitLab boards
One thing missing from GitLab is the equivalent of the Trac inline
reports. We use those to organise our monthly roadmap within the team.
There are two possible alternatives for this. We could use the GitLab
"milestones" feature designed to track software releases. But it is
felt we do not really issue "releases" of our software, since we have
too many moving parts to cohesively release those as a whole.
Instead, it is suggested we adopt the [Kanban][] development strategy
which is implemented in GitLab as [issue boards](https://docs.gitlab.com/ee/user/project/issue_board.html). Issues would
first land into a "triage" queue, then get assigned to a specific
milestone as the ticket gets planned. The default `To do` and `Doing`
boards should be fine to get started, although we could go with
per-month labels as well. That could be adjusted in the future without
formally reviewing this policy.
Priority of items in the `To do` queue are determined by the *order*
of items in the stack. Tickets should *not* stay in the `To do` queue
forever and should instead actively be closed or moved back into the
`Open` or `Backlog` board.
[Kanban]: https://en.wikipedia.org/wiki/Kanban_(development)
## Documentation: GitLab wiki
We are currently using ikiwiki to host our documentation. That has
served us well so far: it's available as a static site in the static
mirror system and allows all sysadmins to have a static, offsite copy
of the documentation when everything is down.
But ikiwiki is showing its age. it's an old program written in Perl,
difficult to theme and not very welcoming to new users. for example,
it's impossible for a user unfamiliar with git to contribute to the
documentation. It also has its own unique Markdown dialect that is not
used anywhere else. and while Markdown itself is not standardized and
has lots of such dialects, there is /some/ convergence around
CommonMark and GFM (GitHub's markdown) as de-facto standards at least,
which ikiwiki still has to catchup with. It also has powerful macros
which are nice to make complex websites, but do not render in the
offline documentation, making us dependent on the rendered copy (as
opposed to setting up client-side tools to peruse the documentation).
GitLab wikis, in contrast, have a web interface to edit pages. It
doesn't have the macros ikiwiki has, but that's nothing a few
commandline hacks can't fix... or at least we should consider it. They
don't have macros or any more powerful features that ikiwiki has, but
maybe that's exactly what we want.
# Deadline
The migration to GitLab issues has already been adopted in the June
TPA meeting.
The rest of this proposal will be adopted in one week unless there are
any objections (2020-06-18).
# Status
This proposal is currently in the `draft` state.
# References
* [old ikiwiki](https://help.torproject.org/)
* [new TPA group](https://gitlab.torproject.org/tpo/tpa)
* [GitLab wiki migration issue 34437](https://trac.torproject.org/projects/tor/ticket/34437)
* GitLab upstream documentation:
* [issue boards documentation](https://docs.gitlab.com/ee/user/project/issue_board.html)
* [issue boards feature page](https://about.gitlab.com/stages-devops-lifecycle/kanban-boards/)
* [issue boards tutorial](https://about.gitlab.com/blog/2018/08/02/4-ways-to-use-gitlab-issue-boards/)
* [Wikipedia article about Kanban development](https://en.wikipedia.org/wiki/Kanban_(development))
* [No bullshit article about issue trackers](https://almad.blog/essays/no-bugs-just-todos/) which inspired the
switch to Kanban
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment