Development practices
This page describes development practices for message_ix_models
and message_data
intended to help reproducibility, interoperability, and reusability.
In the following, the bold-face words required, optional, etc. have specific meanings as described in IETF RFC 2119.
On other pages:
Contributing to development in the MESSAGEix docs. All of these apply to contributions to
message_ix_models
andmessage_data
, including the Code style.Data, metadata, and configuration, for how to add and handle these.
On this page:
Advertise and check compatibility
There are multiple choices of the base structure for a model in the MESSAGEix-GLOBIOM family, e.g. different Node code lists and Years or time periods (year/*.yaml).
Code that will only work with certain structures…
must be documented, and include in its documentation any such limitation, e.g. “
example_func()
only produces data for R11 and year list B.”should use
check_support()
in individual pieces of code to pre-emptively check and raise an exception. This prevents inadvertent use of the code where its data will be invalid:
def myfunc(context, *args):
"""A function that only works on R11 and years ‘B’."""
check_support(
context,
dict(regions=["R11"], years=["B"]),
"Example data produced"
)
# … function code to execute if the check passes
Code may also check a Context
instance and automatically adapt data from certain structures to others, e.g. by interpolating data for certain periods or areas.
To help with validation, code that does this should log on the logging.INFO
level to advertise these steps.
Code owners
The file .github/CODEOWNERS
(on GitHub) indicates ‘owners’ for some files in the repository.
See GitHub’s documentation of this feature.
For message_ix_models
, we use this to designate people who are capable and responsible to evaluate whether changes in a pull request would have any impact on current or planned research applications of that code, and to suggest whether and how to adjust PRs.
As of 2025-01-10, we do not require pull request approvals from code owners on every PR that modifies files they own. Owners only are notified of such PRs. The author of a PR should:
Observe the notified owners, if any.
In the “How to review” section of the PR template, address those people individually with what (if anything) they need to look at as part of the PR. This may entail saying, “@owner-a @owner-b: no need to review because <reasons>”.
Groups of entries should include paths to all of the following, where applicable:
Documentation, for instance
/doc/name
or/doc/project/name.rst
Data, for instance
/message_ix_models/data/name
Code, for instance
/message_ix_models/model/name
or/message_ix_models/project/name
Tests, for instance
/message_ix_models/tests/model/name
or/message_ix_models/tests/project/name
.
At least 2 people (individually, or via a GitHub team) should be designated owners for any file. This may include one ‘active’ owner and a ‘backup’, or two or more active owners, etc.
For any pull request thats add new files to
message_ix_models
, the author(s) and reviewer(s) should:Consider whether the new files have an identifiable owner. This may not be the case, for instance for general-purpose utility code.
Check whether this understanding aligns with the ownership expressed in
CODEOWNERS
.Add, remove, or adjust entries accordingly.
Describe these changes in commit message(s) or their PR description.
If code owners depart IIASA or are reassigned to other work, they or the
message_ix_models
maintainers must initiate a discussion to identify a new set of owners for their files.
Upstream version policy
message_ix_models
is developed to be compatible with the following versions of its upstream dependencies.
ixmp
and message_ix
The most recent 4 minor versions, or all minor versions released in the past two (2) years—whichever is greater.
For example, as of 2024-04-08:
The most recent release of
ixmp
andmessage_ix
are versions 3.8.0 of each project. These are supported bymessage_ix_models
.The previous 3 minor versions are 3.7.0, 3.6.0, and 3.5.0. All were released since 2022-04-08. All are supported by
message_ix_models.
ixmp
andmessage_ix
versions 3.4.0 were released 2022-01-24. These this is the fifth-most-recent minor version and was released more than 2 years before 2024-04-08, so it is not supported.
- Python
All currently-maintained versions of Python.
The Python website displays a list of these versions (1, 2).
For example, as of 2024-04-08:
Python 3.13 is in “prerelease” or “feature” development status, and is not supported by
message_ix_models
.Python 3.12 through 3.8 are in “bugfix” or “security” maintenance status, and are supported by
message_ix_models
.Python 3.7 and earlier are in “end-of-life” status, and are not supported by the Python community or by
message_ix_models
.
Support for older versions of dependencies may be dropped as early as the first
message_ix_models
version released after changes in upstream versions.Conversely, some parts of
message_ix_models
may continue to be compatible with older upstream versions, but this compatibility is not tested and may break at any time.Users should upgrade their dependencies and other code to newer versions; we recommend the latest.
Some newer code is marked with a
minimum_version()
decorator.This indicates that the marked code relies on features only available in certain upstream versions (of one of the packages mentioned above, or another package), newer than those listed in pyproject.toml.
These minima must be mentioned in the
message_ix_models
documentation.Users wishing to use this marked code must use compatible versions of those packages.