Skip to main content

Manage Evergreen modules locally.

Project description

Evergreen Module Manager

Manage Evergreen modules in your local environment.

PyPI - Python Version PyPI Documentation

Table of contents

  1. Description
  2. Getting Help
  3. Documentation
  4. Dependencies
  5. Installation
  6. Usage
  7. Contributor's Guide
  8. Resources

Description

The evg-module-manager is a tool to help improve the local workflows of working with modules in your evergreen projects. It will help you keep any modules defined in your local project in sync. It supports the following functionality:

  • List what modules are defined in the local project.
  • List what modules are currently active in your local repo.
  • Clone a module repository.
  • Enable/disable modules in your local repo.
  • Create an evergreen patch build that includes changes from the local patch build and all enabled modules.
  • Submit a changes to the commit-queue that includes changes from the local patch build and all enabled modules.

Getting Help

What's the right channel to ask my question?

If you have a question about evg-module-manager, please mention @dag-on-call in the slack channel #evergreen-users or email us at dev-prod-dag@mongodb.com.

How can I request a change/report a bug in evg-module-manager?

Create a DAG ticket.

What should I include in my ticket or #evergreen-users question?

Since #evergreen-users questions are interrupts, please include as much information as possible. This can help avoid long information-gathering threads.

Please include the following in any created tickets:

  • Motivation for Request
    • Provide us the motivation for this change.
  • Context
    • Provide some background context for this issue.
  • Description
    • Provide some description on how this issue happened.

Documentation

Read the documentation here.

Dependencies

See Usage Prerequisites for more details.

Installation

We strongly recommend using a tool like pipx to install this tool. This will isolate the dependencies and ensure they don't conflict with other tools.

$ pipx install evg-module-manager

Debugging installation issues

A common issue that arises during installation is pipx failing to install emm and printing out the following error:

$ pipx install evg-module-manager
Fatal error from pip prevented installation. Full pip output in file:
    /home/ubuntu/.local/pipx/logs/cmd_2022-03-31_13.24.42_pip_errors.log
 
Some possibly relevant errors from pip install:
    ERROR: Could not find a version that satisfies the requirement evg-module-manager (from versions: none)
    ERROR: No matching distribution found for evg-module-manager
 
Error installing evg-module-manager.

This error indicates that pipx could not find a version of emm that was built to support the version of Python installed on your machine. Make sure to check that your version of Python matches the requirements called out in the Dependencies section. You can check the version of Python that is on your computer by running

$ python --version

If you are running into the issue above but are sure that the correct version of Python is installed on your computer, you can explicitly specify a path to the correct Python version during installation.

$ which python3.9
/usr/bin/python3.9
$ pipx install evg-module-manager --python /usr/bin/python3.9

Usage

See the documentation for details about using this tool.

Usage: evg-module-manager [OPTIONS] COMMAND [ARGS]...

  Evergreen Module Manager is a tool help simplify the local workflows of evergreen modules.

Options:
  --modules-dir PATH      Directory to store module repositories [default='..']
  --evg-config-file PATH  Path to file with evergreen auth configuration
                          [default='/Users/dbradf/.evergreen.yml']
  --evg-project TEXT      Name of Evergreen project [default='mongodb-mongo-master']
  --help                  Show this message and exit.

Commands:
  disable       Disable the specified module in the current repo.
  enable        Enable the specified module in the current repo.
  evg           Perform evergreen actions against the base repo and enabled modules.
  git           Perform git actions against the base repo and enabled modules.
  list-modules  List the modules available for the current repo.
  pull-request  Create a Github pull request for changes in the base repository and any...

Contributor's Guide

Setting up a local development environment

This project uses poetry for setting up a local environment.

git clone ...
cd evg-module-manager
poetry install

linting/formatting

This project uses black and isort for formatting.

poetry run black src tests
poetry run isort src tests

Running tests

This project uses pytest for testing.

poetry run pytest

Automatically running checks on commit

This project has pre-commit configured. Pre-commit will run configured checks at git commit time. To enable pre-commit on your local repository run:

poetry run pre-commit install

Versioning

This project uses semver for versioning.

Please include a description what is added for each new version in CHANGELOG.md.

Code Review

Please open a Github Pull Request for code review.

Deployment

Deployment to pypi is automatically triggered on merges to main.

Resources

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

evg_module_manager-1.3.1.tar.gz (27.9 kB view details)

Uploaded Source

Built Distribution

evg_module_manager-1.3.1-py3-none-any.whl (33.5 kB view details)

Uploaded Python 3

File details

Details for the file evg_module_manager-1.3.1.tar.gz.

File metadata

  • Download URL: evg_module_manager-1.3.1.tar.gz
  • Upload date:
  • Size: 27.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.9.16 Linux/5.15.0-1037-azure

File hashes

Hashes for evg_module_manager-1.3.1.tar.gz
Algorithm Hash digest
SHA256 4d02b0036465ddf2f52c398616ac670cbc8da1781c99b9ea0c66e04134418f9c
MD5 38e97edab23e738c0ac280ff6a201da3
BLAKE2b-256 0171d233859c2c80a57e5e7c2f0c1fcc9b6759138d93e2eab1aa96aaceba3cb1

See more details on using hashes here.

Provenance

File details

Details for the file evg_module_manager-1.3.1-py3-none-any.whl.

File metadata

  • Download URL: evg_module_manager-1.3.1-py3-none-any.whl
  • Upload date:
  • Size: 33.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.9.16 Linux/5.15.0-1037-azure

File hashes

Hashes for evg_module_manager-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 26c9d8486298b7bfea046fe2379049ac7c09b12255dcf85f7abbc3b45224293d
MD5 29f65c521d5b4a3d3351578575fdcac9
BLAKE2b-256 418e0ed2fb7697586a43de8e877072a6e82b78454fa21426182e2921cb87d770

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page