0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-11-28 07:59:02 +01:00
mongodb/docs/evergreen-testing/yaml_configuration/buildvariants.md
Juan Gu 1b6882af3d SERVER-93157 Add a linter check to prevent tests with experimental ta… (#26832)
GitOrigin-RevId: ec15d8534a13ccdaeddecd51c23c23c9f9f6f7c9
2024-09-10 21:00:16 +00:00

4.7 KiB

Build Variants

This document describes build variants (a.k.a. variants, or builds, or buildvariants) that are used in mongodb-mongo-* projects. To know more about build variants, please refer to the Build Variants section of the Evergreen wiki.

YAML files structure

Build variant configuration files are in etc/evergreen_yml_components/variants directory. They are merged into etc/evergreen.yml and etc/evergreen_nightly.yml with Evergreen's include feature.

Inside etc/evergreen_yml_components/variants directory there are more directories, which are in most cases platform names (e.g. amazon, rhel etc.) or build variant group names (e.g. sanitizer etc.).

Be aware that some of these files could be also used or re-used to be merged into etc/system_perf.yml which is used for sys-perf project.

Build Variants in mongodb-mongo-master and mongodb-mongo-master-nightly

mongodb-mongo-master evergreen project uses etc/evergreen.yml and contains all build variants for development, including all feature-specific, patch build required, and suggested variants.

mongodb-mongo-master-nightly evergreen project uses etc/evergreen_nightly.yml and contains build variants for public nightly builds.

Required and Suggested Build Variants

"Required" build variants are defined as any build variant with a ! at the front of its display name in Evergreen. These build variants also have required tag.

Required Patch Builds Policy

"Suggested" build variants are defined as any build variant with a * at the front of its display name in Evergreen. These build variants also have suggested tag.

Build Variants with forbid_tasks_tagged_with_experimental

Build variants with the forbid_tasks_tagged_with_experimental tag indicate that they do not allow tasks tagged as experimental to run. This tag is used in conjunction with the forbid-tasks-with-tag-on-variants evergreen lint rule to enforce this restriction.

Build Variants after branching

In each of platform or build variant group directory there can be these files:

  • test_dev.yml

    • these files are merged into etc/evergreen.yml which is used for mongodb-mongo-master project on master branch
    • after branching on all new branches these files are merged into etc/evergreen_nightly.yml which is used for a new branch mognodb-mongo-vX.Y project
  • test_dev_master_and_lts_branches_only.yml

    • these files are merged into etc/evergreen.yml which is used for mongodb-mongo-master project on master branch
    • after branching for LTS release (v7.0, v8.0 etc.) on a new branch these files are merged into etc/evergreen_nightly.yml which is used for a new branch mognodb-mongo-vX.Y project
    • important: all tests that are running on these build variants will NOT run on a new Rapid release (v7.1, v7.2, v7.3, v8.1, v8.2, v8.3 etc.) branch projects
  • test_dev_master_branch_only.yml

    • these files are merged into etc/evergreen.yml which is used for mongodb-mongo-master project on master branch
    • after branching on all new branches these files are NOT used
    • important: all tests that are running on these build variants will NOT run on a new branch mongodb-mongo-vX.Y project
  • test_release.yml

    • these files are merged into etc/evergreen_nightly.yml which is used for mongodb-mongo-master-nightly project on master branch
    • after branching on all new branches these files are merged into etc/evergreen_nightly.yml which is used for a new branch mognodb-mongo-vX.Y project
  • test_release_master_and_lts_branches_only.yml

    • these files are merged into etc/evergreen_nightly.yml which is used for mongodb-mongo-master-nightly project on master branch
    • after branching for LTS release (v7.0, v8.0 etc.) on a new branch these files are merged into etc/evergreen_nightly.yml which is used for a new branch mognodb-mongo-vX.Y project
    • important: all tests that are running on these build variants will NOT run on a new Rapid release (v7.1, v7.2, v7.3, v8.1, v8.2, v8.3 etc.) branch projects
  • test_release_master_branch_only.yml

    • these files are merged into etc/evergreen_nightly.yml which is used for mongodb-mongo-master-nightly project on master branch
    • after branching on all new branches these files are NOT used
    • important: all tests that are running on these build variants will NOT run on a new branch mongodb-mongo-vX.Y project