81ba992e3e
OBS-URL: https://build.opensuse.org/package/show/systemsmanagement:saltstack/salt?expand=0&rev=205
57 lines
1.6 KiB
Diff
57 lines
1.6 KiB
Diff
From af5eb3f436fa405b76851c6ba0d491559b020974 Mon Sep 17 00:00:00 2001
|
|
From: Vladimir Nadvornik <nadvornik@suse.cz>
|
|
Date: Mon, 27 Jun 2022 17:00:58 +0200
|
|
Subject: [PATCH] Save log to logfile with docker.build
|
|
|
|
---
|
|
salt/modules/dockermod.py | 18 ++++++++++++++++++
|
|
1 file changed, 18 insertions(+)
|
|
|
|
diff --git a/salt/modules/dockermod.py b/salt/modules/dockermod.py
|
|
index ab5c2ac609..461c89431f 100644
|
|
--- a/salt/modules/dockermod.py
|
|
+++ b/salt/modules/dockermod.py
|
|
@@ -4001,6 +4001,7 @@ def build(
|
|
fileobj=None,
|
|
dockerfile=None,
|
|
buildargs=None,
|
|
+ logfile=None,
|
|
):
|
|
"""
|
|
.. versionchanged:: 2018.3.0
|
|
@@ -4054,6 +4055,9 @@ def build(
|
|
buildargs
|
|
A dictionary of build arguments provided to the docker build process.
|
|
|
|
+ logfile
|
|
+ Path to log file. Output from build is written to this file if not None.
|
|
+
|
|
|
|
**RETURN DATA**
|
|
|
|
@@ -4128,6 +4132,20 @@ def build(
|
|
stream_data = []
|
|
for line in response:
|
|
stream_data.extend(salt.utils.json.loads(line, cls=DockerJSONDecoder))
|
|
+
|
|
+ if logfile:
|
|
+ try:
|
|
+ with salt.utils.files.fopen(logfile, "a") as f:
|
|
+ for item in stream_data:
|
|
+ try:
|
|
+ item_type = next(iter(item))
|
|
+ except StopIteration:
|
|
+ continue
|
|
+ if item_type == "stream":
|
|
+ f.write(item[item_type])
|
|
+ except OSError:
|
|
+ log.error("Unable to write logfile '%s'", logfile)
|
|
+
|
|
errors = []
|
|
# Iterate through API response and collect information
|
|
for item in stream_data:
|
|
--
|
|
2.37.3
|
|
|
|
|