-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME.Rmd
118 lines (85 loc) · 5.51 KB
/
README.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
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```
# `{easystats}`-workflows
GitHub Actions for `{easystats}` packages.
To know more about how to build automation infrastructure to improve user experience and development workflow of R packages using these workflows, have a look at these slides:
<https://indrajeetpatil.github.io/preventive-r-package-care/>
# Using workflows in your packages
## Reusing workflows
You don't need to copy these workflows if you are happy as they are. In this case,
you can just reuse the workflow.
For example, if you wanted to use `check-spelling` workflow, your workflow
(in the file `.github/workflows/check-spelling.yaml`) would look like so:
```yaml
on:
push:
branches: [main, master]
pull_request:
branches: [main, master]
name: check-spelling
jobs:
check-spelling:
uses: easystats/workflows/.github/workflows/check-spelling.yaml@main
```
## Copying workflows
If you wish to copy any of these workflows in your own pages, you can do so
without asking for any permissions.
Just keep in mind that you will need to change the following lines:
```yaml
on:
workflow_call:
#name: test-coverage
```
to (e.g.)
```yaml
on:
push:
branches: [main, master]
pull_request:
branches: [main, master]
name: test-coverage
```
## List of workflows
### General-purpose workflows
| Workflow | Purpose |
| :--------------------------- | :------------------------------------------------------------------------------------------------------------ |
| R-CMD-check-hard.yaml | Runs R CMD check with hard dependencies only (`Imports`) |
| R-CMD-check.yaml | Runs standard R CMD check and fails if there are any `WARNING`s or `NOTE`s |
| test-coverage-examples.yaml | Checks code coverage via examples in the manual and vignettes |
| test-coverage.yaml | Checks code coverage via tests |
| check-random-test-order.yaml | Randomizes the order in which test files are run to check that tests are self-contained. |
| check-all-examples.yaml | Runs *all* examples and checks that they execute successfully and without warnings |
| check-link-rot.yaml | Checks that there are no outdated links (using `{urlchecker}`) |
| check-readme.yaml | Checks that the README can be properly rendered |
| check-spelling.yaml | Checks for spelling mistakes (using `{spelling}`) |
| check-styling.yaml | Checks code formatting against style guide (using `{styler}`) |
| check-test-warnings.yaml | Checks for warnings in tests |
| check-vignette-warnings.yaml | Checks for warnings in vignettes |
| lint.yaml | Runs `{lintr}` on the whole package to check for code quality issues |
| lint-changed-files.yaml | Runs `{lintr}` on the files that were modified in a PR to check for code quality issues |
| html-5-check.yaml | Checks that manual pages are valid HTML5 |
| pkgdown.yaml | Runs the `{pkgdown}` workflow to check that the documentation website can be built |
| pkgdown-no-suggests.yaml | Checks that `{pkgdown}` works with hard dependencies only |
| pre-commit.yaml | Runs git hook scripts to check for code quality issues using [`precommit`](https://pre-commit.com/) framework |
| revdepcheck.yaml | Checks reverse dependencies, it is only run when the branch name starts with `"rc"` |
### `easystats`-related workflows
| Workflow | Purpose |
| :------------------------------- | :------------------------------------------------------------------------------ |
| R-CMD-check-devel-easystats.yaml | Runs R CMD check with the development version of all `easystats` packages |
| update-to-latest-easystats.yaml | Creates a PR to bump all `easystats` dependencies to their latest CRAN version. |
## Acknowledgments
These workflows are based on [r-lib/actions](https://github.com/r-lib/actions). Huge thanks to the creators, maintainers, and contributors to that repo!!
## License ![CC0 licensed](https://img.shields.io/github/license/r-lib/actions)
All examples in this repository are published with the [CC0](./LICENSE) license.
## Other resources
Find more [CI/CD tools for R](https://indrajeetpatil.github.io/awesome-r-pkgtools/#cicd) at [awesome-r-pkgtools](https://github.com/IndrajeetPatil/awesome-r-pkgtools).