Skip to content
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

Design of issue tracking/reporting via GitHub #1595

Draft
wants to merge 7 commits into
base: master
Choose a base branch
from
54 changes: 54 additions & 0 deletions doc/design/dandiset-issues-tracking.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
# Dandiset issues reporting/tracking

Dandisets could have issues related to problems with

- uploaded data files
- metadata records
- missing files
- validation errors
- fix/enhancement proposals
- etc.

We need to enable an easy and consistent interface to allow archive users to search, report, followup, signup etc to them.
Overall, we need an issue tracking system, while avoiding creating one from scratch.

## Current Process

Largely not formalized:

- DLP does not have any pointer to report an issue for dandiset
- footer has overall link to report issues for the archive (and incorrect: [PR to fix](https://github.com/dandi/dandi-archive/pull/1594))
- We generally refer people to [helpdesk discussions](https://github.com/dandi/helpdesk/discussions) as common place to report issues
- While preapring DataLad versions of the dandisets and posting them on GitHub we do not disable `Issues` feature:
- for some dandisets, e.g. https://github.com/dandisets/000108/issues we already used GitHub issues
- we do not anyhow automatically add/invite original uploaders to those dandisets.
- note: ATM we do not collect audit information on who specifically uploaded any asset to reliably deduce github users to assign.
- The issue discussing this: https://github.com/dandi/dandi-archive/issues/863


## Proposed Process

**Overall**: Reuse existing Dandisets on GitHub (https://github.com/dandisets), and available for them GitHub's issue tracker.

- [x] Enable Issue tracking per dandiset.
- In the process of creating DataLad dandisets on GitHub we already enable `Issues` functionality for all dandisets.
- [ ] Upon creation of a DataLad dandiset on GitHub, email dandiset owner inviting to subscribe to the issue tracker on GitHub
- [ ] Setup https://github.com/dandisets [organization-wide](https://docs.github.com/en/communities/setting-up-your-project-for-healthy-contributions/creating-a-default-community-health-file) [`.github/ISSUE_TEMPLATE`](https://docs.github.com/en/communities/using-templates-to-encourage-useful-issues-and-pull-requests/configuring-issue-templates-for-your-repository#creating-issue-forms) with different templates/types of issues to report
waxlamp marked this conversation as resolved.
Show resolved Hide resolved
- [ ] DLP: add a button "View/Report Issues" or "Issues" leading to issue Tracker (e.g. [Issues](https://github.com/dandisets/000108/issues) for 000108)
- Complimentary/alternative: Could be "File an issue" button which would prefeed some issue body with `@dandiset-owner` handles etc. But we might then need to introduce our own UI to choose among different types of issues
- Optionally: dandi-archive could query/cache number of known open issues and include within that button, e.g. have it [(1) Issues](https://github.com/dandisets/000108/issues)
- Complimentary: asset-level issues filing in UI context menu per file, would pre-fill in the asset path
- [ ] Optional: provide consistent collection of labels to outline typical problems which might occur
yarikoptic marked this conversation as resolved.
Show resolved Hide resolved
- e.g., `validation-error`, `unable-to-load`, `io-error`, `missing-file`, `permission`, etc.

yarikoptic marked this conversation as resolved.
Show resolved Hide resolved
### Benefits

- Users already must have a GitHub account to
- register/login to dandiarchive: we will reuse that same mechanism
- submit support requests in helpdesk
- GitHub provides a versatile and customizable issue tracking system many of the users might already be familiar with

### Disadvantages

- not "integrated" within dandiarchive.org
- A possible mitigation: I guess we could collect mirror issues/comments etc from GitHub internally in the archive. There are tools which could even be used to help. E.g. @yarikoptic has experience with using https://github.com/MichaelMure/git-bug to sync all issues from GitHub locally to collect all contributors to the project. E.g. [this script](https://github.com/nipy/heudiconv-joss-paper/blob/main/authors/tools/make-summaries#L92) processes a JSON dump of all issues from `git bug` mirror.