ClickHouse/docker/test/integration/base/Dockerfile

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

75 lines
2.3 KiB
Docker
Raw Normal View History

# rebuild in #33610
2021-09-06 11:33:39 +00:00
# docker build -t clickhouse/integration-test .
ARG FROM_TAG=latest
FROM clickhouse/test-base:$FROM_TAG
2019-07-09 19:41:22 +00:00
2021-06-18 11:02:15 +00:00
SHELL ["/bin/bash", "-c"]
2019-05-21 06:17:46 +00:00
RUN apt-get update \
2019-12-13 13:56:53 +00:00
&& env DEBIAN_FRONTEND=noninteractive apt-get -y install \
bsdutils \
curl \
default-jre \
g++ \
2019-12-13 13:56:53 +00:00
gdb \
iproute2 \
krb5-user \
libicu-dev \
2019-12-13 13:56:53 +00:00
libsqlite3-dev \
libsqliteodbc \
lsof \
lz4 \
2019-12-13 13:56:53 +00:00
odbc-postgresql \
odbcinst \
python3 \
rpm2cpio \
2019-12-13 13:56:53 +00:00
sqlite3 \
tar \
tzdata \
unixodbc \
2022-10-14 15:39:08 +00:00
python3-pip \
libcurl4-openssl-dev \
libssl-dev \
&& apt-get clean \
&& rm -rf /var/lib/apt/lists/* /var/cache/debconf /tmp/*
2021-06-18 11:02:15 +00:00
2022-10-14 15:39:08 +00:00
RUN pip3 install pycurl
# Architecture of the image when BuildKit/buildx is used
ARG TARGETARCH
2019-12-13 13:56:53 +00:00
# Install MySQL ODBC driver from RHEL rpm
2022-07-29 09:52:20 +00:00
# For reference https://downloads.mysql.com/archives/c-odbc/ RHEL
RUN arch=${TARGETARCH:-amd64} \
&& case $arch in \
amd64) rarch=x86_64 ;; \
arm64) rarch=aarch64 ;; \
esac \
&& cd /tmp \
2023-06-20 11:11:11 +00:00
&& curl -o mysql-odbc.rpm "https://cdn.mysql.com/archives/mysql-connector-odbc-8.0/mysql-connector-odbc-8.0.32-1.el9.${rarch}.rpm" \
&& rpm2archive mysql-odbc.rpm \
&& tar xf mysql-odbc.rpm.tgz -C / ./usr/lib64/ \
2023-06-20 11:11:11 +00:00
&& rm mysql-odbc.rpm mysql-odbc.rpm.tgz \
&& ODBC_DIR=$(dpkg -L odbc-postgresql | rg '^/usr/lib/.*-linux-gnu/odbc$') \
&& ln -s /usr/lib64/libmyodbc8a.so "$ODBC_DIR" \
&& ln -s /usr/lib64/libmyodbc8a.so "$ODBC_DIR"/libmyodbc.so
2021-06-18 11:02:15 +00:00
# Unfortunately this is required for a single test for conversion data from zookeeper to clickhouse-keeper.
# ZooKeeper is not started by default, but consumes some space in containers.
# 777 perms used to allow anybody to start/stop ZooKeeper
ENV ZOOKEEPER_VERSION='3.6.3'
RUN curl "https://archive.apache.org/dist/zookeeper/zookeeper-${ZOOKEEPER_VERSION}/apache-zookeeper-${ZOOKEEPER_VERSION}-bin.tar.gz" | \
tar -C opt -zxv && \
mv /opt/apache-zookeeper-${ZOOKEEPER_VERSION}-bin /opt/zookeeper && \
chmod -R 777 /opt/zookeeper && \
echo $'tickTime=2500 \n\
2021-06-18 11:02:15 +00:00
tickTime=2500 \n\
dataDir=/zookeeper \n\
clientPort=2181 \n\
maxClientCnxns=80' > /opt/zookeeper/conf/zoo.cfg && \
mkdir /zookeeper && \
chmod -R 777 /zookeeper
2021-06-18 11:02:15 +00:00
2022-03-14 20:43:51 +00:00
ENV TZ=Etc/UTC
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone