mirror of
https://github.com/versity/versitygw.git
synced 2026-01-04 19:13:57 +00:00
74 lines
2.2 KiB
Plaintext
74 lines
2.2 KiB
Plaintext
FROM ubuntu:latest
|
|
|
|
ARG DEBIAN_FRONTEND=noninteractive
|
|
ARG SECRETS_FILE=tests/.secrets.direct
|
|
ARG CONFIG_FILE=tests/.env.direct
|
|
ARG AWS_CLI=awscli-exe-linux-aarch64.zip
|
|
ARG MC_FOLDER=linux-arm64
|
|
|
|
ENV TZ=Etc/UTC
|
|
RUN apt-get update && \
|
|
apt-get install -y --no-install-recommends \
|
|
git \
|
|
wget \
|
|
curl \
|
|
unzip \
|
|
tzdata \
|
|
s3cmd \
|
|
jq \
|
|
bc \
|
|
libxml2-utils \
|
|
ca-certificates && \
|
|
update-ca-certificates && \
|
|
rm -rf /var/lib/apt/lists/*
|
|
|
|
# Set working directory
|
|
WORKDIR /tmp
|
|
|
|
# Install AWS cli
|
|
RUN curl "https://awscli.amazonaws.com/${AWS_CLI}" -o "awscliv2.zip" && unzip awscliv2.zip && ./aws/install
|
|
|
|
# Install mc
|
|
RUN curl https://dl.min.io/client/mc/release/${MC_FOLDER}/mc \
|
|
--create-dirs \
|
|
-o /usr/local/minio-binaries/mc && \
|
|
chmod -R 755 /usr/local/minio-binaries
|
|
ENV PATH=/usr/local/minio-binaries:${PATH}
|
|
|
|
# Create tester user
|
|
RUN groupadd -r tester && useradd -r -g tester tester
|
|
RUN mkdir /home/tester && chown tester:tester /home/tester
|
|
ENV HOME=/home/tester
|
|
|
|
# install bats
|
|
RUN git clone https://github.com/bats-core/bats-core.git && \
|
|
cd bats-core && \
|
|
./install.sh /home/tester
|
|
|
|
USER tester
|
|
RUN mkdir -p /home/tester/tests
|
|
COPY --chown=tester:tester . /home/tester
|
|
|
|
# add bats support libraries
|
|
RUN git clone https://github.com/bats-core/bats-support.git && rm -rf /home/tester/tests/bats-support && mv bats-support /home/tester/tests
|
|
RUN git clone https://github.com/ztombol/bats-assert.git && rm -rf /home/tester/tests/bats-assert && mv bats-assert /home/tester/tests
|
|
|
|
WORKDIR /home/tester
|
|
|
|
RUN . $SECRETS_FILE && \
|
|
export AWS_ACCESS_KEY_ID AWS_SECRET_ACCESS_KEY AWS_REGION AWS_PROFILE && \
|
|
aws configure set aws_access_key_id $AWS_ACCESS_KEY_ID --profile $AWS_PROFILE && \
|
|
aws configure set aws_secret_access_key $AWS_SECRET_ACCESS_KEY --profile $AWS_PROFILE && \
|
|
aws configure set aws_region $AWS_REGION --profile $AWS_PROFILE
|
|
|
|
RUN mkdir /tmp/gw
|
|
|
|
RUN openssl genpkey -algorithm RSA -out versitygw-docker.pem -pkeyopt rsa_keygen_bits:2048 && \
|
|
openssl req -new -x509 -key versitygw-docker.pem -out cert-docker.pem -days 365 \
|
|
-subj "/C=US/ST=California/L=San Francisco/O=Versity/OU=Software/CN=versity.com"
|
|
|
|
ENV WORKSPACE=.
|
|
ENV VERSITYGW_TEST_ENV=$CONFIG_FILE
|
|
|
|
CMD ["tests/run_all.sh"]
|