mirror of
https://github.com/linuxkit/linuxkit.git
synced 2025-07-22 02:21:34 +00:00
Merge pull request #1937 from rneugeba/mstage
Convert remaining packages to multi-stage, git tree hash, and Alpine base
This commit is contained in:
commit
9e39a8f642
2
Makefile
2
Makefile
@ -5,7 +5,7 @@ all: default
|
|||||||
VERSION="0.0" # dummy for now
|
VERSION="0.0" # dummy for now
|
||||||
GIT_COMMIT=$(shell git rev-list -1 HEAD)
|
GIT_COMMIT=$(shell git rev-list -1 HEAD)
|
||||||
|
|
||||||
GO_COMPILE=linuxkit/go-compile:3ba94f14de51b73551417e769d122815ec917ee7
|
GO_COMPILE=linuxkit/go-compile:6579a00b44686d0e504d513fc4860094769fe7df
|
||||||
|
|
||||||
MOBY?=bin/moby
|
MOBY?=bin/moby
|
||||||
LINUXKIT?=bin/linuxkit
|
LINUXKIT?=bin/linuxkit
|
||||||
|
@ -22,7 +22,7 @@ docker run -it --rm \
|
|||||||
-v $(PWD):/go/src/github.com/docker/moby \
|
-v $(PWD):/go/src/github.com/docker/moby \
|
||||||
-w /go/src/github.com/docker/moby \
|
-w /go/src/github.com/docker/moby \
|
||||||
--entrypoint /go/bin/vndr \
|
--entrypoint /go/bin/vndr \
|
||||||
linuxkit/go-compile:90607983001c2789911afabf420394d51f78ced8
|
linuxkit/go-compile:6579a00b44686d0e504d513fc4860094769fe7df
|
||||||
```
|
```
|
||||||
|
|
||||||
To update a single dependency:
|
To update a single dependency:
|
||||||
@ -32,7 +32,7 @@ docker run -it --rm \
|
|||||||
-v $(PWD):/go/src/github.com/docker/moby \
|
-v $(PWD):/go/src/github.com/docker/moby \
|
||||||
-w /go/src/github.com/docker/moby \
|
-w /go/src/github.com/docker/moby \
|
||||||
--entrypoint /go/bin/vndr \
|
--entrypoint /go/bin/vndr \
|
||||||
linuxkit/go-compile:90607983001c2789911afabf420394d51f78ced8 \
|
linuxkit/go-compile:6579a00b44686d0e504d513fc4860094769fe7df \
|
||||||
github.com/docker/docker
|
github.com/docker/docker
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
// QemuImg is the version of qemu container
|
// QemuImg is the version of qemu container
|
||||||
const QemuImg = "linuxkit/qemu:17f052263d63c8a2b641ad91c589edcbb8a18c82"
|
const QemuImg = "linuxkit/qemu:c9691f5c50dd191e62b77eaa2f3dfd05ed2ed77c"
|
||||||
|
|
||||||
// QemuConfig contains the config for Qemu
|
// QemuConfig contains the config for Qemu
|
||||||
type QemuConfig struct {
|
type QemuConfig struct {
|
||||||
|
@ -7,7 +7,7 @@ init:
|
|||||||
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
||||||
onboot:
|
onboot:
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "10"]
|
command: ["/bin/sh", "/poweroff.sh", "10"]
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
|
@ -7,7 +7,7 @@ init:
|
|||||||
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
||||||
onboot:
|
onboot:
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "10"]
|
command: ["/bin/sh", "/poweroff.sh", "10"]
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
|
@ -7,7 +7,7 @@ init:
|
|||||||
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
||||||
onboot:
|
onboot:
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "10"]
|
command: ["/bin/sh", "/poweroff.sh", "10"]
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
|
@ -7,7 +7,7 @@ init:
|
|||||||
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
||||||
onboot:
|
onboot:
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "10"]
|
command: ["/bin/sh", "/poweroff.sh", "10"]
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
|
@ -7,7 +7,7 @@ init:
|
|||||||
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
||||||
onboot:
|
onboot:
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "3"]
|
command: ["/bin/sh", "/poweroff.sh", "3"]
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
|
@ -7,7 +7,7 @@ init:
|
|||||||
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
||||||
onboot:
|
onboot:
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "10"]
|
command: ["/bin/sh", "/poweroff.sh", "10"]
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
|
@ -10,7 +10,7 @@ onboot:
|
|||||||
image: "linuxkit/test-kernel-config:ecff41279ccbc408079a3996a956432651c6eb9c"
|
image: "linuxkit/test-kernel-config:ecff41279ccbc408079a3996a956432651c6eb9c"
|
||||||
readonly: true
|
readonly: true
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "3"]
|
command: ["/bin/sh", "/poweroff.sh", "3"]
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
|
@ -10,7 +10,7 @@ onboot:
|
|||||||
image: "linuxkit/test-kernel-config:ecff41279ccbc408079a3996a956432651c6eb9c"
|
image: "linuxkit/test-kernel-config:ecff41279ccbc408079a3996a956432651c6eb9c"
|
||||||
readonly: true
|
readonly: true
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "3"]
|
command: ["/bin/sh", "/poweroff.sh", "3"]
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
|
@ -10,7 +10,7 @@ onboot:
|
|||||||
image: "linuxkit/test-kernel-config:ecff41279ccbc408079a3996a956432651c6eb9c"
|
image: "linuxkit/test-kernel-config:ecff41279ccbc408079a3996a956432651c6eb9c"
|
||||||
readonly: true
|
readonly: true
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "3"]
|
command: ["/bin/sh", "/poweroff.sh", "3"]
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
|
@ -14,7 +14,7 @@ onboot:
|
|||||||
capabilities:
|
capabilities:
|
||||||
- all
|
- all
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "3"]
|
command: ["/bin/sh", "/poweroff.sh", "3"]
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
|
@ -36,7 +36,7 @@ services:
|
|||||||
- /lib/modules:/lib/modules
|
- /lib/modules:/lib/modules
|
||||||
- /run:/var/run
|
- /run:/var/run
|
||||||
- name: test-docker-bench
|
- name: test-docker-bench
|
||||||
image: "linuxkit/test-docker-bench:2f941429d874c5dcf05e38005affb4f10192e1a8"
|
image: "linuxkit/test-docker-bench:5264fdfd098d2bfbacd88159e92bc59a9d2be6cc"
|
||||||
ipc: host
|
ipc: host
|
||||||
pid: host
|
pid: host
|
||||||
net: host
|
net: host
|
||||||
|
@ -16,7 +16,7 @@ onboot:
|
|||||||
- /proc/sys/fs/binfmt_misc:/binfmt_misc
|
- /proc/sys/fs/binfmt_misc:/binfmt_misc
|
||||||
command: ["sh", "./check.sh"]
|
command: ["sh", "./check.sh"]
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "10"]
|
command: ["/bin/sh", "/poweroff.sh", "10"]
|
||||||
files:
|
files:
|
||||||
- path: check.sh
|
- path: check.sh
|
||||||
|
@ -15,7 +15,7 @@ onboot:
|
|||||||
- /etc:/host-etc
|
- /etc:/host-etc
|
||||||
command: ["sh", "./check.sh"]
|
command: ["sh", "./check.sh"]
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "10"]
|
command: ["/bin/sh", "/poweroff.sh", "10"]
|
||||||
files:
|
files:
|
||||||
- path: check.sh
|
- path: check.sh
|
||||||
|
@ -17,7 +17,7 @@ onboot:
|
|||||||
- /check.sh:/check.sh
|
- /check.sh:/check.sh
|
||||||
command: ["sh", "./check.sh"]
|
command: ["sh", "./check.sh"]
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "10"]
|
command: ["/bin/sh", "/poweroff.sh", "10"]
|
||||||
files:
|
files:
|
||||||
- path: check.sh
|
- path: check.sh
|
||||||
|
@ -9,7 +9,7 @@ onboot:
|
|||||||
- name: mkimage
|
- name: mkimage
|
||||||
image: "linuxkit/mkimage:a3fd615543b84733ac8ba6f7e1927727665ef404"
|
image: "linuxkit/mkimage:a3fd615543b84733ac8ba6f7e1927727665ef404"
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
files:
|
files:
|
||||||
- path: data/kernel
|
- path: data/kernel
|
||||||
source: run-kernel
|
source: run-kernel
|
||||||
|
@ -7,7 +7,7 @@ init:
|
|||||||
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
||||||
onboot:
|
onboot:
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
trust:
|
trust:
|
||||||
org:
|
org:
|
||||||
- linuxkit
|
- linuxkit
|
||||||
|
@ -18,7 +18,7 @@ onboot:
|
|||||||
- /check.sh:/check.sh
|
- /check.sh:/check.sh
|
||||||
command: ["sh", "./check.sh"]
|
command: ["sh", "./check.sh"]
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "10"]
|
command: ["/bin/sh", "/poweroff.sh", "10"]
|
||||||
files:
|
files:
|
||||||
- path: check.sh
|
- path: check.sh
|
||||||
|
@ -7,15 +7,11 @@ init:
|
|||||||
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
- linuxkit/containerd:b1766e4c4c09f63ac4925a6e4612852a93f7e73b
|
||||||
onboot:
|
onboot:
|
||||||
- name: ltp
|
- name: ltp
|
||||||
image: "linuxkit/test-ltp:20170116"
|
image: "linuxkit/test-ltp:6df23ac196332cafb9c0f8e32f328e22d612267d"
|
||||||
net: host
|
|
||||||
pid: host
|
|
||||||
binds:
|
binds:
|
||||||
- /etc/ltp/baseline:/etc/ltp/baseline
|
- /etc/ltp/baseline:/etc/ltp/baseline
|
||||||
capabilities:
|
|
||||||
- all
|
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
files:
|
files:
|
||||||
- path: /etc/ltp/baseline
|
- path: /etc/ltp/baseline
|
||||||
contents: "100"
|
contents: "100"
|
||||||
|
@ -15,7 +15,7 @@ onboot:
|
|||||||
image: "linuxkit/test-kernel-config:ecff41279ccbc408079a3996a956432651c6eb9c"
|
image: "linuxkit/test-kernel-config:ecff41279ccbc408079a3996a956432651c6eb9c"
|
||||||
readonly: true
|
readonly: true
|
||||||
- name: poweroff
|
- name: poweroff
|
||||||
image: "linuxkit/poweroff:a8f1e4ad8d459f1fdaad9e4b007512cb3b504ae8"
|
image: "linuxkit/poweroff:7404cf2295df89ccfa2dda41997a28307a90cf28"
|
||||||
command: ["/bin/sh", "/poweroff.sh", "3"]
|
command: ["/bin/sh", "/poweroff.sh", "3"]
|
||||||
trust:
|
trust:
|
||||||
image:
|
image:
|
||||||
|
@ -1,22 +1,31 @@
|
|||||||
FROM alpine:3.5
|
FROM linuxkit/alpine:451603daf499e3a40308dbf5571dcffed2343ffa AS mirror
|
||||||
RUN apk update && apk upgrade && apk add --no-cache bash curl
|
RUN mkdir -p /out/etc/apk && cp -r /etc/apk/* /out/etc/apk/
|
||||||
ADD . ./
|
RUN apk add --no-cache --initdb -p /out \
|
||||||
|
alpine-baselayout \
|
||||||
|
busybox \
|
||||||
|
bash \
|
||||||
|
curl
|
||||||
|
RUN rm -rf /out/etc/apk /out/lib/apk /out/var/cache
|
||||||
|
|
||||||
# Also add docker
|
FROM scratch
|
||||||
|
WORKDIR /
|
||||||
|
COPY --from=mirror /out/ /
|
||||||
|
|
||||||
|
# Add docker
|
||||||
ENV DOCKER_BUCKET get.docker.com
|
ENV DOCKER_BUCKET get.docker.com
|
||||||
ENV DOCKER_VERSION 17.04.0-ce
|
ENV DOCKER_VERSION 17.05.0-ce
|
||||||
ENV DOCKER_SHA256 c52cff62c4368a978b52e3d03819054d87bcd00d15514934ce2e0e09b99dd100
|
ENV DOCKER_SHA256 340e0b5a009ba70e1b644136b94d13824db0aeb52e09071410f35a95d94316d9
|
||||||
|
|
||||||
# Downloads docker but only installs the client
|
# Install just the client
|
||||||
RUN set -x \
|
RUN set -x \
|
||||||
&& curl -fSL "https://${DOCKER_BUCKET}/builds/$(uname -s)/$(uname -m)/docker-${DOCKER_VERSION}.tgz" -o docker.tgz \
|
&& curl -fSL "https://${DOCKER_BUCKET}/builds/Linux/x86_64/docker-${DOCKER_VERSION}.tgz" -o docker.tgz \
|
||||||
&& echo "${DOCKER_SHA256} *docker.tgz" | sha256sum -c - \
|
&& echo "${DOCKER_SHA256} *docker.tgz" | sha256sum -c - \
|
||||||
&& tar -xzvf docker.tgz \
|
&& tar -xzvf docker.tgz \
|
||||||
&& mv docker/docker /usr/bin/ \
|
&& mv docker/docker /usr/bin/ \
|
||||||
&& rm -rf docker \
|
&& rm -rf docker \
|
||||||
&& rm docker.tgz \
|
&& rm docker.tgz \
|
||||||
&& docker -v
|
&& docker -v
|
||||||
|
|
||||||
COPY . ./
|
COPY bench_runner.sh ./bench_runner.sh
|
||||||
|
|
||||||
ENTRYPOINT ["/bin/sh", "/bench_runner.sh"]
|
ENTRYPOINT ["/bin/sh", "/bench_runner.sh"]
|
||||||
|
@ -1,29 +1,15 @@
|
|||||||
.PHONY: tag push
|
.PHONY: tag push
|
||||||
|
|
||||||
BASE=alpine:3.5
|
|
||||||
IMAGE=test-docker-bench
|
|
||||||
|
|
||||||
default: push
|
default: push
|
||||||
|
|
||||||
hash: Dockerfile bench_runner.sh
|
ORG?=linuxkit
|
||||||
DOCKER_CONTENT_TRUST=1 docker pull $(BASE)
|
IMAGE=test-docker-bench
|
||||||
tar cf - $^ | docker build --no-cache -t $(IMAGE):build -
|
DEPS=Dockerfile Makefile bench_runner.sh
|
||||||
docker run --rm --entrypoint=/bin/sh $(IMAGE):build -c "cat $^ /lib/apk/db/installed | sha1sum" | sed 's/ .*//' > hash
|
|
||||||
|
|
||||||
push: hash
|
HASH?=$(shell git ls-tree HEAD -- ../$(notdir $(CURDIR)) | awk '{print $$3}')
|
||||||
DOCKER_CONTENT_TRUST=1 docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
|
||||||
(docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash) && \
|
|
||||||
DOCKER_CONTENT_TRUST=1 docker push linuxkit/$(IMAGE):$(shell cat hash))
|
|
||||||
docker rmi $(IMAGE):build
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
tag: hash
|
tag: $(DEPS)
|
||||||
docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
docker build --squash --no-cache -t $(ORG)/$(IMAGE):$(HASH) .
|
||||||
docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash)
|
|
||||||
docker rmi $(IMAGE):build
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
clean:
|
push: tag
|
||||||
rm -f hash
|
DOCKER_CONTENT_TRUST=1 docker pull $(ORG)/$(IMAGE):$(HASH) || \
|
||||||
|
DOCKER_CONTENT_TRUST=1 docker push $(ORG)/$(IMAGE):$(HASH)
|
||||||
.DELETE_ON_ERROR:
|
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
FROM debian:jessie
|
FROM debian:jessie@sha256:476959f29a17423a24a17716e058352ff6fbf13d8389e4a561c8ccc758245937 AS build
|
||||||
|
|
||||||
ARG LTP_VERSION
|
|
||||||
|
|
||||||
|
ENV LTP_VERSION=20170116
|
||||||
ENV LTP_SOURCE=https://github.com/linux-test-project/ltp/releases/download/${LTP_VERSION}/ltp-full-${LTP_VERSION}.tar.xz
|
ENV LTP_SOURCE=https://github.com/linux-test-project/ltp/releases/download/${LTP_VERSION}/ltp-full-${LTP_VERSION}.tar.xz
|
||||||
ENV DEBIAN_FRONTEND=noninteractive
|
ENV DEBIAN_FRONTEND=noninteractive
|
||||||
|
|
||||||
@ -17,3 +16,10 @@ RUN cd /ltp \
|
|||||||
&& ./configure \
|
&& ./configure \
|
||||||
&& make -j "$(getconf _NPROCESSORS_ONLN)" all \
|
&& make -j "$(getconf _NPROCESSORS_ONLN)" all \
|
||||||
&& make install
|
&& make install
|
||||||
|
|
||||||
|
FROM debian:jessie-slim@sha256:12d31a3d5a1f7cb272708be35031ba068dec46fa84af6aeb38aef5c8a83e8974
|
||||||
|
COPY --from=build /opt/ltp/ /opt/ltp/
|
||||||
|
ADD check.sh ./check.sh
|
||||||
|
WORKDIR /opt/ltp
|
||||||
|
ENTRYPOINT ["/bin/sh", "/check.sh"]
|
||||||
|
LABEL org.mobyproject.config='{"pid": "host", "capabilities": ["all"]}'
|
@ -1,4 +0,0 @@
|
|||||||
FROM debian:jessie-slim@sha256:fb22c1cef74071a6cd0145c1f91ca85ba9bd3f8b4d6db8560fe69eb36a175ca3
|
|
||||||
ADD . /
|
|
||||||
WORKDIR /opt/ltp
|
|
||||||
ENTRYPOINT ["/bin/sh", "/check.sh"]
|
|
@ -1,44 +1,15 @@
|
|||||||
LTP_VERSION=20170116
|
.PHONY: tag push
|
||||||
|
default: push
|
||||||
|
|
||||||
all: ltp.tar push
|
ORG?=linuxkit
|
||||||
|
|
||||||
# Build LTP and get the result as a tarball
|
|
||||||
DEPS=Dockerfile.build Makefile
|
|
||||||
ltp.tag: $(DEPS)
|
|
||||||
BUILD=$$(docker build -f $< -q . --build-arg LTP_VERSION=$(LTP_VERSION)) && [ -n "$$BUILD" ] && echo "Built $$BUILD" && echo "$$BUILD" > $@
|
|
||||||
|
|
||||||
ltp.tar: ltp.tag
|
|
||||||
docker run --rm --net=none --log-driver=none $(shell cat ltp.tag) tar cf - opt/ltp > $@
|
|
||||||
|
|
||||||
SHASUM=alpine:3.5
|
|
||||||
IMAGE=test-ltp
|
IMAGE=test-ltp
|
||||||
|
DEPS=Dockerfile Makefile check.sh
|
||||||
|
|
||||||
# Note: We do not compute the hash from all the dependencies here
|
HASH?=$(shell git ls-tree HEAD -- ../$(notdir $(CURDIR)) | awk '{print $$3}')
|
||||||
# because the ltp binaries will change everytime we build. Ideally, we
|
|
||||||
# would calculate the hash from the source and the apt-get cache, but
|
|
||||||
# it's not that critical.
|
|
||||||
hash: Dockerfile.pkg ltp.tar check.sh $(DEPS)
|
|
||||||
tar xf ltp.tar
|
|
||||||
tar cf - Dockerfile.pkg opt check.sh | docker build --no-cache -t $(IMAGE):build -f Dockerfile.pkg -
|
|
||||||
cat Dockerfile.pkg check.sh $(DEPS) | DOCKER_CONTENT_TRUST=1 docker run --rm -i $(SHASUM) sha1sum | sed 's/ .*//' > $@
|
|
||||||
|
|
||||||
push: hash
|
tag: $(DEPS)
|
||||||
DOCKER_CONTENT_TRUST=1 docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
docker build --no-cache -t $(ORG)/$(IMAGE):$(HASH) .
|
||||||
(docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash) && \
|
|
||||||
docker tag $(IMAGE):build linuxkit/$(IMAGE):$(LTP_VERSION) && \
|
|
||||||
DOCKER_CONTENT_TRUST=1 docker push linuxkit/$(IMAGE):$(shell cat hash) && \
|
|
||||||
DOCKER_CONTENT_TRUST=1 docker push linuxkit/$(IMAGE):$(LTP_VERSION))
|
|
||||||
docker rmi $(IMAGE):build
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
tag: hash
|
push: tag
|
||||||
docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
DOCKER_CONTENT_TRUST=1 docker pull $(ORG)/$(IMAGE):$(HASH) || \
|
||||||
docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash)
|
DOCKER_CONTENT_TRUST=1 docker push $(ORG)/$(IMAGE):$(HASH)
|
||||||
docker rmi $(IMAGE):build
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
.PHONY: clean
|
|
||||||
clean:
|
|
||||||
rm -rf opt ltp.tar ltp.tag hash
|
|
||||||
|
|
||||||
.DELETE_ON_ERROR:
|
|
||||||
|
@ -1,4 +1,12 @@
|
|||||||
FROM alpine:3.5
|
FROM linuxkit/alpine:451603daf499e3a40308dbf5571dcffed2343ffa AS mirror
|
||||||
ADD . ./
|
RUN mkdir -p /out/etc/apk && cp -r /etc/apk/* /out/etc/apk/
|
||||||
|
RUN apk add --no-cache --initdb -p /out alpine-baselayout busybox musl
|
||||||
|
RUN rm -rf /out/etc/apk /out/lib/apk /out/var/cache
|
||||||
|
|
||||||
|
FROM scratch
|
||||||
|
CMD []
|
||||||
|
WORKDIR /
|
||||||
|
COPY --from=mirror /out/ /
|
||||||
|
COPY /poweroff.sh /poweroff.sh
|
||||||
ENTRYPOINT ["/bin/sh", "/poweroff.sh"]
|
ENTRYPOINT ["/bin/sh", "/poweroff.sh"]
|
||||||
LABEL org.mobyproject.config='{"pid": "host", "readonly": true, "capabilities": ["CAP_SYS_BOOT"]}'
|
LABEL org.mobyproject.config='{"pid": "host", "readonly": true, "capabilities": ["CAP_SYS_BOOT"]}'
|
||||||
|
@ -1,29 +1,15 @@
|
|||||||
.PHONY: tag push
|
.PHONY: tag push
|
||||||
|
|
||||||
BASE=alpine:3.5
|
|
||||||
IMAGE=poweroff
|
|
||||||
|
|
||||||
default: push
|
default: push
|
||||||
|
|
||||||
hash: Dockerfile poweroff.sh
|
ORG?=linuxkit
|
||||||
DOCKER_CONTENT_TRUST=1 docker pull $(BASE)
|
IMAGE=poweroff
|
||||||
tar cf - $^ | docker build --no-cache -t $(IMAGE):build -
|
DEPS=Dockerfile Makefile poweroff.sh
|
||||||
docker run --rm --entrypoint=/bin/sh $(IMAGE):build -c "cat $^ /lib/apk/db/installed | sha1sum" | sed 's/ .*//' > hash
|
|
||||||
|
|
||||||
push: hash
|
HASH?=$(shell git ls-tree HEAD -- ../$(notdir $(CURDIR)) | awk '{print $$3}')
|
||||||
DOCKER_CONTENT_TRUST=1 docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
|
||||||
(docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash) && \
|
|
||||||
DOCKER_CONTENT_TRUST=1 docker push linuxkit/$(IMAGE):$(shell cat hash))
|
|
||||||
docker rmi $(IMAGE):build
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
tag: hash
|
tag: $(DEPS)
|
||||||
docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
docker build --no-cache --network=none -t $(ORG)/$(IMAGE):$(HASH) .
|
||||||
docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash)
|
|
||||||
docker rmi $(IMAGE):build
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
clean:
|
push: tag
|
||||||
rm -f hash
|
DOCKER_CONTENT_TRUST=1 docker pull $(ORG)/$(IMAGE):$(HASH) || \
|
||||||
|
DOCKER_CONTENT_TRUST=1 docker push $(ORG)/$(IMAGE):$(HASH)
|
||||||
.DELETE_ON_ERROR:
|
|
||||||
|
@ -24,6 +24,9 @@ RUN apk index --rewrite-arch $(uname -m) -o /mirror/$(uname -m)/APKINDEX.unsigne
|
|||||||
RUN cp /mirror/$(uname -m)/APKINDEX.unsigned.tar.gz /mirror/$(uname -m)/APKINDEX.tar.gz
|
RUN cp /mirror/$(uname -m)/APKINDEX.unsigned.tar.gz /mirror/$(uname -m)/APKINDEX.tar.gz
|
||||||
RUN abuild-sign /mirror/$(uname -m)/APKINDEX.tar.gz
|
RUN abuild-sign /mirror/$(uname -m)/APKINDEX.tar.gz
|
||||||
|
|
||||||
|
# fetch OVMF for qemu EFI boot (this is not added as a package)
|
||||||
|
RUN apk add -X http://dl-cdn.alpinelinux.org/alpine/edge/community ovmf
|
||||||
|
|
||||||
# set this as our repo
|
# set this as our repo
|
||||||
RUN echo "/mirror" > /etc/apk/repositories && apk update
|
RUN echo "/mirror" > /etc/apk/repositories && apk update
|
||||||
|
|
||||||
@ -44,6 +47,7 @@ COPY --from=mirror /etc/apk/repositories /etc/apk/repositories
|
|||||||
COPY --from=mirror /etc/apk/keys /etc/apk/keys/
|
COPY --from=mirror /etc/apk/keys /etc/apk/keys/
|
||||||
COPY --from=mirror /mirror /mirror/
|
COPY --from=mirror /mirror /mirror/
|
||||||
COPY --from=mirror /go/bin /go/bin/
|
COPY --from=mirror /go/bin /go/bin/
|
||||||
|
COPY --from=mirror /usr/share/ovmf/bios.bin /usr/share/ovmf/bios.bin
|
||||||
COPY --from=mirror /Dockerfile /Dockerfile
|
COPY --from=mirror /Dockerfile /Dockerfile
|
||||||
|
|
||||||
COPY --from=shellcheck /usr/local/bin/shellcheck /usr/local/bin/shellcheck
|
COPY --from=shellcheck /usr/local/bin/shellcheck /usr/local/bin/shellcheck
|
||||||
|
@ -1,10 +1,16 @@
|
|||||||
FROM alpine:3.5
|
FROM linuxkit/alpine:451603daf499e3a40308dbf5571dcffed2343ffa AS mirror
|
||||||
RUN apk update && apk add --no-cache build-base git go
|
RUN mkdir -p /out/etc/apk && cp -r /etc/apk/* /out/etc/apk/
|
||||||
|
RUN apk add --no-cache --initdb -p /out \
|
||||||
|
alpine-baselayout \
|
||||||
|
busybox \
|
||||||
|
git \
|
||||||
|
go \
|
||||||
|
musl-dev
|
||||||
|
RUN rm -rf /out/etc/apk /out/lib/apk /out/var/cache
|
||||||
|
|
||||||
|
FROM scratch
|
||||||
ENV GOPATH=/go PATH=$PATH:/go/bin
|
ENV GOPATH=/go PATH=$PATH:/go/bin
|
||||||
RUN go get -u github.com/golang/lint/golint && \
|
COPY --from=mirror /out/ /
|
||||||
go get -u github.com/gordonklaus/ineffassign && \
|
COPY --from=mirror /go/bin/ /go/bin/
|
||||||
go get -u github.com/LK4D4/vndr
|
COPY /compile.sh /compile.sh
|
||||||
|
|
||||||
COPY . ./
|
|
||||||
|
|
||||||
ENTRYPOINT ["/compile.sh"]
|
ENTRYPOINT ["/compile.sh"]
|
||||||
|
@ -1,41 +1,15 @@
|
|||||||
.PHONY: tag push
|
.PHONY: tag push
|
||||||
|
|
||||||
BASE=alpine:3.5
|
|
||||||
IMAGE=go-compile
|
|
||||||
|
|
||||||
default: push
|
default: push
|
||||||
|
|
||||||
hash: Dockerfile compile.sh
|
ORG?=linuxkit
|
||||||
DOCKER_CONTENT_TRUST=1 docker pull $(BASE)
|
IMAGE=go-compile
|
||||||
tar cf - $^ | docker build --no-cache -t $(IMAGE):build -
|
DEPS=Dockerfile Makefile compile.sh
|
||||||
docker run --rm --entrypoint=/bin/sh $(IMAGE):build -c "cat $^ /lib/apk/db/installed /go/bin/golint | sha1sum" | sed 's/ .*//' > hash
|
|
||||||
|
|
||||||
push: hash
|
HASH?=$(shell git ls-tree HEAD -- ../$(notdir $(CURDIR)) | awk '{print $$3}')
|
||||||
docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
|
||||||
(docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash) && \
|
|
||||||
docker push linuxkit/$(IMAGE):$(shell cat hash))
|
|
||||||
docker rmi $(IMAGE):build
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
tag: hash
|
tag: $(DEPS)
|
||||||
docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
docker build --no-cache --network=none -t $(ORG)/$(IMAGE):$(HASH) .
|
||||||
docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash)
|
|
||||||
docker rmi $(IMAGE):build
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
signed-tag: hash
|
push: tag
|
||||||
DOCKER_CONTENT_TRUST=1 docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
DOCKER_CONTENT_TRUST=1 docker pull $(ORG)/$(IMAGE):$(HASH) || \
|
||||||
(DOCKER_CONTENT_TRUST=1 docker pull $(BASE) && \
|
DOCKER_CONTENT_TRUST=1 docker push $(ORG)/$(IMAGE):$(HASH)
|
||||||
docker build --no-cache -t $(IMAGE):build . && \
|
|
||||||
docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash))
|
|
||||||
|
|
||||||
sign: signed-tag
|
|
||||||
DOCKER_CONTENT_TRUST=1 docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
|
||||||
DOCKER_CONTENT_TRUST=1 docker push linuxkit/$(IMAGE):$(shell cat hash)
|
|
||||||
rm -f hash
|
|
||||||
docker rmi $(IMAGE):build || true
|
|
||||||
|
|
||||||
clean:
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
.DELETE_ON_ERROR:
|
|
||||||
|
@ -1,15 +1,19 @@
|
|||||||
FROM alpine:edge
|
FROM linuxkit/alpine:5240cbd9cf371c8211c8f1968e57c51a32098c8f AS mirror
|
||||||
|
RUN mkdir -p /out/etc/apk && cp -r /etc/apk/* /out/etc/apk/
|
||||||
|
RUN apk add --no-cache --initdb -p /out \
|
||||||
|
alpine-baselayout \
|
||||||
|
busybox \
|
||||||
|
libarchive-tools \
|
||||||
|
qemu-img \
|
||||||
|
qemu-system-x86_64
|
||||||
|
|
||||||
COPY repositories /etc/apk/
|
RUN mkdir -p /out/usr/share/ovmf \
|
||||||
|
&& cp /usr/share/ovmf/bios.bin /out/usr/share/ovmf/bios.bin
|
||||||
|
RUN rm -rf /out/etc/apk /out/lib/apk /out/var/cache
|
||||||
|
|
||||||
RUN \
|
FROM scratch
|
||||||
apk update && apk upgrade && \
|
ENTRYPOINT []
|
||||||
apk add --no-cache \
|
CMD []
|
||||||
libarchive-tools \
|
WORKDIR /
|
||||||
qemu-img \
|
COPY --from=mirror /out/ /
|
||||||
qemu-system-arm \
|
|
||||||
qemu-system-x86_64 \
|
|
||||||
ovmf@testing \
|
|
||||||
&& true
|
|
||||||
|
|
||||||
COPY . .
|
|
||||||
|
@ -1,29 +1,15 @@
|
|||||||
.PHONY: tag push
|
.PHONY: tag push
|
||||||
|
|
||||||
BASE=alpine:3.5
|
|
||||||
IMAGE=qemu
|
|
||||||
|
|
||||||
default: push
|
default: push
|
||||||
|
|
||||||
hash: Dockerfile repositories
|
ORG?=linuxkit
|
||||||
DOCKER_CONTENT_TRUST=1 docker pull $(BASE)
|
IMAGE=qemu
|
||||||
tar cf - $^ | docker build --no-cache -t $(IMAGE):build -
|
DEPS=Dockerfile Makefile
|
||||||
docker run --rm --entrypoint /bin/sh $(IMAGE):build -c 'cat Dockerfile /lib/apk/db/installed | sha1sum' | sed 's/ .*//' > $@
|
|
||||||
|
|
||||||
push: hash
|
HASH?=$(shell git ls-tree HEAD -- ../$(notdir $(CURDIR)) | awk '{print $$3}')
|
||||||
docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
|
||||||
(docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash) && \
|
|
||||||
docker push linuxkit/$(IMAGE):$(shell cat hash))
|
|
||||||
docker rmi $(IMAGE):build
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
tag: hash
|
tag: $(DEPS)
|
||||||
docker pull linuxkit/$(IMAGE):$(shell cat hash) || \
|
DOCKER_CONTENT_TRUST=1 docker build --no-cache --network=none -t $(ORG)/$(IMAGE):$(HASH) .
|
||||||
docker tag $(IMAGE):build linuxkit/$(IMAGE):$(shell cat hash)
|
|
||||||
docker rmi $(IMAGE):build
|
|
||||||
rm -f hash
|
|
||||||
|
|
||||||
clean:
|
push: tag
|
||||||
rm -f hash
|
docker pull $(ORG)/$(IMAGE):$(HASH) || \
|
||||||
|
docker push $(ORG)/$(IMAGE):$(HASH)
|
||||||
.DELETE_ON_ERROR:
|
|
||||||
|
@ -1,2 +0,0 @@
|
|||||||
http://dl-cdn.alpinelinux.org/alpine/edge/main
|
|
||||||
@testing http://dl-cdn.alpinelinux.org/alpine/edge/testing
|
|
Loading…
Reference in New Issue
Block a user