From 31d4a1d441a024ba5642e781c732429b8daf7c13 Mon Sep 17 00:00:00 2001 From: Andrew Cholakian Date: Fri, 15 Jan 2021 06:43:33 -0600 Subject: [PATCH] Cherry-pick #23274 to 7.x: Synthetics docker image (#23380) Co-authored-by: Jaime Soriano Pastor --- CHANGELOG.next.asciidoc | 1 + .../templates/docker/Dockerfile.tmpl | 39 ++++++++++++++++++- 2 files changed, 38 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.next.asciidoc b/CHANGELOG.next.asciidoc index 206c125d0d96..a6a987a93cfd 100644 --- a/CHANGELOG.next.asciidoc +++ b/CHANGELOG.next.asciidoc @@ -553,6 +553,7 @@ https://github.com/elastic/beats/compare/v7.0.0-alpha2...master[Check the HEAD d *Heartbeat* - Add mime type detection for http responses. {pull}22976[22976] +- Bundle synthetics deps with heartbeat docker image. {pull}23274[23274] *Heartbeat* diff --git a/dev-tools/packaging/templates/docker/Dockerfile.tmpl b/dev-tools/packaging/templates/docker/Dockerfile.tmpl index b0d5122adbe5..dd7a0080d6ba 100644 --- a/dev-tools/packaging/templates/docker/Dockerfile.tmpl +++ b/dev-tools/packaging/templates/docker/Dockerfile.tmpl @@ -8,7 +8,15 @@ FROM {{ .buildFrom }} AS home COPY beat {{ $beatHome }} -RUN mkdir {{ $beatHome }}/data {{ $beatHome }}/logs && \ +{{- if (and (eq .BeatName "heartbeat") (not (contains .from "ubi-minimal"))) }} +RUN mkdir -p {{ $beatHome }}/.node \ + {{ $beatHome }}/.npm \ + {{ $beatHome }}/.cache \ + {{ $beatHome }}/.config \ + {{ $beatHome }}/suites +{{- end }} + +RUN mkdir -p {{ $beatHome }}/data {{ $beatHome }}/logs && \ chown -R root:root {{ $beatHome }} && \ find {{ $beatHome }} -type d -exec chmod 0750 {} \; && \ find {{ $beatHome }} -type f -exec chmod 0640 {} \; && \ @@ -28,9 +36,19 @@ RUN microdnf -y --setopt=tsflags=nodocs update && \ microdnf install shadow-utils && \ microdnf clean all {{- else }} -RUN yum -y --setopt=tsflags=nodocs update && yum clean all +RUN yum -y --setopt=tsflags=nodocs update \ + {{- if (eq .BeatName "heartbeat") }} + && yum -y install epel-release \ + && yum -y install atk cups gtk gdk xrandr pango.x86_64 libXcomposite.x86_64 libXcursor.x86_64 libXdamage.x86_64 \ + libXext.x86_64 libXi.x86_64 libXtst.x86_64 cups-libs.x86_64 libXScrnSaver.x86_64 libXrandr.x86_64 GConf2.x86_64 \ + alsa-lib.x86_64 atk.x86_64 gtk3.x86_64 ipa-gothic-fonts xorg-x11-fonts-100dpi xorg-x11-fonts-75dpi xorg-x11-utils \ + xorg-x11-fonts-cyrillic xorg-x11-fonts-Type1 xorg-x11-fonts-misc \ + {{- end }} + && yum clean all && rm -rf /var/cache/yum + # See https://access.redhat.com/discussions/3195102 for why rm is needed {{- end }} + LABEL \ org.label-schema.build-date="{{ date }}" \ org.label-schema.schema-version="1.0" \ @@ -80,6 +98,23 @@ RUN mkdir /licenses COPY --from=home {{ $beatHome }}/LICENSE.txt /licenses COPY --from=home {{ $beatHome }}/NOTICE.txt /licenses +{{- if (and (eq .BeatName "heartbeat") (not (contains .from "ubi-minimal"))) }} +# Setup synthetics env vars +ENV ELASTIC_SYNTHETICS_CAPABLE=true +ENV SUITES_DIR={{ $beatHome }}/suites +ENV NODE_PATH={{ $beatHome }}/.node + +# Setup node +RUN cd /usr/share/heartbeat/.node \ + && mkdir node \ + && curl https://nodejs.org/dist/v12.18.4/node-v12.18.4-linux-x64.tar.xz | tar -xJ --strip 1 -C node +ENV PATH="/usr/share/heartbeat/.node/node/bin:$PATH" +# Install the latest version of @elastic/synthetics forcefully ignoring the previously +# cached node_modules, hearbeat then calls the global executable to run test suites +RUN npm i -g -f @elastic/synthetics +{{- end }} + + {{- if ne .user "root" }} RUN groupadd --gid 1000 {{ .BeatName }} RUN useradd -M --uid 1000 --gid 1000 --groups 0 --home {{ $beatHome }} {{ .user }}