Skip to content

Commit

Permalink
REF: improvements to GHA/env file how-to guides
Browse files Browse the repository at this point in the history
  • Loading branch information
lizgehret committed Sep 9, 2024
1 parent a5d96b1 commit 8d06da3
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 1 deletion.
13 changes: 12 additions & 1 deletion book/plugins/how-to-guides/automate-testing.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,15 @@ Github Actions can be a bit confusing to set up.
We recommend the online course, [*GitHub Automation for Scientists*](https://hutchdatascience.org/GitHub_Automation_for_Scientists), developed by the [ITCR Training Network](https://www.itcrtraining.org/), before moving forward.
Once you've read through this (and hopefully played around with a few of the toy examples provided therein), you can start to put together a CI workflow based the examples provided here.

``````{Note}
Before creating any GHAs for your plugin, you'll start by creating a top-level directory within your plugin's repository with the following name:
```
.github/workflows/
```
This naming structure is what allows Github to identify any relevant actions or workflows that should be run within your repository, and is where all of your GHA files should be created.
``````

Here is what the basic structure of your GHA will look like:

```
Expand All @@ -49,7 +58,7 @@ This will typically be your `main` branch, but may differ if you've customized t
- `<repository-name>`: the name of your repository on GitHub
- `<target-epoch>-<package-name>-environment.yml`: the name of your environment file. If you haven't created this yet, refer back to [](facilitating-installation) before continuing.

Your GHA file will be stored under under `.github/workflows/` in your repository, and you can use the same name as your Github Action for the filename (e.g., `ci-<repository-name>.yml`).
Your GHA file will be stored under the `.github/workflows/` directory in your repository, and you can use the same name as your Github Action for the filename (e.g., `ci-<repository-name>.yml`).
Note that the extension will also be `.yml` (same as your environment file(s)).

After creating this file and pushing it to the main branch of your repository, this GHA should run anytime there is a commit to `<target-branch>` or a pull request against `<target-branch>`.
Expand Down Expand Up @@ -82,6 +91,8 @@ jobs:
env-file-name: development-<repository-name>-environment.yml>
```

This GHA file will also be stored under the `.github/workflows/` directory in your repository, and you can use the same name as your Github Action for the filename (e.g., `cron-<repository-name>.yml`).

Relative to the GHA example above, the differences are:

- The trigger for this action (i.e., `on`) is either manual (`workflow_dispatch`) or a schedule (`cron`) (previously it was commits and pull requests).
Expand Down
9 changes: 9 additions & 0 deletions book/plugins/how-to-guides/facilitate-installation.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,15 @@ With the following terms defined:
- `<repository-name>`: the name of your plugin repository on GitHub (this often will be the same as your plugin's package name, e.g., `q2-dwq2`)
- `<target-branch>` (optional): the relevant branch that users should be utilizing to install your plugin - if not specified, this will default to your repository's *Default branch* (e.g., `main`). If you don't include this, you should leave off the `@` symbol following `.git`

``````{Note}
In the examples provided in this guide, we utilize the `released` channel for our QIIME 2 packages (i.e. `packages.qiime2.org/qiime2/<target-epoch>/<target-distribution>/released`).
If you are interested in creating and/or sharing instructions for installing a version of your plugin that relies on one of our development environments (meaning the current development cycle environment prior to an official release version), you'll want to target the `passed` channel of that particular distribution.
Here's an example of what this channel might look like (as of Sept. 2024, prior to the 2024.10 release):
```
https://packages.qiime2.org/qiime2/2024.10/amplicon/passed
```
``````

Using the above guidelines, you can provide the following install instructions for your users:
```
conda env create \
Expand Down

0 comments on commit 8d06da3

Please sign in to comment.