User Tools

Site Tools


github_auth48_experiment

Experiment: Using GitHub for AUTH48

This experiment has been run twice (during AUTH48 for RFC 8446 and RFC 8829). The idea was to use GitHub instead of email for AUTH48 state. Details below.

RFC 8446 RFC 8829
I-D draft-ietf-tls-tls13-28 draft-ietf-rtcweb-jsep
Pages submitted 156 pages 115 pages
I-D approved 2018-03-21 2018-03-01
(into MISSREF state)
AUTH48 start 2018-06-14 2020-07-06
Publication 2018-08-10 2021-01-20
GitHub repo https://github.com/tlswg/tls13-rfc https://github.com/rtcweb-wg/jsep
AUTH48 details
Time in state 8.2 weeks 28.3 weeks
# questions at start 58 60
(yielded 78 issues in GitHub)

Process Plan in 2018

  1. The author will create a repository with just the XML. We ask that the author not use their existing repository, for various reasons.
  2. The RPC updates the submitted/approved I-D with the items listed below and keeps this file on hand to send to the authors when AUTH48 is initiated.
    • document header
    • copyright
    • status of this memo
    • section movement to meet the style guide requirements (e.g., move acks and contribs to appear at the end)
  3. RFC Editor goes through the EDIT and RFC EDITOR process states and sends an email with a link to the XML file created in step 2 and the edited XML file at the start of AUTH48. [Both files provided 2018-06-14]
  4. At the start of AUTH48, the author will create a Pull Request (PR) with the changes proposed by the RPC. The authors respond and point to the repository they created.
  5. The relevant people from the RPC will subscribe to notifications from that repository using the “Watch” button and confirm they are watching. For this test case, Heather, Adam, and Martin will follow along as well.
  6. The authors provide a review of the PR they create. That will include line-by-line commentary in the comment section of the PR. This will produce an email sent to anyone watching.
  7. The RPC can review at that point. The RPC will either ask clarifying questions in the comments for the PR, or tag the AD for approval.
  8. Once each author-provided PR is approved by the authors, the authors will merge that PR. The RPC may engage in discussion and/or request AD approval while the PRs are being discussed or may comment after the updates have been merged.
  9. Once all author-provided PRs are merged, the RPC will download the current XML file - Adam or Martin will make sure the RPC has the correct URL to get to that file.
  10. The RPC will produce, if necessary, a new revision of the document and send an email with the link to the XML file to the authors.
  11. If a new version of the document is produced and the authors approve the updated text for publication, they send the RPC their approval.
  12. If the authors don't approve, they update the RPC's PR and we go back to step 4.
  13. Final approval for the full document needs to result in an explicit email to the the RPC from each author indicating approval. GitHub will be used for editorial discussion, but the final text approval will be done via email.

Evaluation Criteria in 2018

RPC Criteria

Does GitHub seem to provide an easy-to-use mechanism for:

  • tracking changes during AUTH48 in such a way that the RPC can query, at any point of time in the future, who approved those changes?
  • having clear interactions with all parties that need to submit approvals during AUTH48?
  • a reasonable (no longer than bringing a new editor up to speed on current AUTH48 processes) learning curve for the use of GitHub?

Measurements

  • Average time in AUTH48 state for standard process documents
  • Average time in AUTH48 state for 100+ page standard process documents
  • Time in AUTH48 state for this document
  • Number of questions at start of AUTH48
  • Number of pull requests afterwards

Measurements in 2018 and 2020

RFC 8446 RFC 8829
AUTH48 time using GitHub 8.2 weeks 28.3 weeks
Comparing with standard process
Concurrent Avg. AUTH48 time* 3.2 weeks 10.1 weeks
Avg. AUTH48 time for docs over 100 pages** 4.4 weeks (n=7) 3.5 weeks (n=6)

* using standard AUTH48 process for the 3 months preceding publication.
** using standard AUTH48 process for the 18 months preceding publication.

Notes

  • future work will require mapping of GitHub account names to Authors, WG Chairs, Document Shepherds, ADs, Stream Managers (possible GDPR implications this information is outside the publishing industry norm for information stored about an individual during a publication process)

Feedback in 2018


Work Flow in 2020-2021

The authors and editor agreed to use the GitHub Pull Request work flow:

  1. The authors answer the AQ in the comments of the issue (e.g., see comments for #922).
  2. The authors indicate that an issue is ready for editor attention by labeling the issue “editor-ready” and assigning the issue to the editor.
  3. The editor creates a branch off the rfced branch to address the issue.
  4. The editor makes edits in that branch.
  5. The editor commits changes.
  6. The editor creates a Pull Request (PR) to submit the changes to the repo (e.g., PR #997).
  7. The authors review the PR:
    1. If the PR is accepted, the authors merge the changes to the rfced branch, which closes the issue.
    2. If the PR is rejected, the editor makes changes to the current branch and resubmits the PR.
  8. Repeat for the other issues.

The authors and the editor set up notifications so that many of these steps automatically generated emails to involved parties (assigning/commenting on issues, use of @mentions, creating/accepting/rejecting PRs). 766 messages were generated during AUTH48.

Feedback in 2020-2021

github_auth48_experiment.txt · Last modified: 2021/02/24 00:15 by arusso