Skip to content

Commit 4fac70c

Browse files
Merge pull request #1135 from PeterDaveHello/Node.js_v13
Add node.js v13.0.0 with Yarn v1.19.1
2 parents 1145838 + f6f0701 commit 4fac70c

13 files changed

Lines changed: 434 additions & 1 deletion

.travis.yml

Lines changed: 35 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -191,6 +191,41 @@ jobs:
191191
- NODE_VERSION="12"
192192
- VARIANT="buster-slim"
193193

194+
- stage: Build
195+
before_script: *auto_skip
196+
name: 13 on alpine
197+
env:
198+
- NODE_VERSION="13"
199+
- VARIANT="alpine"
200+
201+
- stage: Build
202+
before_script: *auto_skip
203+
name: 13 on stretch
204+
env:
205+
- NODE_VERSION="13"
206+
- VARIANT="stretch"
207+
208+
- stage: Build
209+
before_script: *auto_skip
210+
name: 13 on stretch-slim
211+
env:
212+
- NODE_VERSION="13"
213+
- VARIANT="stretch-slim"
214+
215+
- stage: Build
216+
before_script: *auto_skip
217+
name: 13 on buster
218+
env:
219+
- NODE_VERSION="13"
220+
- VARIANT="buster"
221+
222+
- stage: Build
223+
before_script: *auto_skip
224+
name: 13 on buster-slim
225+
env:
226+
- NODE_VERSION="13"
227+
- VARIANT="buster-slim"
228+
194229
- stage: Build
195230
before_script: *auto_skip
196231
name: 8 on jessie

13/alpine/Dockerfile

Lines changed: 74 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,74 @@
1+
FROM alpine:3.10
2+
3+
ENV NODE_VERSION 13.0.0
4+
5+
RUN addgroup -g 1000 node \
6+
&& adduser -u 1000 -G node -s /bin/sh -D node \
7+
&& apk add --no-cache \
8+
libstdc++ \
9+
&& apk add --no-cache --virtual .build-deps \
10+
binutils-gold \
11+
curl \
12+
g++ \
13+
gcc \
14+
gnupg \
15+
libgcc \
16+
linux-headers \
17+
make \
18+
python \
19+
# gpg keys listed at https://github.com/nodejs/node#release-keys
20+
&& for key in \
21+
94AE36675C464D64BAFA68DD7434390BDBE9B9C5 \
22+
FD3A5288F042B6850C66B31F09FE44734EB7990E \
23+
71DCFD284A79C3B38668286BC97EC7A07EDE3FC1 \
24+
DD8F2338BAE7501E3DD5AC78C273792F7D83545D \
25+
C4F0DFFF4E8C1A8236409D08E73BC641CC11F4C8 \
26+
B9AE9905FFD7803F25714661B63B535A4C206CA9 \
27+
77984A986EBC2AA786BC0F66B01FBB92821C587A \
28+
8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 \
29+
4ED778F539E3634C779C87C6D7062848A1AB005C \
30+
A48C2BEE680E841632CD4E44F07496B3EB3C1762 \
31+
B9E2F5981AA6E0CD28160D9FF13993A75599653C \
32+
; do \
33+
gpg --batch --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" || \
34+
gpg --batch --keyserver hkp://ipv4.pool.sks-keyservers.net --recv-keys "$key" || \
35+
gpg --batch --keyserver hkp://pgp.mit.edu:80 --recv-keys "$key" ; \
36+
done \
37+
&& curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION.tar.xz" \
38+
&& curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" \
39+
&& gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc \
40+
&& grep " node-v$NODE_VERSION.tar.xz\$" SHASUMS256.txt | sha256sum -c - \
41+
&& tar -xf "node-v$NODE_VERSION.tar.xz" \
42+
&& cd "node-v$NODE_VERSION" \
43+
&& ./configure \
44+
&& make -j$(getconf _NPROCESSORS_ONLN) V= \
45+
&& make install \
46+
&& apk del .build-deps \
47+
&& cd .. \
48+
&& rm -Rf "node-v$NODE_VERSION" \
49+
&& rm "node-v$NODE_VERSION.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt
50+
51+
ENV YARN_VERSION 1.19.1
52+
53+
RUN apk add --no-cache --virtual .build-deps-yarn curl gnupg tar \
54+
&& for key in \
55+
6A010C5166006599AA17F08146C2130DFD2497F5 \
56+
; do \
57+
gpg --batch --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" || \
58+
gpg --batch --keyserver hkp://ipv4.pool.sks-keyservers.net --recv-keys "$key" || \
59+
gpg --batch --keyserver hkp://pgp.mit.edu:80 --recv-keys "$key" ; \
60+
done \
61+
&& curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" \
62+
&& curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" \
63+
&& gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \
64+
&& mkdir -p /opt \
65+
&& tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ \
66+
&& ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn \
67+
&& ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg \
68+
&& rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \
69+
&& apk del .build-deps-yarn
70+
71+
COPY docker-entrypoint.sh /usr/local/bin/
72+
ENTRYPOINT ["docker-entrypoint.sh"]
73+
74+
CMD [ "node" ]

13/alpine/docker-entrypoint.sh

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
#!/bin/sh
2+
set -e
3+
4+
if [ "${1#-}" != "${1}" ] || [ -z "$(command -v "${1}")" ]; then
5+
set -- node "$@"
6+
fi
7+
8+
exec "$@"

13/architectures

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
bashbrew-arch variants
2+
amd64 alpine,stretch,stretch-slim,buster,buster-slim
3+
arm32v6 alpine
4+
arm32v7 alpine,stretch,stretch-slim,buster,buster-slim
5+
arm64v8 alpine,stretch,stretch-slim,buster,buster-slim
6+
i386 alpine
7+
ppc64le alpine,stretch,stretch-slim,buster,buster-slim
8+
s390x alpine,stretch,stretch-slim,buster,buster-slim

13/buster-slim/Dockerfile

Lines changed: 70 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
FROM debian:buster-slim
2+
3+
RUN groupadd --gid 1000 node \
4+
&& useradd --uid 1000 --gid node --shell /bin/bash --create-home node
5+
6+
ENV NODE_VERSION 13.0.0
7+
8+
RUN buildDeps='xz-utils' \
9+
&& ARCH= && dpkgArch="$(dpkg --print-architecture)" \
10+
&& case "${dpkgArch##*-}" in \
11+
amd64) ARCH='x64';; \
12+
ppc64el) ARCH='ppc64le';; \
13+
s390x) ARCH='s390x';; \
14+
arm64) ARCH='arm64';; \
15+
armhf) ARCH='armv7l';; \
16+
i386) ARCH='x86';; \
17+
*) echo "unsupported architecture"; exit 1 ;; \
18+
esac \
19+
&& set -ex \
20+
&& apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr $buildDeps --no-install-recommends \
21+
&& rm -rf /var/lib/apt/lists/* \
22+
&& for key in \
23+
94AE36675C464D64BAFA68DD7434390BDBE9B9C5 \
24+
FD3A5288F042B6850C66B31F09FE44734EB7990E \
25+
71DCFD284A79C3B38668286BC97EC7A07EDE3FC1 \
26+
DD8F2338BAE7501E3DD5AC78C273792F7D83545D \
27+
C4F0DFFF4E8C1A8236409D08E73BC641CC11F4C8 \
28+
B9AE9905FFD7803F25714661B63B535A4C206CA9 \
29+
77984A986EBC2AA786BC0F66B01FBB92821C587A \
30+
8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 \
31+
4ED778F539E3634C779C87C6D7062848A1AB005C \
32+
A48C2BEE680E841632CD4E44F07496B3EB3C1762 \
33+
B9E2F5981AA6E0CD28160D9FF13993A75599653C \
34+
; do \
35+
gpg --batch --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" || \
36+
gpg --batch --keyserver hkp://ipv4.pool.sks-keyservers.net --recv-keys "$key" || \
37+
gpg --batch --keyserver hkp://pgp.mit.edu:80 --recv-keys "$key" ; \
38+
done \
39+
&& curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-$ARCH.tar.xz" \
40+
&& curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" \
41+
&& gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc \
42+
&& grep " node-v$NODE_VERSION-linux-$ARCH.tar.xz\$" SHASUMS256.txt | sha256sum -c - \
43+
&& tar -xJf "node-v$NODE_VERSION-linux-$ARCH.tar.xz" -C /usr/local --strip-components=1 --no-same-owner \
44+
&& rm "node-v$NODE_VERSION-linux-$ARCH.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt \
45+
&& apt-get purge -y --auto-remove $buildDeps \
46+
&& ln -s /usr/local/bin/node /usr/local/bin/nodejs
47+
48+
ENV YARN_VERSION 1.19.1
49+
50+
RUN set -ex \
51+
&& for key in \
52+
6A010C5166006599AA17F08146C2130DFD2497F5 \
53+
; do \
54+
gpg --batch --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" || \
55+
gpg --batch --keyserver hkp://ipv4.pool.sks-keyservers.net --recv-keys "$key" || \
56+
gpg --batch --keyserver hkp://pgp.mit.edu:80 --recv-keys "$key" ; \
57+
done \
58+
&& curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" \
59+
&& curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" \
60+
&& gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \
61+
&& mkdir -p /opt \
62+
&& tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ \
63+
&& ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn \
64+
&& ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg \
65+
&& rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz
66+
67+
COPY docker-entrypoint.sh /usr/local/bin/
68+
ENTRYPOINT ["docker-entrypoint.sh"]
69+
70+
CMD [ "node" ]
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
#!/bin/sh
2+
set -e
3+
4+
if [ "${1#-}" != "${1}" ] || [ -z "$(command -v "${1}")" ]; then
5+
set -- node "$@"
6+
fi
7+
8+
exec "$@"

13/buster/Dockerfile

Lines changed: 67 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,67 @@
1+
FROM buildpack-deps:buster
2+
3+
RUN groupadd --gid 1000 node \
4+
&& useradd --uid 1000 --gid node --shell /bin/bash --create-home node
5+
6+
ENV NODE_VERSION 13.0.0
7+
8+
RUN ARCH= && dpkgArch="$(dpkg --print-architecture)" \
9+
&& case "${dpkgArch##*-}" in \
10+
amd64) ARCH='x64';; \
11+
ppc64el) ARCH='ppc64le';; \
12+
s390x) ARCH='s390x';; \
13+
arm64) ARCH='arm64';; \
14+
armhf) ARCH='armv7l';; \
15+
i386) ARCH='x86';; \
16+
*) echo "unsupported architecture"; exit 1 ;; \
17+
esac \
18+
# gpg keys listed at https://github.com/nodejs/node#release-keys
19+
&& set -ex \
20+
&& for key in \
21+
94AE36675C464D64BAFA68DD7434390BDBE9B9C5 \
22+
FD3A5288F042B6850C66B31F09FE44734EB7990E \
23+
71DCFD284A79C3B38668286BC97EC7A07EDE3FC1 \
24+
DD8F2338BAE7501E3DD5AC78C273792F7D83545D \
25+
C4F0DFFF4E8C1A8236409D08E73BC641CC11F4C8 \
26+
B9AE9905FFD7803F25714661B63B535A4C206CA9 \
27+
77984A986EBC2AA786BC0F66B01FBB92821C587A \
28+
8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 \
29+
4ED778F539E3634C779C87C6D7062848A1AB005C \
30+
A48C2BEE680E841632CD4E44F07496B3EB3C1762 \
31+
B9E2F5981AA6E0CD28160D9FF13993A75599653C \
32+
; do \
33+
gpg --batch --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" || \
34+
gpg --batch --keyserver hkp://ipv4.pool.sks-keyservers.net --recv-keys "$key" || \
35+
gpg --batch --keyserver hkp://pgp.mit.edu:80 --recv-keys "$key" ; \
36+
done \
37+
&& curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-$ARCH.tar.xz" \
38+
&& curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" \
39+
&& gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc \
40+
&& grep " node-v$NODE_VERSION-linux-$ARCH.tar.xz\$" SHASUMS256.txt | sha256sum -c - \
41+
&& tar -xJf "node-v$NODE_VERSION-linux-$ARCH.tar.xz" -C /usr/local --strip-components=1 --no-same-owner \
42+
&& rm "node-v$NODE_VERSION-linux-$ARCH.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt \
43+
&& ln -s /usr/local/bin/node /usr/local/bin/nodejs
44+
45+
ENV YARN_VERSION 1.19.1
46+
47+
RUN set -ex \
48+
&& for key in \
49+
6A010C5166006599AA17F08146C2130DFD2497F5 \
50+
; do \
51+
gpg --batch --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" || \
52+
gpg --batch --keyserver hkp://ipv4.pool.sks-keyservers.net --recv-keys "$key" || \
53+
gpg --batch --keyserver hkp://pgp.mit.edu:80 --recv-keys "$key" ; \
54+
done \
55+
&& curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" \
56+
&& curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" \
57+
&& gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \
58+
&& mkdir -p /opt \
59+
&& tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ \
60+
&& ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn \
61+
&& ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg \
62+
&& rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz
63+
64+
COPY docker-entrypoint.sh /usr/local/bin/
65+
ENTRYPOINT ["docker-entrypoint.sh"]
66+
67+
CMD [ "node" ]

13/buster/docker-entrypoint.sh

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
#!/bin/sh
2+
set -e
3+
4+
if [ "${1#-}" != "${1}" ] || [ -z "$(command -v "${1}")" ]; then
5+
set -- node "$@"
6+
fi
7+
8+
exec "$@"

13/stretch-slim/Dockerfile

Lines changed: 70 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
FROM debian:stretch-slim
2+
3+
RUN groupadd --gid 1000 node \
4+
&& useradd --uid 1000 --gid node --shell /bin/bash --create-home node
5+
6+
ENV NODE_VERSION 13.0.0
7+
8+
RUN buildDeps='xz-utils' \
9+
&& ARCH= && dpkgArch="$(dpkg --print-architecture)" \
10+
&& case "${dpkgArch##*-}" in \
11+
amd64) ARCH='x64';; \
12+
ppc64el) ARCH='ppc64le';; \
13+
s390x) ARCH='s390x';; \
14+
arm64) ARCH='arm64';; \
15+
armhf) ARCH='armv7l';; \
16+
i386) ARCH='x86';; \
17+
*) echo "unsupported architecture"; exit 1 ;; \
18+
esac \
19+
&& set -ex \
20+
&& apt-get update && apt-get install -y ca-certificates curl wget gnupg dirmngr $buildDeps --no-install-recommends \
21+
&& rm -rf /var/lib/apt/lists/* \
22+
&& for key in \
23+
94AE36675C464D64BAFA68DD7434390BDBE9B9C5 \
24+
FD3A5288F042B6850C66B31F09FE44734EB7990E \
25+
71DCFD284A79C3B38668286BC97EC7A07EDE3FC1 \
26+
DD8F2338BAE7501E3DD5AC78C273792F7D83545D \
27+
C4F0DFFF4E8C1A8236409D08E73BC641CC11F4C8 \
28+
B9AE9905FFD7803F25714661B63B535A4C206CA9 \
29+
77984A986EBC2AA786BC0F66B01FBB92821C587A \
30+
8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 \
31+
4ED778F539E3634C779C87C6D7062848A1AB005C \
32+
A48C2BEE680E841632CD4E44F07496B3EB3C1762 \
33+
B9E2F5981AA6E0CD28160D9FF13993A75599653C \
34+
; do \
35+
gpg --batch --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" || \
36+
gpg --batch --keyserver hkp://ipv4.pool.sks-keyservers.net --recv-keys "$key" || \
37+
gpg --batch --keyserver hkp://pgp.mit.edu:80 --recv-keys "$key" ; \
38+
done \
39+
&& curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-$ARCH.tar.xz" \
40+
&& curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" \
41+
&& gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc \
42+
&& grep " node-v$NODE_VERSION-linux-$ARCH.tar.xz\$" SHASUMS256.txt | sha256sum -c - \
43+
&& tar -xJf "node-v$NODE_VERSION-linux-$ARCH.tar.xz" -C /usr/local --strip-components=1 --no-same-owner \
44+
&& rm "node-v$NODE_VERSION-linux-$ARCH.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt \
45+
&& apt-get purge -y --auto-remove $buildDeps \
46+
&& ln -s /usr/local/bin/node /usr/local/bin/nodejs
47+
48+
ENV YARN_VERSION 1.19.1
49+
50+
RUN set -ex \
51+
&& for key in \
52+
6A010C5166006599AA17F08146C2130DFD2497F5 \
53+
; do \
54+
gpg --batch --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" || \
55+
gpg --batch --keyserver hkp://ipv4.pool.sks-keyservers.net --recv-keys "$key" || \
56+
gpg --batch --keyserver hkp://pgp.mit.edu:80 --recv-keys "$key" ; \
57+
done \
58+
&& curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" \
59+
&& curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" \
60+
&& gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \
61+
&& mkdir -p /opt \
62+
&& tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ \
63+
&& ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn \
64+
&& ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg \
65+
&& rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz
66+
67+
COPY docker-entrypoint.sh /usr/local/bin/
68+
ENTRYPOINT ["docker-entrypoint.sh"]
69+
70+
CMD [ "node" ]
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
#!/bin/sh
2+
set -e
3+
4+
if [ "${1#-}" != "${1}" ] || [ -z "$(command -v "${1}")" ]; then
5+
set -- node "$@"
6+
fi
7+
8+
exec "$@"

0 commit comments

Comments
 (0)