-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy path22-accuracy.Rmd
79 lines (58 loc) · 6.93 KB
/
22-accuracy.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
---
title: ''
output: html_document
---
# Accurate {#accurate}
Code should be error free and appropriately quality assured. Alongside simple sense-checking, two of the key mechanisms for ensuring that code is accurate are testing and project review.
## Testing {#unittest}
Testing our code helps to ensure that it is both correct and robust. For further guidance on what you should test, see the [Coffee and Coding 'Testing' session][221].
As a broad description, unit tests should exist to check that your actual results match your expected results.
Unit tests should test, as a minimum, any functions you create. The purpose of these granular tests is to ensure the code continues to give the correct answer in a range of cases, and even in edge cases (where unusual inputs are provided).
You should ensure that your tests and linters run automatically on all pull requests, using [Github Actions](https://help.github.com/en/actions/automating-your-workflow-with-github-actions).
There are a number of tools to enable unit testing:
+---------------+--------------------------------------------------------+
| Language | Tools |
+===============+========================================================+
| R | In R, consider using the [testthat][222] package. For an introduction to using testthat, try reading this [blog post][223] from Inattentional Coffee or this [Towards Data Science post][224]. For an example unit tests within a project, see [here][225]. |
+---------------+--------------------------------------------------------+
| Python | Consider using [unittest](https://docs.python.org/3/library/unittest.html) or [pytest](https://docs.pytest.org/en/latest/). |
+---------------+--------------------------------------------------------+
| Javascript | See [here](http://busypeoples.github.io/post/testing-d3-with-jasmine/) for testing with javascript. For data vis in Javascript, you need unit tests of routines that manipulate your data or data structures. Visual checks are sufficient of visualisation outputs, but you must make visual checks of the output against real data, and some test datasets that produce predictable output (e.g. where values are set to 1, 0.5 etc.). |
+---------------+--------------------------------------------------------+
[223]:https://katherinemwood.github.io/post/testthat/
[224]:https://towardsdatascience.com/unit-testing-in-r-68ab9cc8d211
[225]:https://github.com/RobinL/costmodelr/tree/master/tests
[222]: https://github.com/r-lib/testthat
[221]: https://github.com/moj-analytical-services/coffee-and-coding-public/tree/master/2019-12-06%20Testing%20as%20part%20of%20an%20Analytical%20Project
## Project review {#review}
Code review provides additional assurance that code logic is correct, as well as providing feedback on code and problem structuring. For smaller projects, the review only needs to be a simple read-through and sanity check.
Code reviews should be initiated through the creation of a [pull request](#flow). The review should typically involve the reviewer pulling the code to their local machine, testing it, and leaving comments in the pull request.
Remember that it’s always easier (for both you and your reviewers) if you commit and push your changes regularly. You should merge branches into the master regularly so that reviewers review little and often, rather than attempting to review your entire codebase all at once.
### Performing good peer review {-}
When performing peer review, asking yourself the following questions is a good place to start:
+----------------------------+---------------------------------------------------------------------------------------------+
| Theme | Check |
+============================+=============================================================================================+
| [Clear, concise code](#ccc)| - Did the code need to be explained to me? |
| | - Is the code readable? |
| | - Could the same thing be achieved in a simpler way? |
| | - Does the code follow [style guidelines](#style)? |
| | - Are the names of functions and variables sensible and descriptive? |
+----------------------------+---------------------------------------------------------------------------------------------+
| Packages | - Did the code run without [dependency issues](#projdep)? |
| | - Are [packages / libraries used sensibly](#defaults)? |
+----------------------------+---------------------------------------------------------------------------------------------+
| Validation | - Is the process doing what is needed? |
+----------------------------+---------------------------------------------------------------------------------------------+
| Verification | - Are the calculations correct? |
+----------------------------+---------------------------------------------------------------------------------------------+
| Testing | - Are there [unit tests](#unittest) (if required)? |
| | - Is it tested with sufficient coverage? |
| | - Are there any cases that might [break it](#unittest)? |
+----------------------------+---------------------------------------------------------------------------------------------+
| Documentation | - Are the code comments sufficient? |
| | - Have assumptions been documented? |
| | - Has accompanying documentation (e.g. [readme](#readme),wiki) been updated (if required)? |
| | - Have AQA documents been updated (if required)? |
+----------------------------+---------------------------------------------------------------------------------------------+
If you're reviewing the code of a more experienced coder, it is a chance to learn and you have every right to ask for an explanation if there's something that is unclear. It's in everyone's interest that you understand what you're reading and it could be that you don't understand it because the author has made a mistake or over-complicated something.