Skip to content

Commit

Permalink
Test 1.0.0 - Ubuntu 22.04 (amd64 and arm64)
Browse files Browse the repository at this point in the history
Signed-off-by: Aravinda Vishwanathapura <[email protected]>
  • Loading branch information
aravindavk committed Nov 30, 2022
1 parent 21a617c commit 23ea600
Show file tree
Hide file tree
Showing 11 changed files with 117 additions and 43 deletions.
14 changes: 8 additions & 6 deletions .github/workflows/on-pr-submit.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ name: Run on every PR
on:
pull_request:
branches:
- main_
- main
paths-ignore:
- 'docs/**'
- 'extras/**'
Expand All @@ -14,7 +14,7 @@ jobs:
# TODO: Add unit test as well here
tests:
name: Kadalu Storage Tests
runs-on: ubuntu-latest
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v2
- name: Install Binnacle
Expand All @@ -27,8 +27,10 @@ jobs:
run: |
cd tests && ./build-container.sh
- name: Setup Test environment
run: binnacle -v tests/setup.t
run: sudo binnacle -v tests/setup.t
- name: Build and Install Storage manager to nodes/containers
run: VERSION="${{ github.ref_name }}" binnacle -v tests/install.t
- name: Run all Tests
run: binnacle -v tests/all
run: sudo VERSION="${{ github.ref_name }}" binnacle -v tests/install.t
- name: Run all Tests - Amd64
run: sudo ARCH=amd binnacle -v tests/all
- name: Run all Tests - Arm64
run: sudo ARCH=arm binnacle -v tests/all
4 changes: 2 additions & 2 deletions tests/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
FROM ubuntu:20.04
FROM ubuntu:22.04

ENV DEBIAN_FRONTEND=noninteractive

Expand All @@ -10,4 +10,4 @@ RUN echo "root:kadalu" | chpasswd

RUN systemctl mask getty.target

cmd ["/usr/sbin/init"]
CMD ["/usr/sbin/init"]
9 changes: 5 additions & 4 deletions tests/all/node_proxy_tests.t
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,9 @@

load "#{File.dirname(__FILE__)}/../reset.t"

EMIT_STDOUT true
USE_REMOTE_PLUGIN "docker"
nodes = ["server1", "server2", "server3"]
nodes = ["#{ENV["ARCH"]}-server1", "#{ENV["ARCH"]}-server2", "#{ENV["ARCH"]}-server3"]

nodes.each do |node|
USE_NODE node
Expand Down Expand Up @@ -34,7 +35,7 @@ USE_NODE nodes[1]
puts TEST "kadalu user login admin --password=kadalu"

# Distribute
TEST "kadalu volume create DEV/vol1 server1:/exports/vol1/s1 server2:/exports/vol1/s2 server3:/exports/vol1/s3"
TEST "kadalu volume create DEV/vol1 #{nodes[0]}:/exports/vol1/s1 #{nodes[1]}:/exports/vol1/s2 #{nodes[2]}:/exports/vol1/s3"

nodes.each do |node|
USE_NODE node
Expand All @@ -46,7 +47,7 @@ end
USE_NODE nodes[1]
TEST "mkdir /mnt/vol1"
TEST "chattr +i /mnt/vol1"
TEST "mount -t kadalu #{nodes[1]}:DEV/vol1 /mnt/vol1"
TEST "mount -t kadalu DEV/vol1 /mnt/vol1"

TEST "echo \"Hello World\" > /mnt/vol1/f1"
# TODO: Validate this value below
Expand All @@ -68,4 +69,4 @@ puts TEST "kadalu user logout"
nodes.each do |node|
USE_NODE node
puts TEST "cat /var/log/kadalu/mgr.log"
end
end
3 changes: 2 additions & 1 deletion tests/all/nodes.t
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,9 @@

load "#{File.dirname(__FILE__)}/../reset.t"

EMIT_STDOUT true
USE_REMOTE_PLUGIN "docker"
nodes = ["server1", "server2", "server3"]
nodes = ["#{ENV["ARCH"]}-server1", "#{ENV["ARCH"]}-server2", "#{ENV["ARCH"]}-server3"]

nodes.each do |node|
USE_NODE node
Expand Down
5 changes: 3 additions & 2 deletions tests/all/pools.t
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,9 @@

load "#{File.dirname(__FILE__)}/../reset.t"

EMIT_STDOUT true
USE_REMOTE_PLUGIN "docker"
nodes = ["server1", "server2", "server3"]
nodes = ["#{ENV["ARCH"]}-server1", "#{ENV["ARCH"]}-server2", "#{ENV["ARCH"]}-server3"]

nodes.each do |node|
USE_NODE node
Expand All @@ -12,7 +13,7 @@ nodes.each do |node|
end

USE_NODE nodes[0]
puts TEST "curl -i http://server1:3000/ping"
puts TEST "curl -i http://#{ENV["ARCH"]}-server1:3000/ping"
puts TEST "kadalu user create admin --password=kadalu"
puts TEST "kadalu user login admin --password=kadalu"
puts TEST "kadalu pool create DEV"
Expand Down
3 changes: 2 additions & 1 deletion tests/all/users.t
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,9 @@

load "#{File.dirname(__FILE__)}/../reset.t"

EMIT_STDOUT true
USE_REMOTE_PLUGIN "docker"
nodes = ["server1", "server2", "server3"]
nodes = ["#{ENV["ARCH"]}-server1", "#{ENV["ARCH"]}-server2", "#{ENV["ARCH"]}-server3"]

nodes.each do |node|
USE_NODE node
Expand Down
96 changes: 78 additions & 18 deletions tests/all/volumes.t
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,9 @@

load "#{File.dirname(__FILE__)}/../reset.t"

EMIT_STDOUT true
USE_REMOTE_PLUGIN "docker"
nodes = ["server1", "server2", "server3"]
nodes = ["#{ENV["ARCH"]}-server1", "#{ENV["ARCH"]}-server2", "#{ENV["ARCH"]}-server3"]

nodes.each do |node|
USE_NODE node
Expand Down Expand Up @@ -44,16 +45,16 @@ end

USE_NODE nodes[0]
# Distribute
TEST "kadalu volume create DEV/vol1 server1:/exports/vol1/s1 server2:/exports/vol1/s2 server3:/exports/vol1/s3"
TEST "kadalu volume create DEV/vol1 #{nodes[0]}:/exports/vol1/s1 #{nodes[1]}:/exports/vol1/s2 #{nodes[2]}:/exports/vol1/s3"

# Replicate
TEST "kadalu volume create DEV/vol2 replica server1:/exports/vol2/s1 server2:/exports/vol2/s2 server3:/exports/vol2/s3"
TEST "kadalu volume create DEV/vol2 replica #{nodes[0]}:/exports/vol2/s1 #{nodes[1]}:/exports/vol2/s2 #{nodes[2]}:/exports/vol2/s3"

# Disperse
TEST "kadalu volume create DEV/vol3 data server1:/exports/vol3/s1 server2:/exports/vol3/s2 redundancy server3:/exports/vol3/s3"
TEST "kadalu volume create DEV/vol3 data #{nodes[0]}:/exports/vol3/s1 #{nodes[1]}:/exports/vol3/s2 redundancy #{nodes[2]}:/exports/vol3/s3"

# Distributed Replicate
TEST "kadalu volume create DEV/vol4 replica server1:/exports/vol4/s1 server2:/exports/vol4/s2 server3:/exports/vol4/s3 replica server1:/exports/vol4/s4 server2:/exports/vol4/s5 server3:/exports/vol4/s6"
TEST "kadalu volume create DEV/vol4 replica #{nodes[0]}:/exports/vol4/s1 #{nodes[1]}:/exports/vol4/s2 #{nodes[2]}:/exports/vol4/s3 replica #{nodes[0]}:/exports/vol4/s4 #{nodes[1]}:/exports/vol4/s5 #{nodes[2]}:/exports/vol4/s6"

puts TEST "kadalu volume list --json"

Expand All @@ -70,7 +71,7 @@ end
USE_NODE nodes[0]
TEST "mkdir /mnt/vol2"
TEST "chattr +i /mnt/vol2"
TEST "mount -t kadalu #{nodes[0]}:DEV/vol2 /mnt/vol2"
TEST "mount -t kadalu DEV/vol2 /mnt/vol2"

TEST "echo \"Hello World\" > /mnt/vol2/f1"
# TODO: Validate this value below
Expand Down Expand Up @@ -98,7 +99,7 @@ end
puts TEST "kadalu pool delete DEV --mode=script"

USE_NODE nodes[0]
TEST "kadalu volume create DEV/vol5 server1:/exports/vol5/s1 server2:/exports/vol5/s2 server3:/exports/vol5/s3 --auto-create-pool --auto-add-nodes"
TEST "kadalu volume create DEV/vol5 #{nodes[0]}:/exports/vol5/s1 #{nodes[1]}:/exports/vol5/s2 #{nodes[2]}:/exports/vol5/s3 --auto-create-pool --auto-add-nodes"
TEST "kadalu volume stop DEV/vol5 --mode=script"
TEST "kadalu volume delete DEV/vol5 --mode=script"

Expand All @@ -114,41 +115,42 @@ end
# Case 1
# Create vol6 & delete it. Reuse the same path with --volume-id for vol7.
USE_NODE nodes[0]
vol_id = create_volume_and_get_id("kadalu volume create DEV/vol6 server1:/exports/vol6/s1 server2:/exports/vol6/s2 server3:/exports/vol6/s3 --no-start")
vol_id = create_volume_and_get_id("kadalu volume create DEV/vol6 #{nodes[0]}:/exports/vol6/s1 #{nodes[1]}:/exports/vol6/s2 #{nodes[2]}:/exports/vol6/s3 --no-start")
TEST "kadalu volume delete DEV/vol6 --mode=script"
new_vol_id = create_volume_and_get_id("kadalu volume create DEV/vol7 server1:/exports/vol6/s1 server2:/exports/vol6/s2 server3:/exports/vol6/s3 --no-start --volume-id=#{vol_id}")
new_vol_id = create_volume_and_get_id("kadalu volume create DEV/vol7 #{nodes[0]}:/exports/vol6/s1 #{nodes[1]}:/exports/vol6/s2 #{nodes[2]}:/exports/vol6/s3 --no-start --volume-id=#{vol_id}")
EQUAL vol_id, new_vol_id, "Checking if volume-id are equal after vol6 is reused with --volume-id in vol7"
TEST "kadalu volume delete DEV/vol7 --mode=script"

# Case 2
# Create vol8. Create vol9 with --volume-id of active vol8.
vol_id = create_volume_and_get_id("kadalu volume create DEV/vol8 server1:/exports/vol8/s1 server2:/exports/vol8/s2 server3:/exports/vol8/s3 --no-start")
TEST 1, "kadalu volume create DEV/vol9 server1:/exports/vol9/s1 server2:/exports/vol9/s2 server3:/exports/vol9/s3 --no-start --volume-id=#{vol_id}"
vol_id = create_volume_and_get_id("kadalu volume create DEV/vol8 #{nodes[0]}:/exports/vol8/s1 #{nodes[1]}:/exports/vol8/s2 #{nodes[2]}:/exports/vol8/s3 --no-start")
TEST 1, "kadalu volume create DEV/vol9 #{nodes[0]}:/exports/vol9/s1 #{nodes[1]}:/exports/vol9/s2 #{nodes[2]}:/exports/vol9/s3 --no-start --volume-id=#{vol_id}"
TEST "kadalu volume delete DEV/vol8 --mode=script"

# Case 3
# Create vol10 with full storage-unit directory
TEST "kadalu volume create DEV/vol10 server1:/exports/vol10/s1 --no-start"
TEST "kadalu volume create DEV/vol10 #{nodes[0]}:/exports/vol10/s1 --no-start"
TEST "kadalu volume delete DEV/vol10 --mode=script"

# Case 4 [Negation of Case1]
# Create vol11 & delete it. Create vol12 with same path of unactive vol11 without --volume-id.
TEST "kadalu volume create DEV/vol11 server1:/exports/vol11/s1 server2:/exports/vol11/s2 server3:/exports/vol11/s3 --no-start"
TEST "kadalu volume create DEV/vol11 #{nodes[0]}:/exports/vol11/s1 #{nodes[1]}:/exports/vol11/s2 #{nodes[2]}:/exports/vol11/s3 --no-start"
TEST "kadalu volume delete DEV/vol11 --mode=script"
TEST 1, "kadalu volume create DEV/vol12 server1:/exports/vol11/s1 server2:/exports/vol11/s2 server3:/exports/vol11/s3 --no-start"
TEST 1, "kadalu volume create DEV/vol12 #{nodes[0]}:/exports/vol11/s1 #{nodes[1]}:/exports/vol11/s2 #{nodes[2]}:/exports/vol11/s3 --no-start"

# Case 5
# Create vol13 with fresh path & no xattrs using --volume-id with wrong format. [Check for matching format of vol-id with uuid]
TEST 1, "kadalu volume create DEV/vol13 server1:/exports/vol12/s1 server2:/exports/vol12/s2 server3:/exports/vol12/s3 --no-start --volume-id=123-456-789"
TEST 1, "kadalu volume create DEV/vol13 #{nodes[0]}:/exports/vol12/s1 #{nodes[1]}:/exports/vol12/s2 #{nodes[2]}:/exports/vol12/s3 --no-start --volume-id=123-456-789"


# Tests for restarting of all services on node-reboot
TEST "kadalu volume create DEV/vol14 server1:/exports/vol14/s1 server2:/exports/vol14/s2 server3:/exports/vol14/s3"
TEST "kadalu volume create DEV/vol14 #{nodes[0]}:/exports/vol14/s1 #{nodes[1]}:/exports/vol14/s2 #{nodes[2]}:/exports/vol14/s3"
nodes.each do |node|
USE_NODE node
puts TEST "ps aux | grep 'glusterfsd'"
EQUAL "1", (TEST "ps aux | grep '[g]lusterfsd'| wc -l").strip, "Check for equal number of services[brick-processes]"
puts TEST "kill $(pidof 'glusterfsd')"
# TODO: This is not working in arm64.
#puts TEST "kill -9 $(pidof 'glusterfsd')"
TEST "systemctl restart kadalu-mgr"
puts TEST "ps aux | grep 'glusterfsd'"
EQUAL "1", (TEST "ps aux | grep '[g]lusterfsd'| wc -l").strip, "Check for equal number of services[brick-processes]"
Expand All @@ -159,8 +161,65 @@ USE_NODE nodes[0]
TEST "kadalu volume stop DEV/vol14 --mode=script"
TEST "kadalu volume delete DEV/vol14 --mode=script"

# Volfile Server tests
# Volume create with known Storage unit port
TEST "mkdir -p /exports/vol_volfile/s1"
TEST "kadalu volume create DEV/vol_volfile #{nodes[0]}:5007:/exports/vol_volfile/s1"
puts TEST "ls /var/lib/kadalu/volfiles"

# Mount the Volume
TEST "mkdir -p /mnt/vol_volfile"
TEST "glusterfs -s #{nodes[0]}:5007 --volfile-id vol_volfile -l/tmp/volspec.log /mnt/vol_volfile"
puts TEST "df /mnt/vol_volfile"

# Use mount command (Different options)
# Using Mgr URL
TEST "mkdir -p /mnt/vol_volfile_1"
puts TEST "mount -t kadalu http://#{nodes[0]}:3000:/DEV/vol_volfile /mnt/vol_volfile_1"
puts TEST "df /mnt/vol_volfile_1"

# TODO: Mgr URL from ENV
TEST "mkdir -p /mnt/vol_volfile_2"
puts TEST "mount -t kadalu /DEV/vol_volfile /mnt/vol_volfile_2"
puts TEST "df /mnt/vol_volfile_2"

# Using Storage Unit URL directly
TEST "mkdir -p /mnt/vol_volfile_3"
puts TEST "mount -t kadalu #{nodes[0]}:5007:/DEV/vol_volfile /mnt/vol_volfile_3"
puts TEST "df /mnt/vol_volfile_3"

# Using Volfile Server option
TEST "mkdir -p /mnt/vol_volfile_4"
puts TEST "mount -t kadalu -o \"volfile-server=#{nodes[0]}:5007\" /DEV/vol_volfile /mnt/vol_volfile_4"
puts TEST "df /mnt/vol_volfile_4"

# Using Volfile Servers option
TEST "mkdir -p /mnt/vol_volfile_5"
puts TEST "mount -t kadalu -o \"volfile-servers=#{nodes[0]}:5007 #{nodes[0]}:5007\" /DEV/vol_volfile /mnt/vol_volfile_5"
puts TEST "df /mnt/vol_volfile_5"

# Using Volfile Path option
TEST "mkdir -p /mnt/vol_volfile_6"
puts TEST "mount -t kadalu /var/lib/kadalu/volfiles/vol_volfile.vol /mnt/vol_volfile_6"
puts TEST "df /mnt/vol_volfile_6"

TEST "umount /mnt/vol_volfile_*"

# Change option using Volume set
TEST "kadalu volume set DEV/vol_volfile debug/io-stats.log-level DEBUG"
TEST "sleep 5"

# Print the mount log to see if the option changed is reflected
puts TEST "cat /tmp/volspec.log"
TEST "grep -q \"Volume file changed\" /tmp/volspec.log"

TEST "umount /mnt/vol_volfile"

TEST "kadalu volume stop DEV/vol_volfile --mode=script"
TEST "kadalu volume delete DEV/vol_volfile --mode=script"

# Tests for Backup & Restore
TEST "kadalu volume create DEV/vol19 server1:/exports/vol19/s1 server2:/exports/vol19/s2 server3:/exports/vol19/s3"
TEST "kadalu volume create DEV/vol19 #{nodes[0]}:/exports/vol19/s1 #{nodes[1]}:/exports/vol19/s2 #{nodes[2]}:/exports/vol19/s3"
USE_NODE nodes[0]
TEST "kadalu config-snapshot create snap1"
puts TEST "kadalu config-snapshot list"
Expand All @@ -171,6 +230,7 @@ TEST "rm -rf /var/lib/kadalu/meta /var/lib/kadalu/info"
TEST "kadalu config-snapshot restore snap1 --mode=script"

TEST "systemctl start kadalu-mgr"
TEST "sleep 5"

TEST "kadalu volume stop DEV/vol19 --mode=script"
TEST "kadalu volume delete DEV/vol19 --mode=script"
Expand Down
4 changes: 3 additions & 1 deletion tests/build-container.sh
Original file line number Diff line number Diff line change
@@ -1,2 +1,4 @@
#!/bin/sh
docker build . --tag kadalu/storage-node-testing -f Dockerfile
docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
docker buildx build --load --platform=linux/amd64 . --tag kadalu-amd/storage-node-testing -f Dockerfile
docker buildx build --load --platform=linux/arm64 . --tag kadalu-arm/storage-node-testing -f Dockerfile
8 changes: 4 additions & 4 deletions tests/install.t
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
# -*- mode: ruby -*-

EMIT_STDOUT true
USE_REMOTE_PLUGIN "docker"
nodes = ["server1", "server2", "server3"]
nodes = ["amd-server1", "amd-server2", "amd-server3", "arm-server1", "arm-server2", "arm-server3"]

# Install Kadalu Storage
nodes.each do |node|
USE_NODE node
TEST "wget -qO- https://kadalu.tech/pkgs/1/ubuntu/20.04/KEY.gpg | sudo tee kadalu_storage.gpg"
TEST "apt-key add kadalu_storage.gpg"
TEST "wget -qO /etc/apt/sources.list.d/kadalu_storage.list https://kadalu.tech/pkgs/1/ubuntu/20.04/sources.list"
TEST "echo 'deb https://kadalu.tech/pkgs/1.0.x/ubuntu/22.04 /' | sudo tee /etc/apt/sources.list.d/kadalu.list"
TEST "curl -fsSL https://kadalu.tech/pkgs/1.0.x/ubuntu/22.04/KEY.gpg | gpg --dearmor | sudo tee /etc/apt/trusted.gpg.d/kadalu.gpg > /dev/null"
TEST "apt update -y"
TEST "apt install -y kadalu-storage"
end
Expand Down
3 changes: 2 additions & 1 deletion tests/reset.t
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
# -*- mode: ruby -*-

EMIT_STDOUT true
USE_REMOTE_PLUGIN "docker"
nodes = ["server1", "server2", "server3"]
nodes = ["amd-server1", "amd-server2", "amd-server3", "arm-server1", "arm-server2", "arm-server3"]

nodes.each do |node|
USE_NODE node
Expand Down
11 changes: 8 additions & 3 deletions tests/setup.t
Original file line number Diff line number Diff line change
@@ -1,19 +1,24 @@
# -*- mode: ruby -*-
EMIT_STDOUT true
USE_REMOTE_PLUGIN "docker"
nodes = ["server1", "server2", "server3"]

# Start three or N storage nodes(Containers)
USE_NODE "local"
nodes.each do |node|
USE_NODE "local"
RUN "docker stop #{node}"
RUN "docker rm #{node}"
RUN "docker stop amd-#{node}"
RUN "docker rm amd-#{node}"
RUN "docker stop arm-#{node}"
RUN "docker rm arm-#{node}"
end

RUN "docker network rm k1"
TEST "docker network create k1"

nodes.each do |node|
USE_NODE "local"
TEST "docker run -d -v /sys/fs/cgroup/:/sys/fs/cgroup:ro --privileged --name #{node} --hostname #{node} --network k1 kadalu/storage-node-testing"
TEST "docker run -d -v /sys/fs/cgroup/:/sys/fs/cgroup:ro --privileged --name amd-#{node} --hostname #{node} --network k1 kadalu-amd/storage-node-testing"
TEST "docker run --rm --privileged multiarch/qemu-user-static --reset -p yes"
TEST "docker run -d -v /sys/fs/cgroup/:/sys/fs/cgroup:ro --privileged --name arm-#{node} --hostname #{node} --network k1 kadalu-arm/storage-node-testing"
end

0 comments on commit 23ea600

Please sign in to comment.