Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CNF-15235: cnf-tests: move to rhel 9 #2139

Merged
merged 9 commits into from
Jan 7, 2025
26 changes: 21 additions & 5 deletions cnf-tests/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
FROM registry.ci.openshift.org/ocp/builder:rhel-8-golang-1.22-openshift-4.18 AS builder-stresser
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 AS builder-stresser
ENV PKG_NAME=github.com/openshift-kni/cnf-features-deploy
ENV PKG_PATH=/go/src/$PKG_NAME
ENV TESTER_PATH=$PKG_PATH/cnf-tests/pod-utils/stresser
Expand All @@ -10,7 +10,7 @@ WORKDIR $TESTER_PATH

RUN go build -mod=vendor -o /stresser

FROM registry.ci.openshift.org/ocp/builder:rhel-8-golang-1.22-openshift-4.18 AS builder-sctptester
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 AS builder-sctptester
ENV PKG_NAME=github.com/openshift-kni/cnf-features-deploy
ENV PKG_PATH=/go/src/$PKG_NAME
ENV TESTER_PATH=$PKG_PATH/cnf-tests/pod-utils/sctptester
Expand All @@ -22,8 +22,22 @@ WORKDIR $TESTER_PATH

RUN go build -mod=vendor -o /sctptest

# build hugepages-allocator's binary
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 AS builder-hugepages-allocator

ENV PKG_NAME=github.com/openshift-kni/cnf-features-deploy
ENV PKG_PATH=/go/src/$PKG_NAME
ENV TOOL_PATH=$PKG_PATH/cnf-tests/pod-utils/hugepages-allocator

RUN mkdir -p $PKG_PATH

COPY . $PKG_PATH/
WORKDIR $TOOL_PATH

RUN go build -mod=vendor -o /hugepages-allocator

# build latency-test's runner binaries
FROM registry.ci.openshift.org/ocp/builder:rhel-8-golang-1.22-openshift-4.18 AS builder-latency-test-runners
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 AS builder-latency-test-runners

ENV PKG_NAME=github.com/openshift-kni/cnf-features-deploy
ENV PKG_PATH=/go/src/$PKG_NAME
Expand All @@ -39,7 +53,7 @@ RUN go build -mod=vendor -o /oslat-runner oslat-runner/main.go && \
go build -mod=vendor -o /hwlatdetect-runner hwlatdetect-runner/main.go

# build latency testing suite
FROM registry.ci.openshift.org/ocp/builder:rhel-8-golang-1.22-openshift-4.18 AS go-builder
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 AS go-builder
WORKDIR /app
COPY . .
RUN make test-bin
Expand All @@ -59,7 +73,7 @@ RUN yum install -y numactl-devel make gcc && \
cp hwlatdetect /hwlatdetect && \
cp cyclictest /cyclictest

FROM quay.io/openshift/origin-oc-rpms:4.16 AS oc
FROM quay.io/openshift/origin-oc-rpms:4.19 AS oc

# Final image
FROM centos:7
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think you need to update this one also

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It was on purpose actually, if we're changing to rhel9 then both Dockerfile and Dockerfile.openshift are identical. So one can be deleted

Expand All @@ -84,6 +98,8 @@ COPY --from=builder-latency-test-tools /hwlatdetect /usr/bin/hwlatdetect

COPY --from=oc /go/src/github.com/openshift/oc/oc /usr/bin/oc

COPY --from=builder-hugepages-allocator /hugepages-allocator /usr/bin//hugepages-allocator

COPY --from=go-builder /app/cnf-tests/bin/mirror /usr/bin/mirror
COPY --from=go-builder /app/cnf-tests/mirror/images.json /usr/local/etc/cnf
COPY --from=go-builder /app/cnf-tests/entrypoint/test-run.sh /usr/bin/test-run.sh
Expand Down
32 changes: 24 additions & 8 deletions cnf-tests/Dockerfile.openshift
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# This dockerfile is specific to building the OpenShift CNF stresser image
FROM registry.ci.openshift.org/ocp/builder:rhel-8-golang-1.22-openshift-4.18 as builder-stresser
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 as builder-stresser

# Add everything
ENV PKG_NAME=github.com/openshift-kni/cnf-features-deploy
Expand All @@ -14,7 +14,7 @@ WORKDIR $STRESSER_PATH
RUN go build -mod=vendor -o /stresser

# This dockerfile is specific to building the OpenShift CNF sctp tester image
FROM registry.ci.openshift.org/ocp/builder:rhel-8-golang-1.22-openshift-4.18 as builder-sctptester
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 as builder-sctptester

# Add everything
ENV PKG_NAME=github.com/openshift-kni/cnf-features-deploy
Expand All @@ -28,8 +28,22 @@ WORKDIR $TESTER_PATH

RUN go build -mod=vendor -o /sctptest

# build hugepages-allocator's binary
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 AS builder-hugepages-allocator

ENV PKG_NAME=github.com/openshift-kni/cnf-features-deploy
ENV PKG_PATH=/go/src/$PKG_NAME
ENV TOOL_PATH=$PKG_PATH/cnf-tests/pod-utils/hugepages-allocator

RUN mkdir -p $PKG_PATH

COPY . $PKG_PATH/
WORKDIR $TOOL_PATH

RUN go build -mod=vendor -o /hugepages-allocator

# build latency-test's runner binaries
FROM registry.ci.openshift.org/ocp/builder:rhel-8-golang-1.22-openshift-4.18 AS builder-latency-test-runners
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 AS builder-latency-test-runners

ENV PKG_NAME=github.com/openshift-kni/cnf-features-deploy
ENV PKG_PATH=/go/src/$PKG_NAME
Expand All @@ -45,13 +59,13 @@ RUN go build -mod=vendor -o /oslat-runner oslat-runner/main.go && \
go build -mod=vendor -o /hwlatdetect-runner hwlatdetect-runner/main.go

# build latency testing suite
FROM registry.ci.openshift.org/ocp/builder:rhel-8-golang-1.22-openshift-4.18 AS go-builder
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 AS go-builder
WORKDIR /app
COPY . .
RUN make test-bin

# Build latency-test binaries
FROM registry.ci.openshift.org/ocp/builder:rhel-8-golang-1.22-openshift-4.18 as builder-latency-test-tools
FROM registry.ci.openshift.org/ocp/builder:rhel-9-golang-1.23-openshift-4.19 as builder-latency-test-tools

ENV RT_TESTS_URL=https://git.kernel.org/pub/scm/utils/rt-tests/rt-tests.git/snapshot
ENV RT_TESTS_PKG=rt-tests-2.0
Expand All @@ -65,13 +79,13 @@ RUN yum install -y numactl-devel make gcc && \
cp hwlatdetect /hwlatdetect && \
cp cyclictest /cyclictest

FROM quay.io/openshift/origin-oc-rpms:4.16 AS oc
FROM registry.ci.openshift.org/ocp/4.19:oc-rpms AS oc

# Final image
FROM openshift/origin-base
FROM registry.ci.openshift.org/ocp/4.19:base-rhel9

# python3 is needed for hwlatdetect
RUN yum install -y lksctp-tools iproute libhugetlbfs-utils libhugetlbfs tmux ethtool iputils numactl-libs iptables kmod linuxptp iperf3 python3 nc iptables && \
RUN yum install -y lksctp-tools iproute tmux ethtool iputils numactl-libs iptables kmod linuxptp iperf3 python3 nc iptables && \
yum clean all

RUN mkdir -p /usr/local/etc/cnf
Expand All @@ -90,6 +104,8 @@ COPY --from=builder-latency-test-tools /hwlatdetect /usr/bin/hwlatdetect

COPY --from=oc /go/src/github.com/openshift/oc/oc /usr/bin/oc

COPY --from=builder-hugepages-allocator /hugepages-allocator /usr/bin//hugepages-allocator

COPY --from=go-builder /app/cnf-tests/bin/mirror /usr/bin/mirror
COPY --from=go-builder /app/cnf-tests/mirror/images.json /usr/local/etc/cnf
COPY --from=go-builder /app/cnf-tests/entrypoint/test-run.sh /usr/bin/test-run.sh
Expand Down
2 changes: 1 addition & 1 deletion cnf-tests/mirror/images.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
[
{
"registry": "quay.io/openshift-kni/",
"image": "cnf-tests:4.16"
"image": "cnf-tests:4.18"
},
{
"registry": "quay.io/openshift-kni/",
Expand Down
90 changes: 90 additions & 0 deletions cnf-tests/pod-utils/hugepages-allocator/main.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
package main

import (
"flag"
"fmt"
"math"
"os"
"os/signal"
"syscall"
"time"
"unsafe"

"k8s.io/klog/v2"
)

const (
// MapHugeShift Shift for HugePage size
MapHugeShift = 26
// DefaultHugePageSize 1GB HugePage size
DefaultHugePageSize = 1 * 1024 * 1024 * 1024
)

// MAP_HUGE_1GB 1GB HugePage mmap flag
const MAP_HUGE_1GB = 30 << MapHugeShift

type Args struct {
TimeDuration time.Duration
HugePageSize int
}

func main() {
klog.InitFlags(nil)
args := &Args{}
flag.DurationVar(&args.TimeDuration, "time-duration", math.MaxInt64, "set the time duration for program to wait - wait forever by default")
flag.IntVar(&args.HugePageSize, "hugepage-size", DefaultHugePageSize, "hugepage size to allocate - allocate 1G by default")

flag.Parse()

// Flags for HugePage allocation
mmapFlags := syscall.MAP_PRIVATE | syscall.MAP_ANONYMOUS | syscall.MAP_HUGETLB | MAP_HUGE_1GB
// Use mmap to allocate memory
addr, _, errno := syscall.Syscall6(
syscall.SYS_MMAP,
0, // Let the kernel choose the address
uintptr(args.HugePageSize), // Size of the memory
uintptr(syscall.PROT_READ|syscall.PROT_WRITE), // Read/Write permissions
uintptr(mmapFlags), // mmap flags
0, // File descriptor (not used for anonymous memory)
0, // Offset
)
if errno != 0 {
klog.ErrorS(fmt.Errorf("errno=%v", errno), "Failed to allocate HugePage")
os.Exit(1)
}
memory := unsafe.Pointer(addr)
// Write a byte to the allocated memory
*(*byte)(memory) = 42

klog.InfoS("Successfully allocated 1GB HugePage memory", "address", fmt.Sprintf("%p", unsafe.Pointer(addr)))

// Cleanup: Unmap the memory
defer func() {
_, _, errno = syscall.Syscall(syscall.SYS_MUNMAP, addr, uintptr(args.HugePageSize), 0)
if errno != 0 {
klog.ErrorS(fmt.Errorf("errno=%v", errno), "Failed to unmap HugePage")
os.Exit(2)
}
klog.InfoS("1GB HugePage memory unmapped successfully")
}()
wait(args.TimeDuration)
}

func wait(timeout time.Duration) {
// Create a channel to listen for signals.
signalChan := make(chan os.Signal, 1)

// SIGINT handles Ctrl+C locally.
// SIGTERM handles Cloud Run termination signal.
signal.Notify(signalChan, syscall.SIGINT, syscall.SIGTERM)

klog.InfoS("Waiting", "period", timeout.String())
select {
// Receive output from signalChan.
case sig := <-signalChan:
klog.InfoS("signal caught", "signal", sig)
case <-time.After(timeout):
klog.InfoS("Done")
return
}
}
2 changes: 1 addition & 1 deletion cnf-tests/testsuites/pkg/images/images.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ func init() {

cnfTestsImage = os.Getenv("CNF_TESTS_IMAGE")
if cnfTestsImage == "" {
cnfTestsImage = "cnf-tests:4.16"
cnfTestsImage = "cnf-tests:4.18"
}

dpdkTestImage = os.Getenv("DPDK_TESTS_IMAGE")
Expand Down
3 changes: 1 addition & 2 deletions cnf-tests/testsuites/pkg/pods/pods.go
Original file line number Diff line number Diff line change
Expand Up @@ -188,8 +188,7 @@ func DefineWithHugePages(namespace, nodeName string) *corev1.Pod {
RedefineWithCommand(
getDefinition(namespace),
[]string{"/bin/bash", "-c",
`tmux new -d 'LD_PRELOAD=libhugetlbfs.so HUGETLB_MORECORE=yes top -b > /dev/null'
sleep INF`}, []string{},
`/usr/bin/hugepages-allocator > /dev/null`}, []string{},
),
corev1.RestartPolicyNever,
)
Expand Down