Skip to content

Latest commit

 

History

History
65 lines (49 loc) · 2.6 KB

README.md

File metadata and controls

65 lines (49 loc) · 2.6 KB

Macrostrat Python libraries

A monorepo containing Python-based tools and libraries for Earth data projects.

  • This is still very early-stage.
  • The intent is to share common subsystems between Sparrow, Macrostrat and other tools.
  • All modules can be consumed as PyPI packages, or embedded locally as a submodule (though this is less-recommended).

Modules

  • macrostrat.app_frame: A control framework for manging Dockerized applications. Currently used by Sparrow, Mapboard GIS, and Macrostrat.
  • macrostrat.auth_system: Authentication utilities
  • macrostrat.database: Database connection and query utilities geared towards PostgreSQL
  • macrostrat.dinosaur: Utilities for on-the-fly database migration and conformance testing
  • macrostrat.utils: Helpers for logging and command-line apps

Development

You need python >= 3.8 and the poetry package manager (installed separately) to develop the modules here. Running poetry install (aliased to make) bootstraps the project in a local virtual environment.

Dependencies can be installed by adding them to the respective pyproject.toml files or by running poetry add .... Make sure to keep development dependencies (e.g., for testing) separate from core package dependencies. poetry add -D ... adds dependencies that will only be installed in development, analogous to NPM and Yarn.

Testing

Tests can be run using make test, or, for added control, poetry run pytest .... Docker is required to run all tests, as some of them require several containers.

Testing the macrostrat.app_frame module

The app_frame module can be tested using a simple mock application, which can be controlled using the poetry run test-app command. This command presents the application's CLI interface, which can be used to start and stop the application, e.g. with poetry run test-app up.`

Releasing on PyPI

This repository is designed to facilitate rapid iteration of its components and release to PyPI. All modules are part of the macrostrat namespace package: macrostrat.database, macrostrat.dinosaur, macrostrat.utils, etc.

To release a new version of a module, increment its version in the appropriate pyproject.toml file and run make publish. This will run a publication script that checks for current versions and publishes if none exist.

Structure and similar projects