From 75ed7a313caca75e75e6d5d8f9a8de9e680ff376 Mon Sep 17 00:00:00 2001 From: justinwoo Date: Sun, 7 Apr 2024 09:07:55 -0500 Subject: [PATCH] add memory and cpu limits for docker run --- src/TestContainers.hs | 2 ++ src/TestContainers/Docker.hs | 26 ++++++++++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/src/TestContainers.hs b/src/TestContainers.hs index 5677d9b..b2f7838 100644 --- a/src/TestContainers.hs +++ b/src/TestContainers.hs @@ -25,6 +25,8 @@ module TestContainers M.setVolumeMounts, M.setRm, M.setEnv, + M.setMemory, + M.setCpus, M.withWorkingDirectory, M.withNetwork, M.withNetworkAlias, diff --git a/src/TestContainers/Docker.hs b/src/TestContainers/Docker.hs index b51cfc4..acdf716 100644 --- a/src/TestContainers/Docker.hs +++ b/src/TestContainers/Docker.hs @@ -82,6 +82,8 @@ module TestContainers.Docker setSuffixedName, setRandomName, setCmd, + setMemory, + setCpus, setVolumeMounts, setRm, setEnv, @@ -276,6 +278,8 @@ data ContainerRequest = ContainerRequest volumeMounts :: [(Text, Text)], network :: Maybe (Either Network Text), networkAlias :: Maybe Text, + cpus :: Maybe Text, + memory :: Maybe Text, links :: [ContainerId], naming :: NamingStrategy, rmOnExit :: Bool, @@ -311,6 +315,8 @@ containerRequest image = volumeMounts = [], network = Nothing, networkAlias = Nothing, + memory = Nothing, + cpus = Nothing, links = [], rmOnExit = False, readiness = mempty, @@ -363,6 +369,22 @@ setCmd :: [Text] -> ContainerRequest -> ContainerRequest setCmd newCmd req = req {cmd = Just newCmd} +-- | Set the memory limit of a Docker container. This is equivalent to +-- invoking @docker run@ with the @--memory@ parameter. +-- +-- @since x.x.x.x +setMemory :: Text -> ContainerRequest -> ContainerRequest +setMemory newMemory req = + req {memory = Just newMemory} + +-- | Set the cpus limit of a Docker container. This is equivalent to +-- invoking @docker run@ with the @--cpus@ parameter. +-- +-- @since x.x.x.x +setCpus :: Text -> ContainerRequest -> ContainerRequest +setCpus newCpus req = + req {cpus = Just newCpus} + -- | The volume mounts to link to Docker container. This is the equivalent -- of passing the command on the @docker run -v@ invocation. setVolumeMounts :: [(Text, Text)] -> ContainerRequest -> ContainerRequest @@ -525,6 +547,8 @@ run request = do volumeMounts, network, networkAlias, + memory, + cpus, links, rmOnExit, readiness, @@ -569,6 +593,8 @@ run request = do ++ [["--volume", src <> ":" <> dest] | (src, dest) <- volumeMounts] ++ [["--rm"] | rmOnExit] ++ [["--workdir", workdir] | Just workdir <- [workDirectory]] + ++ [["--memory", value] | Just value <- [memory]] + ++ [["--cpus", value] | Just value <- [cpus]] ++ [[tag]] ++ [command | Just command <- [cmd]]