FROM golang:1.8 # libseccomp in jessie is not _quite_ new enough -- need backports version RUN echo 'deb http://httpredir.debian.org/debian jessie-backports main' > /etc/apt/sources.list.d/backports.list RUN apt-get update && apt-get install -y \ apparmor \ autoconf \ automake \ bison \ build-essential \ curl \ e2fslibs-dev \ gawk \ gettext \ iptables \ pkg-config \ libaio-dev \ libcap-dev \ libfuse-dev \ libostree-dev \ libprotobuf-dev \ libprotobuf-c0-dev \ libseccomp2/jessie-backports \ libseccomp-dev/jessie-backports \ libtool \ libudev-dev \ protobuf-c-compiler \ protobuf-compiler \ python-minimal \ libglib2.0-dev \ libapparmor-dev \ btrfs-tools \ libdevmapper1.02.1 \ libdevmapper-dev \ libgpgme11-dev \ liblzma-dev \ netcat \ socat \ --no-install-recommends \ && apt-get clean # install bats RUN cd /tmp \ && git clone https://github.com/sstephenson/bats.git \ && cd bats \ && git reset --hard 03608115df2071fff4eaaff1605768c275e5f81f \ && ./install.sh /usr/local # install criu ENV CRIU_VERSION 1.7 RUN mkdir -p /usr/src/criu \ && curl -sSL https://github.com/xemul/criu/archive/v${CRIU_VERSION}.tar.gz | tar -v -C /usr/src/criu/ -xz --strip-components=1 \ && cd /usr/src/criu \ && make install-criu \ && rm -rf /usr/src/criu # Install runc ENV RUNC_COMMIT 84a082bfef6f932de921437815355186db37aeb1 RUN set -x \ && export GOPATH="$(mktemp -d)" \ && git clone https://github.com/opencontainers/runc.git "$GOPATH/src/github.com/opencontainers/runc" \ && cd "$GOPATH/src/github.com/opencontainers/runc" \ && git fetch origin --tags \ && git checkout -q "$RUNC_COMMIT" \ && make static BUILDTAGS="seccomp selinux" \ && cp runc /usr/bin/runc \ && rm -rf "$GOPATH" # Install CNI plugins ENV CNI_COMMIT dcf7368eeab15e2affc6256f0bb1e84dd46a34de RUN set -x \ && export GOPATH="$(mktemp -d)" \ && git clone https://github.com/containernetworking/plugins.git "$GOPATH/src/github.com/containernetworking/plugins" \ && cd "$GOPATH/src/github.com/containernetworking/plugins" \ && git checkout -q "$CNI_COMMIT" \ && ./build.sh \ && mkdir -p /usr/libexec/cni \ && cp bin/* /usr/libexec/cni \ && rm -rf "$GOPATH" # Install custom CNI bridge test plugin # XXX: this plugin is meant to be a replacement for the old "test_plugin_args.bash" # we need this in testing because sandbox_run now gather IP address and the mock # plugin wasn't able to properly setup the net ns. # The bridge is based on the same commit as the one above. #ENV CNI_COMMIT 6bfe036c38c8e1410f1acaa4b2ee16f1851472e4 ENV CNI_TEST_BRANCH custom-bridge RUN set -x \ && export GOPATH="$(mktemp -d)" \ && git clone https://github.com/runcom/plugins.git "$GOPATH/src/github.com/containernetworking/plugins" \ && cd "$GOPATH/src/github.com/containernetworking/plugins" \ && git checkout -q "$CNI_TEST_BRANCH" \ && ./build.sh \ && mkdir -p /opt/cni/bin \ && cp bin/bridge /opt/cni/bin/bridge-custom \ && rm -rf "$GOPATH" # Install crictl ENV CRICTL_COMMIT 16e6fe4d7199c5689db4630a9330e6a8a12cecd1 RUN set -x \ && export GOPATH="$(mktemp -d)" \ && git clone https://github.com/kubernetes-incubator/cri-tools.git "$GOPATH/src/github.com/kubernetes-incubator/cri-tools" \ && cd "$GOPATH/src/github.com/kubernetes-incubator/cri-tools" \ && git checkout -q "$CRICTL_COMMIT" \ && go install github.com/kubernetes-incubator/cri-tools/cmd/crictl \ && cp "$GOPATH"/bin/crictl /usr/bin/ \ && rm -rf "$GOPATH" # Make sure we have some policy for pulling images RUN mkdir -p /etc/containers COPY test/policy.json /etc/containers/policy.json COPY test/redhat_sigstore.yaml /etc/containers/registries.d/registry.access.redhat.com.yaml WORKDIR /go/src/github.com/projectatomic/libpod ADD . /go/src/github.com/projectatomic/libpod