-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #93 from nsidc/issue-62
Issue 62
- Loading branch information
Showing
9 changed files
with
360 additions
and
50 deletions.
There are no files selected for viewing
5 changes: 2 additions & 3 deletions
5
.github/workflows/push.yml → .github/workflows/build-test.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
name: Publish release to PyPI | ||
|
||
on: | ||
release: | ||
types: [released] | ||
|
||
jobs: | ||
build: | ||
name: Build package | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- uses: actions/setup-python@v5 | ||
with: | ||
python-version: 3.12 | ||
|
||
- name: cache poetry install | ||
uses: actions/cache@v4 | ||
with: | ||
path: ~/.local | ||
key: poetry-1.8.3-0 | ||
|
||
- uses: snok/install-poetry@v1 | ||
with: | ||
version: 1.8.3 | ||
virtualenvs-create: true | ||
virtualenvs-in-project: true | ||
|
||
- name: cache deps | ||
id: cache-deps | ||
uses: actions/cache@v4 | ||
with: | ||
path: .venv | ||
key: pydeps-${{ hashFiles('**/poetry.lock') }} | ||
|
||
- run: poetry install --no-interaction --no-root | ||
if: steps.cache-deps.outputs.cache-hit != 'true' | ||
|
||
- run: poetry install --no-interaction | ||
|
||
- run: poetry build | ||
|
||
- uses: actions/upload-artifact@v4 | ||
with: | ||
name: release-dists | ||
path: dist/ | ||
|
||
publish: | ||
name: Publish to PyPI | ||
runs-on: ubuntu-latest | ||
needs: [build] | ||
permissions: | ||
id-token: write | ||
attestations: write | ||
contents: read | ||
environment: | ||
name: PyPI | ||
url: https://pypi.org/p/nsidc-metgenc | ||
steps: | ||
- uses: actions/download-artifact@v4 | ||
with: | ||
name: release-dists | ||
path: dist/ | ||
|
||
- name: Generate artifact attestation for sdist and wheel | ||
uses: actions/[email protected] | ||
with: | ||
subject-path: "dist/*" | ||
|
||
- name: Publish package distributions to PyPI | ||
uses: pypa/gh-action-pypi-publish@release/v1 | ||
with: | ||
packages-dir: dist/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
MetGenC Changelog | ||
|
||
## UNRELEASED | ||
|
||
This is the Minimum Viable Product (MVP) release of MetGenC. The | ||
features include: | ||
|
||
* Provides a prompt-driven means of configuring MetGenC to ingest | ||
a new collection. | ||
* Processing is driven by a configuration file for control of various | ||
aspects of the ingest. | ||
* Generates a UUID and submission time for each granule. | ||
* Creates UMM-G compliant metadata for each source granule. | ||
* The UMM-G includes required attributes, including temporal and | ||
spatial bounds. | ||
* Generates a Cumulus Notification Message (CNM) for each granule. | ||
* Stages the science data files and their UMM-G metadata in | ||
a configurable S3 bucket location. | ||
* Submits the CNM message to a configurable Kinesis stream in | ||
order to trigger a Cumulus workflow. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,6 +4,9 @@ | |
|
||
# MetGenC | ||
|
||
![build & test workflow](https://github.com/nsidc/granule-metgen/actions/workflows/build-test.yml/badge.svg) | ||
![workflow workflow](https://github.com/nsidc/granule-metgen/actions/workflows/publish.yml/badge.svg) | ||
|
||
The `MetGenC` toolkit enables Operations staff and data | ||
producers to create metadata files conforming to NASA's Common Metadata Repository UMM-G | ||
specification and ingest data directly to NASA EOSDIS’s Cumulus archive. Cumulus is an | ||
|
@@ -31,14 +34,8 @@ or | |
|
||
$ python3 --version | ||
|
||
Next, you must also install [Poetry](https://python-poetry.org/) either by using the [official | ||
installer](https://python-poetry.org/docs/#installing-with-the-official-installer) | ||
if you’re comfortable following the instructions, or by using a package | ||
manager (like Homebrew) if this is more familiar to you. When successfully | ||
installed, you should be able to run: | ||
|
||
$ poetry --version | ||
Poetry (version 1.8.3) | ||
Next, install the AWS commandline interface (CLI) by [following the appropriate | ||
instructions for your platform](https://docs.aws.amazon.com/cli/latest/userguide/getting-started-install.html). | ||
|
||
Lastly, you will need to create & setup AWS credentials for yourself. The ways in which | ||
this can be accomplished are detailed in the **AWS Credentials** section below. | ||
|
@@ -58,29 +55,13 @@ this can be accomplished are detailed in the **AWS Credentials** section below. | |
can be used to determine the padding added to x and y values. | ||
- Date/time strings can be parsed using `datetime.fromisoformat` | ||
|
||
## Installation of MetGenC from GitHub | ||
|
||
Make a local directory (i.e., on your computer), and then `cd` into that | ||
directory. Clone the `granule-metgen` repository using ssh if you have [added | ||
ssh keys to your GitHub | ||
account](https://docs.github.com/en/authentication/connecting-to-github-with-ssh/adding-a-new-ssh-key-to-your-github-account) | ||
or via https if you haven't: | ||
|
||
$ mkdir -p ~/my-projects; cd ~/my-projects | ||
# Install using ssh: | ||
$ git clone [email protected]:nsidc/granule-metgen.git | ||
OR | ||
# Install using https: | ||
$ git clone https://github.com/nsidc/granule-metgen.git | ||
## Installing MetGenC | ||
|
||
Enter the `granule-metgen` directory and run Poetry to have it install the `granule-metgen` dependencies. Then start a new shell in which you can run the tool: | ||
MetGenC can be installed from [PyPI](https://pypi.org/): | ||
|
||
$ cd granule-metgen | ||
$ poetry install | ||
$ poetry shell | ||
$ pip install nsidc-metgenc | ||
|
||
With the Poetry shell running, start the metgenc tool JUST to verify that it’s working by requesting its usage options and having them | ||
returned. There’s more to do (detailed in the **Usage** section below) before MetGenC can be run to successfully create ummg files, cnm messages, and stage data to an S3 bucket for ingest!):: | ||
That's it! Now we're ready to run MetGenC and see what it can do: | ||
|
||
$ metgenc --help | ||
Usage: metgenc [OPTIONS] COMMAND [ARGS]... | ||
|
@@ -221,6 +202,15 @@ TBD | |
* [Python](https://www.python.org/) v3.12+ | ||
* [Poetry](https://python-poetry.org/docs/#installing-with-the-official-installer) | ||
|
||
You can install [Poetry](https://python-poetry.org/) either by using the [official | ||
installer](https://python-poetry.org/docs/#installing-with-the-official-installer) | ||
if you’re comfortable following the instructions, or by using a package | ||
manager (like Homebrew) if this is more familiar to you. When successfully | ||
installed, you should be able to run: | ||
|
||
$ poetry --version | ||
Poetry (version 1.8.3) | ||
|
||
### Installing Dependencies | ||
|
||
* Use Poetry to create and activate a virtual environment | ||
|
@@ -231,14 +221,46 @@ TBD | |
|
||
$ poetry install | ||
|
||
### Run tests: | ||
### Run tests | ||
|
||
$ poetry run pytest | ||
|
||
### Run tests when source changes (uses [pytest-watcher](https://github.com/olzhasar/pytest-watcher)): | ||
|
||
$ poetry run ptw . --now --clear | ||
|
||
### Releasing | ||
|
||
* Update the CHANGELOG to include details of the changes included in the new | ||
release. The version should be the string literal 'UNRELEASED' (without | ||
single-quotes). It will be replaced with the actual version number after | ||
we bump the version below. | ||
|
||
* Show the current version and the possible next versions: | ||
|
||
$ bump-my-version show-bump | ||
0.3.0 ── bump ─┬─ major ─ 1.0.0 | ||
├─ minor ─ 0.4.0 | ||
╰─ patch ─ 0.3.1 | ||
|
||
* Bump the version to the desired number, for example: | ||
|
||
$ bump-my-version bump minor | ||
|
||
You will see the latest commit & tag by looking at `git log`. You can then | ||
push these to GitHub (`git push --follow-tags`) to trigger the CI/CD | ||
workflow. | ||
|
||
* On the [GitHub repository](https://github.com/nsidc/granule-metgen), click | ||
'Releases' and follow the steps documented on the | ||
[GitHub Releases page](https://docs.github.com/en/repositories/releasing-projects-on-github/managing-releases-in-a-repository#creating-a-release). | ||
Draft a new Release using the version tag created above. After you have | ||
published the release, the MetGenC Publish GHA workflow will be started. | ||
Check that the workflow succeeds on the | ||
[MetGenC Actions page](https://github.com/nsidc/granule-metgen/actions), | ||
and verify that the | ||
[new MetGenC release is available on PyPI](https://pypi.org/project/nsidc-metgenc/). | ||
|
||
## Credit | ||
|
||
This content was developed by the National Snow and Ice Data Center with funding from | ||
|
Oops, something went wrong.