Skip to content

vmactions/base-vm

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Run GitHub CI in BaseVM Test

Use this action to run your CI in BaseVM.

The github workflow only supports Ubuntu, Windows and MacOS. But what if you need to use BaseVM?

All the supported releases are here:

Release x86_64 aarch64
14.1 yes yes
14.2 yes yes

1. Example: test.yml:

name: Test

on: [push]

jobs:
  test:
    runs-on: ubuntu-latest
    name: A job to run test in BaseVM
    env:
      MYTOKEN : ${{ secrets.MYTOKEN }}
      MYTOKEN2: "value2"
    steps:
    - uses: actions/checkout@v4
    - name: Test in BaseVM
      id: test
      uses: vmactions/base-vm@
      with:
        envs: 'MYTOKEN MYTOKEN2'
        usesh: true
        prepare: |
          pkg install -y curl

        run: |
          pwd
          ls -lah
          whoami
          env
          freebsd-version



The latest major version is: , which is the most recommended to use. (You can also use the latest full version: )

If you are migrating from the previous v0, please change the runs-on: to runs-on: ubuntu-latest

The envs: 'MYTOKEN MYTOKEN2' is the env names that you want to pass into the vm.

The run: xxxxx is the command you want to run in the vm.

The env variables are all copied into the VM, and the source code and directory are all synchronized into the VM.

The working dir for run in the VM is the same as in the Host machine.

All the source code tree in the Host machine are mounted into the VM.

All the GITHUB_* as well as CI=true env variables are passed into the VM.

So, you will have the same directory and same default env variables when you run the CI script.

The default shell in BaseVM is csh, if you want to use sh to execute the run script, please set usesh to true.

2. Share code

The code is shared from the host to the VM via rsync by default, you can choose to use sshfs or nfs to share code instead.


...

    steps:
    - uses: actions/checkout@v4
    - name: Test
      id: test
      uses: vmactions/base-vm@
      with:
        envs: 'MYTOKEN MYTOKEN2'
        usesh: true
        sync: sshfs  # or: nfs
        prepare: |
          pkg install -y curl



...


You can also set sync: no, so the files will not be synced to the VM.

When using rsync, you can define copyback: false to not copy files back from the VM in to the host.


...

    steps:
    - uses: actions/checkout@v4
    - name: Test
      id: test
      uses: vmactions/base-vm@
      with:
        envs: 'MYTOKEN MYTOKEN2'
        usesh: true
        sync: rsync
        copyback: false
        prepare: |
          pkg install -y curl



...


3. NAT from host runner to the VM

You can add NAT port between the host and the VM.

...
    steps:
    - uses: actions/checkout@v4
    - name: Test
      id: test
      uses: vmactions/base-vm@
      with:
        envs: 'MYTOKEN MYTOKEN2'
        usesh: true
        nat: |
          "8080": "80"
          "8443": "443"
          udp:"8081": "80"
...

4. Set memory and cpu

The default memory of the VM is 6144MB, you can use mem option to set the memory size:

...
    steps:
    - uses: actions/checkout@v4
    - name: Test
      id: test
      uses: vmactions/base-vm@
      with:
        envs: 'MYTOKEN MYTOKEN2'
        usesh: true
        mem: 4096
...

The VM is using all the cpu cores of the host by default, you can use cpu option to change the cpu cores:

...
    steps:
    - uses: actions/checkout@v4
    - name: Test
      id: test
      uses: vmactions/base-vm@
      with:
        envs: 'MYTOKEN MYTOKEN2'
        usesh: true
        cpu: 3
...

5. Select release

It uses the BaseVM 13.1 by default, you can use release option to use another version of BaseVM:

...
    steps:
    - uses: actions/checkout@v4
    - name: Test
      id: test
      uses: vmactions/base-vm@
      with:
        release: "13.2"
...

6. Select architecture

The vm is using x86_64(AMD64) by default, but you can use arch option to change the architecture:

...
    steps:
    - uses: actions/checkout@v4
    - name: Test
      id: test
      uses: vmactions/base-vm@
      with:
        release: "13.2"
        arch: aarch64
...

7. Custom shell

Support custom shell:

...
    steps:
    - uses: actions/checkout@v4
    - name: Start VM
      id: vm
      uses: vmactions/base-vm@
      with:
        sync: nfs
    - name: Custom shell step 1
      shell: {{VM_OS_NAME}} {0}
      run: |
        cd $GITHUB_WORKSPACE;
        pwd
        echo "this is step 1, running inside the VM"
    - name: Custom shell step 2
      shell: {{VM_OS_NAME}} {0}
      run: |
        cd $GITHUB_WORKSPACE;
        pwd
        echo "this is step 2, running inside the VM"
...

Under the hood

We use Qemu and Libvirt to run the BaseVM VM.

Upcoming features:

  1. Support s390x, or other architectures.
  2. Support MacOS runner.
  3. Support Linux ARM runner.
  4. Get rid of Libvirt.

About

The base vm template

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

Packages

No packages published

Contributors 3

  •  
  •  
  •