generated from jhudsl/OTTR_Template
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path04-good_documentation.Rmd
179 lines (125 loc) · 11.1 KB
/
04-good_documentation.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
---
title: "What is good documentation"
output: html_document
---
```{r, include = FALSE, echo = FALSE}
ottrpal::set_knitr_image_path()
```
# What does good documentation look like?
```{r, fig.alt="Learning Objectives This chapter will demonstrate how to: Identify major components common to good documentation. Describe the purposes of components of good documentation. Set up our documentation templates for following along with the rest of this course.", echo = FALSE}
ottrpal::include_slide("https://docs.google.com/presentation/d/1PH9_KlLVggYpNJI0fgvcIcft2vDtGA_mlCqKFA8gnAg/edit#slide=id.gd422c5de97_0_30")
```
## Major components of good documentation
In this chapter we are going to cover the major aspects of a well-documented tool. In the subsequent chapters, we will talk about each of these components in more detail, providing relevant examples and tools. Others have divided this system into different categories which we have taken inspiration from for what we describe here [@divio].
```{r, fig.alt="The anthropomorphic documentation has 6 major components in this illustration including: The why, getting started, how-to examples, reference guide, code comments, and user feedback.", echo = FALSE}
ottrpal::include_slide("https://docs.google.com/presentation/d/1PH9_KlLVggYpNJI0fgvcIcft2vDtGA_mlCqKFA8gnAg/edit#slide=id.gcd0e3791ab_0_23")
```
^[For all cartoons:
Avataars by https://getavataaars.com/.
Icons by https://thenounproject.com/ License CC BY-NC-ND 2.0.
Emojis by OpenMoji License: CC BY-SA 4.0.]
We can think of these components of documentation in terms of how much time a user has invested in learning the tool:
```{r, fig.alt="The various components of good documentation: The why, getting started, how-to examples, reference guide, code comments, and user feedback are on a continuum in that order from the most to least amount of time spent invested in a tool.", echo = FALSE}
ottrpal::include_slide("https://docs.google.com/presentation/d/1PH9_KlLVggYpNJI0fgvcIcft2vDtGA_mlCqKFA8gnAg/edit#slide=id.g23b977ee2c1_0_19")
```
This isn't always a perfect linear timeline like this, users may use these items in a different order than we expect, but this demonstrates the intent of how users would progress through the documentation.
### The 'Why'
<img src="resources/images/why.png" width="8%">
Before we get into the technical information in your documentation, the first thing that should be obvious to your user is why they should want to use your tool!
What need of your users does your tool fulfill?
If this is not glaringly obvious, users will move on without realizing how valuable your tool could be for their research!
#### Exercise: Write the why of your tool!
This should be the first thing your user sees on the main page of your tool. If it currently is not clear, take this time to workshop one or two sentences that explain the 'why' of your tool. As you craft this sentence, think about the needs of your user and how to summarize your tool's purpose in a brief, punchy way. Stay away from jargon unless perhaps its jargon that you know your user will understand.
_Examples of tools with their why's well-stated prominently on their web page:_
> Gene Set Enrichment Analysis (GSEA) is a computational method that determines whether an a priori defined set of genes shows statistically significant, concordant differences between two biological states (e.g. phenotypes).
Here, [GSEA](http://www.gsea-msigdb.org/gsea/index.jsp) tells us the exact kind of question we can ask and what input is needed.
> Salmon is a tool for wicked-fast transcript quantification from RNA-seq data. It requires a set of target transcripts (either from a reference or de-novo assembly) to quantify.
[Salmon](https://salmon.readthedocs.io/en/latest/salmon.html#using-salmon) tells us its for transcript quantification but that its particular strength is it's "wicked-fast."
### Getting started
<img src="resources/images/getting-started.png" width="8%">
A getting started section will be a new user's first introduction to your tool.
It will tell them specific steps they need to "get started" (hence why we call it this) -- no long-winded explanations, just the quickest way to reach some sort of output.
In the most clear steps as possible, a getting started section will tell the user how to:
- Install the tool and any of its dependencies.
- Run the most basic analysis with the tool.
- Obtain some quick result.
It's crucial that the steps here are simple and easy to follow or you risk losing new users before they even get going.
### How-to examples
<img src="resources/images/how-to.png" width="8%">
A set of how-to examples are like a cookbook of recipes that will demonstrate step-by-step the most common uses for your tool after they have completed the getting started steps.
- The most common use cases of your tool are shown step-by-step
- Each step is clearly provided and explained.
- Any data needed to run the example is provided.
- Example code is written with teaching in mind.
How-to examples give users next steps to get further comfortable with your tool and shows them what an analysis might look like.
### Reference guides
<img src="resources/images/ref-guide.png" width="8%">
A reference guide is like a dictionary that a user can look up items as questions arise.
A user will likely have a specific question about a function, parameter, data type, or option and will want to be able to navigate to information about that item.
Users who end up looking through your reference guide are likely a bit invested and may have already gone through the getting started section and/or how-to examples.
- All items are described in clear, non-jargon language.
- The items are searchable or at least can be easily visually scanned.
- All options and defaults are explained and linked to more information where appropriate.
### Code comments
<img src="resources/images/comment.png" width="8%">
Comments in your source code are also a part of documentation -- and likely the first part of the documentation you worked on!
In most instances, if your tool is functioning fine, code will probably only be looked at by advanced and/or the most invested users.
But also recall that documentation is not only for your user but for future you and existing or potential collaborators.
### User feedback mechanism
<img src="resources/images/user-feedback.png" width="8%">
Try as you might, you will not be able to predict every scenario that a user may engage with your tool.
Your user may encounter errors or quirks that you did not foresee but that would be helpful for you to know about.
Your documentation should direct your users where they should send any comments or concerns.
You should also make sure that this feedback method is something you can check up on and respond to regularly.
We'll also discuss how to conduct usability research to get the most informative feedback on your tool.
## The documentation templates for this course
We encourage you to create these pieces of documentation we will further discuss in the rest of this course!
We have template documentation you can use to use as a starting point.
_Still in progress: If you are creating documentation to accompany a package you are submitting to Bioconductor or Galaxy we are working on constructing specific templates and recommendations for those instances._
### Well-documented checklist
[This document is a checklist](https://github.com/jhudsl/template-documentation/blob/master/docs/well_documented_checklist.md) that summarizes the major aspects that should be included in a tools' documentation.
We recommend using it to evaluate the documentation for an existing tool and identify any gaps you may need to address, or as a to-do list for creating new documentation that you can check off as you follow along with this course.
For more inspiration, here are more articles about good documentation:
- [Benefits of Software Documentation - SDLC Best Practices](https://systemsplusgroup.blogspot.com/2014/05/benefits-of-software-documentation-sdlc.html)
- [5 Examples of What Great Documentation Looks Like for Developers](https://codeburst.io/5-examples-of-what-great-documentation-looks-like-for-developers-162bdec11020)
- [Software Documentation Types and Best Practices](https://blog.prototypr.io/software-documentation-types-and-best-practices-1726ca595c7f)
## Exercise: setting up our templates for your own use
There are two options we suggest for creating documentation as you follow along with this course.
**Option 1)** Use these template markdowns essentially as they are (after you fill them in) and add them to an existing repository.
_Pros_: Is easier and quicker.
_Cons_: Is not as user-friendly as option 2.
**Option 2)** Clone a repository with these templates and set up a MkDocs github pages site. Slightly more work, but a very nice end result; [see demo here](https://jhudatascience.org/template-documentation/).
_Pros_: This format of documentation sites are easy to navigate and likely familiar to your user.
_Cons_: Will require you to use `mkdocs` package to get this set up.
### Steps for Option 1) Adding completed template markdowns to an existing GitHub repository
- [Download the folder of templates using this link](https://github.com/jhudsl/template-documentation/tree/master/).
- Complete each markdown template, filling in the blanks as you go along with the course.
- File a pull request to your repository to add these files.
- (Optional but encouraged) [Publish your repository to Github Pages](https://guides.github.com/features/pages/).
Here's what's in that folder:
```
templates/
├── well_documented_checklist.md
├── getting_started_template.md
├── how_to_examples.md
├── reference_guide_template.md
├── bioconductor-guides/
│ ├── bioconductor_example_script.R
│ ├── bioconductor_vignette_template.Rmd
│ └── README.md
└── galaxy-guides/
```
### Steps for Option 2) Creating a MkDocs site with Github pages
- Go to our [template documentation repository](https://github.com/jhudsl/template-documentation).
- Click `Use this Template` to get started.
- Name your repository something that relates to your tool.
_On your computer's command line_:
- [`git clone` your new repository](https://docs.github.com/en/github/creating-cloning-and-archiving-repositories/cloning-a-repository) you made from our template.
- Navigate to your the root of your local version of this repository.
- [Install mkdocs following their instructions](https://www.mkdocs.org/#installation).
- Run `mkdocs serve` to see a preview of your docs.
- Edit the template pages we've provided in the `docs/` folder.
- As you make changes you can run `mkdocs build` and then `mkdocs serve` to see a preview.
- When you are ready to publish your documentation to its own website, run [`mkdocs gh-deploy`](https://www.mkdocs.org/user-guide/deploying-your-docs/), it will return the web address of your new site
- Go to that address and bask in the success of your newly made documentation!
Now that we have a basic structure and plan for our documentation, let's discuss each each section of this documentation in more detail!