/virtual-environments

GitHub Actions virtual environments

Primary LanguagePowerShellMIT LicenseMIT

GitHub Actions Virtual Environments

This repository contains the code that we use to create the GitHub Actions virtual environments. Please use the issue templates to submit requests and bug reports related to the installed software.

If you need help with how to set up your workflow file or use a specific tool, check out the GitHub Actions Community Forum.

If you need help with how to build VM machine from source code, check out the documentation.

OS's offered

We currently offer Linux, macOS, and Windows virtual environments:

  • Linux. We offer Ubuntu 16.04 and Ubuntu 18.04. We do not plan to offer other Linux distributions. If you want to build using other distributions with the hosted virtual environments, we suggest you use Docker. Alternatively, you can host your own VMs and make use of self-hosted runners.
  • macOS. We offer macOS Catalina 10.15.
  • Windows. We offer Windows Server 2016 and Windows Server 2019.

Guidelines for what's installed

We follow these rough guidelines when deciding what to pre-install:

  • Tools and ecosystems that are more popular and widely-used will be given priority.
  • More recent versions of tools will be given priority over older versions.
  • Tools and versions that are deprecated or have reached end-of-life will not be added.
  • Tools and versions will be removed 6 months after they are deprecated or have reached end-of-life.
  • If a tool can be installed during the build, we will evaluate how much time is saved and how much space is used by having the tool pre-installed.

Updates to the virtual environments

Cadence

You can expect approximately weekly updates to the software on the virtual environments. For some tools, we always install the latest at the time of the deployment; for others, we pin the tool to specific version(s).

Notifications

Right now, we don't have a great way for you to know when updates to the images are coming. When we have the code available here, you can watch the Releases for when we generate candidate environments, and when we deploy new ones.