From f5671f0f79f4e3c76e9e9c3491e95f7645591d8e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?C=C3=A9dric=20Bosdonnat?= Date: Mon, 16 Dec 2024 11:36:27 +0100 Subject: [PATCH] tests: add fakeipmi container In order to remove the need to install OpenIPMI in the server container, prepare a container image to run the fake IPMI server. --- .github/workflows/build_containers.yml | 31 +++++++++++++++++++ testsuite/dockerfiles/fakeipmi/Dockerfile | 8 +++++ .../dockerfiles/fakeipmi/fake_ipmi_host.sh | 9 ++++++ testsuite/dockerfiles/fakeipmi/ipmisim1.emu | 17 ++++++++++ testsuite/dockerfiles/fakeipmi/lan.conf | 25 +++++++++++++++ 5 files changed, 90 insertions(+) create mode 100644 testsuite/dockerfiles/fakeipmi/Dockerfile create mode 100755 testsuite/dockerfiles/fakeipmi/fake_ipmi_host.sh create mode 100644 testsuite/dockerfiles/fakeipmi/ipmisim1.emu create mode 100644 testsuite/dockerfiles/fakeipmi/lan.conf diff --git a/.github/workflows/build_containers.yml b/.github/workflows/build_containers.yml index d812d8fc5401..f3d73b627c4d 100644 --- a/.github/workflows/build_containers.yml +++ b/.github/workflows/build_containers.yml @@ -252,3 +252,34 @@ jobs: push: true tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }} + + build-and-push-fakeipmi-image: + runs-on: ubuntu-latest + permissions: + contents: read + packages: write + + steps: + - name: Checkout repository + uses: actions/checkout@v4 + + - name: Log in to the Container registry + uses: docker/login-action@v3 + with: + registry: ${{ env.REGISTRY }} + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Extract metadata (tags, labels) for Docker + id: meta + uses: docker/metadata-action@v5 + with: + images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}/ci-fakeipmi + + - name: Build and push Docker image + uses: docker/build-push-action@v5 + with: + context: ./testsuite/dockerfiles/fakeipmi/ + push: true + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} diff --git a/testsuite/dockerfiles/fakeipmi/Dockerfile b/testsuite/dockerfiles/fakeipmi/Dockerfile new file mode 100644 index 000000000000..743584253c4f --- /dev/null +++ b/testsuite/dockerfiles/fakeipmi/Dockerfile @@ -0,0 +1,8 @@ +FROM opensuse/leap:15.5 + +RUN zypper -n in OpenIPMI && \ + mkdir -p /etc/ipmi + +COPY ipmisim1.emu lan.conf fake_ipmi_host.sh /etc/ipmi + +CMD ["ipmi_sim", "-n"] diff --git a/testsuite/dockerfiles/fakeipmi/fake_ipmi_host.sh b/testsuite/dockerfiles/fakeipmi/fake_ipmi_host.sh new file mode 100755 index 000000000000..5074742ba846 --- /dev/null +++ b/testsuite/dockerfiles/fakeipmi/fake_ipmi_host.sh @@ -0,0 +1,9 @@ +#! /bin/bash + +echo +echo "#### Fake IPM host started ####" +echo + +while true; do + sleep 5 +done diff --git a/testsuite/dockerfiles/fakeipmi/ipmisim1.emu b/testsuite/dockerfiles/fakeipmi/ipmisim1.emu new file mode 100644 index 000000000000..f414e085f34a --- /dev/null +++ b/testsuite/dockerfiles/fakeipmi/ipmisim1.emu @@ -0,0 +1,17 @@ +# Minimalistic simulation setup for ipmi_sim. + +# The BMC is the MC at address 20 +mc_setbmc 0x20 + +# Now add the BMC +mc_add 0x20 0 no-device-sdrs 0x23 9 8 0x9f 0x1291 0xf02 persist_sdr +sel_enable 0x20 1000 0x0a + +# Watchdog sensor. This must be sensor zero. +sensor_add 0x20 0 0 35 0x6f event-only +sensor_set_event_support 0x20 0 0 enable scanning per-state \ + 000000000001111 000000000000000 \ + 000000000001111 000000000000000 + +# Turn on the BMC +mc_enable 0x20 diff --git a/testsuite/dockerfiles/fakeipmi/lan.conf b/testsuite/dockerfiles/fakeipmi/lan.conf new file mode 100644 index 000000000000..860fedd1d9a1 --- /dev/null +++ b/testsuite/dockerfiles/fakeipmi/lan.conf @@ -0,0 +1,25 @@ +name "ipmisim1" + +set_working_mc 0x20 + + # Define a LAN channel on channel 1 + startlan 1 + addr 127.0.0.1 623 + priv_limit admin + + allowed_auths_callback none md2 md5 straight + allowed_auths_user none md2 md5 straight + allowed_auths_operator none md2 md5 straight + allowed_auths_admin none md2 md5 straight + + guid a123456789abcdefa123456789abcdef + endlan + + serial 15 127.0.0.1 9002 codec VM + + startcmd "/etc/ipmi/fake_ipmi_host.sh" + startnow false + + user 1 true "admin" "admin" user 10 none md2 md5 straight + user 2 true "ipmiusr" "test" admin 10 none md2 md5 straight +