Supported Platforms

Introduction

The Science Pipelines are required to be portable across many compute platforms ranging from high-performance computing centers to laptops (refer to DMS-REQ-0308 in LSE-61). The software will likely work on any Unix-like systems but we limit our testing and support to a fixed set of platforms. Patches may be accepted from developers who test on other operating systems.

Platforms

We have a baseline platform which is what we are using for integration testing and deployments. For each product, we also have a number of other platforms which are regularly tested by our continuous integration system to enhance portability.

The baseline platform is currently CentOS 7 on Intel x86_64.

Note

We aim to stay current with CentOS 7 minor releases, updating within 6 months of their release.

We regularly test the following platforms in addition to the baseline platform:

  • macOS Big Sur (11.0);
  • macOS Catalina (10.15).

See https://ci.lsst.codes for the current list of regularly-tested platforms. (The “osx” platform there for the “stack-os-matrix” job randomly chooses a Big Sur or Catalina machine for each execution to limit load.)

Environment

On each of these platforms, we rely on Conda and conda-forge to provide our build- and run-time dependencies, including compilers and the Python interpreter. The Conda environment for Science Pipelines is generated by the rubin-env metapackage. This defines the environment within which our code must execute: all code must be compatible with the current version of rubin-env. Compatibility with different versions is determined by the rubin-env semantic version number. The Conda environment is periodically updated to maintain compatibility, to utilize new features of third-party packages, or to add new dependencies. To request that a new package be added to the environment, please file an RFC.