-
Notifications
You must be signed in to change notification settings - Fork 13
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #555 from flatcar/krnowak/open-iscsi-test
Add action for building other docker images, add a test for open-iscsi
- Loading branch information
Showing
4 changed files
with
216 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
name: Build other docker image | ||
on: | ||
workflow_dispatch: | ||
inputs: | ||
image_name: | ||
description: "Name of the image from the other-dockerfiles directory." | ||
required: true | ||
type: choice | ||
options: | ||
- targetcli-fb | ||
|
||
env: | ||
REGISTRY: ghcr.io | ||
ORG: flatcar | ||
|
||
jobs: | ||
docker: | ||
runs-on: ubuntu-latest | ||
permissions: | ||
contents: read | ||
packages: write | ||
steps: | ||
|
||
- name: Checkout repository | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
|
||
- name: Setup QEMU | ||
uses: docker/setup-qemu-action@v3 | ||
with: | ||
platforms: linux/amd64,linux/arm64 | ||
|
||
- name: Set up Docker Buildx | ||
uses: docker/setup-buildx-action@v3 | ||
|
||
- name: Login to registry | ||
uses: docker/login-action@v3 | ||
with: | ||
registry: ${{ env.REGISTRY }} | ||
username: ${{ github.actor }} | ||
password: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Build and push | ||
uses: docker/build-push-action@v5 | ||
with: | ||
context: other-dockerfiles/${{ inputs.image_name }} | ||
push: true | ||
platforms: linux/amd64,linux/arm64 | ||
tags: ${{ env.REGISTRY }}/${{ env.ORG }}/${{ inputs.image_name }}:latest | ||
cache-from: type=gha | ||
cache-to: type=gha,mode=max |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,157 @@ | ||
package packages | ||
|
||
import ( | ||
"fmt" | ||
"strings" | ||
|
||
"github.com/flatcar/mantle/kola/cluster" | ||
"github.com/flatcar/mantle/kola/tests/util" | ||
"github.com/flatcar/mantle/platform" | ||
) | ||
|
||
var ( | ||
getInitiatorClientScript = util.TrimLeftSpace(` | ||
#!/bin/bash | ||
set -euo pipefail | ||
sudo systemctl start iscsid | ||
for i in {0..9}; do | ||
if [[ ! -e /etc/iscsi/initiatorname.iscsi ]]; then | ||
sleep 1 | ||
continue | ||
fi | ||
name=$(grep -F InitiatorName /etc/iscsi/initiatorname.iscsi | cut -d= -f2-) | ||
if [[ -z ${name} ]]; then | ||
echo "malformed initiator name config" | ||
exit 1 | ||
fi | ||
echo "${name}" | ||
exit 0 | ||
done | ||
echo "no initiator name config found" | ||
exit 1 | ||
`) | ||
|
||
setupServerScript = util.TrimLeftSpace(` | ||
#!/bin/bash | ||
set -euo pipefail | ||
initiator=${1} | ||
mkdir -p /shared | ||
cat <<EOF >/shared/init.script | ||
cd / | ||
backstores/fileio create test /shared/test.img 100m | ||
iscsi/ create iqn.2006-04.com.example:test-target | ||
cd iscsi/iqn.2006-04.com.example:test-target/tpg1/ | ||
luns/ create /backstores/fileio/test | ||
set attribute generate_node_acls=1 | ||
acls/ create ${initiator} | ||
EOF | ||
docker_args=( | ||
--privileged | ||
--network host | ||
--mount type=bind,source=/sys,destination=/sys | ||
--mount type=bind,source=/shared,destination=/shared | ||
--mount type=bind,source=/run/dbus,destination=/run/dbus,readonly | ||
--mount type=bind,source=/usr/lib/modules,destination=/usr/lib/modules,readonly | ||
--rm | ||
) | ||
docker run "${docker_args[@]}" ghcr.io/flatcar/targetcli-fb bash -c 'targetcli </shared/init.script' | ||
`) | ||
|
||
discoverClientScript = util.TrimLeftSpace(` | ||
#!/bin/bash | ||
set -euo pipefail | ||
host_ip=${1} | ||
target=$(iscsiadm --mode=discovery --type=sendtargets --portal="${host_ip}" | cut -d' ' -f 2-) | ||
iscsiadm --mode=node --login --targetname="${target}" --portal="${host_ip}" | ||
for i in {0..9}; do | ||
if [[ -e /dev/sda ]]; then | ||
break | ||
fi | ||
sleep 1 | ||
done | ||
if [[ ! -e /dev/sda ]]; then | ||
echo "no /dev/sda device" | ||
exit 1 | ||
fi | ||
mkfs.ext2 /dev/sda | ||
mkdir -p /drive | ||
mount -t ext2 /dev/sda /drive | ||
echo "seems to be working" >/drive/test-file | ||
umount /drive | ||
systemctl enable iscsi | ||
`) | ||
|
||
checkClientScript = util.TrimLeftSpace(` | ||
#!/bin/bash | ||
set -euo pipefail | ||
if [[ ! -e /dev/sda ]]; then | ||
echo "no /dev/sda device after reboot" | ||
exit 1 | ||
fi | ||
mkdir -p /drive | ||
mount -t ext2 /dev/sda /drive | ||
if [[ ! -e /drive/test-file ]]; then | ||
echo 'expected file missing' | ||
exit 1 | ||
fi | ||
contents=$(cat /drive/test-file) | ||
if [[ ${contents} != 'seems to be working' ]]; then | ||
echo "unexpected file contents: ${contents@Q}" | ||
exit 1 | ||
fi | ||
umount /drive | ||
`) | ||
) | ||
|
||
func openISCSI(c cluster.TestCluster) { | ||
// machine 0 will have the remote disk mounted | ||
// | ||
// machine 1 will be a disk provider | ||
client := c.Machines()[0] | ||
server := c.Machines()[1] | ||
|
||
for name, script := range map[string]string{ | ||
"/get_initiator": getInitiatorClientScript, | ||
"/discover": discoverClientScript, | ||
"/check": checkClientScript, | ||
} { | ||
if err := platform.InstallFile(strings.NewReader(script), client, name); err != nil { | ||
c.Fatalf("failed to upload script %s to client: %v", name, err) | ||
} | ||
} | ||
if err := platform.InstallFile(strings.NewReader(setupServerScript), server, "/setup"); err != nil { | ||
c.Fatalf("failed to upload script /setup to server: %v", err) | ||
} | ||
|
||
c.MustSSH(client, "sudo chmod a+x /get_initiator /discover /check") | ||
c.MustSSH(server, "sudo chmod a+x /setup") | ||
|
||
initiatorName := c.MustSSH(client, `sudo /get_initiator`) | ||
c.MustSSH(server, fmt.Sprintf("sudo /setup '%s'", initiatorName)) | ||
c.MustSSH(client, fmt.Sprintf("sudo /discover %s", server.PrivateIP())) | ||
if err := client.Reboot(); err != nil { | ||
c.Fatalf("failed to reboot the client: %v", err) | ||
} | ||
c.MustSSH(client, "sudo /check") | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
# For this image to work /sys, /etc, /run/dbus and /usr/lib/modules | ||
# need to be forwarded, also needs --privileged and --network host. | ||
|
||
FROM docker.io/library/debian:bookworm-slim | ||
RUN apt-get update && apt-get upgrade --assume-yes && apt-get install --assume-yes --no-install-recommends kmod targetcli-fb |