From 58e57df2c98a442471d02cf9edd5aab7d4711f5b Mon Sep 17 00:00:00 2001 From: Ilia Beliaev Date: Thu, 11 Apr 2024 09:19:29 +0200 Subject: [PATCH] Fix checking Reaper and the SSHd containers when `_HUB_IMAGE_NAME_PREFIX` provided (#751) --- .../src/container-runtime/image-name.test.ts | 1 + .../testcontainers/src/container-runtime/image-name.ts | 9 ++++++--- .../testcontainers/src/port-forwarder/port-forwarder.ts | 6 ++++-- packages/testcontainers/src/reaper/reaper.ts | 6 ++++-- 4 files changed, 15 insertions(+), 7 deletions(-) diff --git a/packages/testcontainers/src/container-runtime/image-name.test.ts b/packages/testcontainers/src/container-runtime/image-name.test.ts index 785658b6d..fe919ae62 100644 --- a/packages/testcontainers/src/container-runtime/image-name.test.ts +++ b/packages/testcontainers/src/container-runtime/image-name.test.ts @@ -167,6 +167,7 @@ describe("ContainerImage", () => { { customRegistry: "custom.com/registry", expectedRegistry: "custom.com", expectedImagePrefix: "registry/" }, { customRegistry: "custom.com/registry/", expectedRegistry: "custom.com", expectedImagePrefix: "registry/" }, { customRegistry: "custom.com", expectedRegistry: "custom.com", expectedImagePrefix: "" }, + { customRegistry: "custom.com/", expectedRegistry: "custom.com", expectedImagePrefix: "" }, { customRegistry: "custom.com/registry/with/slashes", expectedRegistry: "custom.com", diff --git a/packages/testcontainers/src/container-runtime/image-name.ts b/packages/testcontainers/src/container-runtime/image-name.ts index 7c9221141..8e8e85427 100644 --- a/packages/testcontainers/src/container-runtime/image-name.ts +++ b/packages/testcontainers/src/container-runtime/image-name.ts @@ -14,11 +14,14 @@ export class ImageName { const prefix = process.env.TESTCONTAINERS_HUB_IMAGE_NAME_PREFIX; // Parse the registry. If it's undefined - then the whole prefix is a registry. - const registry = ImageName.getRegistry(prefix); - this.registry = registry ?? prefix; + const parsedRegistry = ImageName.getRegistry(prefix); + this.registry = parsedRegistry ?? prefix; // If the registry is defined, then the imagePrefix is the rest of the prefix. - const imagePrefix = registry ? prefix.substring(prefix.indexOf("/") + 1).replace(/\/?$/, "/") : ""; + let imagePrefix = parsedRegistry ? prefix.substring(prefix.indexOf("/") + 1) : ""; + if (imagePrefix) { + imagePrefix = imagePrefix.replace(/\/?$/, "/"); + } const originalImage = this.image; this.image = `${imagePrefix}${this.image}`; diff --git a/packages/testcontainers/src/port-forwarder/port-forwarder.ts b/packages/testcontainers/src/port-forwarder/port-forwarder.ts index 989549be8..f13139508 100644 --- a/packages/testcontainers/src/port-forwarder/port-forwarder.ts +++ b/packages/testcontainers/src/port-forwarder/port-forwarder.ts @@ -1,13 +1,15 @@ import { createSshConnection, SshConnection } from "ssh-remote-port-forward"; import { GenericContainer } from "../generic-container/generic-container"; import { log, withFileLock } from "../common"; -import { ContainerRuntimeClient, getContainerRuntimeClient } from "../container-runtime"; +import { ContainerRuntimeClient, getContainerRuntimeClient, ImageName } from "../container-runtime"; import { getReaper } from "../reaper/reaper"; import { PortWithOptionalBinding } from "../utils/port"; import Dockerode, { ContainerInfo } from "dockerode"; import { LABEL_TESTCONTAINERS_SESSION_ID, LABEL_TESTCONTAINERS_SSHD } from "../utils/labels"; -export const SSHD_IMAGE = process.env["SSHD_CONTAINER_IMAGE"] ?? "testcontainers/sshd:1.1.0"; +export const SSHD_IMAGE = process.env["SSHD_CONTAINER_IMAGE"] + ? ImageName.fromString(process.env["SSHD_CONTAINER_IMAGE"]).string + : ImageName.fromString("testcontainers/sshd:1.1.0").string; class PortForwarder { constructor( diff --git a/packages/testcontainers/src/reaper/reaper.ts b/packages/testcontainers/src/reaper/reaper.ts index a9841a8ed..fd9fdf87b 100644 --- a/packages/testcontainers/src/reaper/reaper.ts +++ b/packages/testcontainers/src/reaper/reaper.ts @@ -2,11 +2,13 @@ import { ContainerInfo } from "dockerode"; import { GenericContainer } from "../generic-container/generic-container"; import { Wait } from "../wait-strategies/wait"; import { Socket } from "net"; -import { ContainerRuntimeClient } from "../container-runtime"; +import { ContainerRuntimeClient, ImageName } from "../container-runtime"; import { IntervalRetry, log, RandomUuid, withFileLock } from "../common"; import { LABEL_TESTCONTAINERS_SESSION_ID } from "../utils/labels"; -export const REAPER_IMAGE = process.env["RYUK_CONTAINER_IMAGE"] ?? "testcontainers/ryuk:0.5.1"; +export const REAPER_IMAGE = process.env["RYUK_CONTAINER_IMAGE"] + ? ImageName.fromString(process.env["RYUK_CONTAINER_IMAGE"]).string + : ImageName.fromString("testcontainers/ryuk:0.5.1").string; export interface Reaper { sessionId: string;