From e2b66a1f6b32c5a0aa323bd8306d72337c38dd57 Mon Sep 17 00:00:00 2001 From: David Manthey Date: Fri, 5 May 2023 10:10:15 -0400 Subject: [PATCH] Make it easier to switch node versions in the test docker. --- .circleci/config.yml | 4 ++-- test.Dockerfile | 25 ++++++++++++++++++------- 2 files changed, 20 insertions(+), 9 deletions(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index d9079bcb7..ef527322a 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -177,7 +177,7 @@ jobs: steps: - checkout - allservices: - version: 3.10.10 + version: 3.10.11 node: v12 - tox: env: test-py310 @@ -190,7 +190,7 @@ jobs: steps: - checkout - allservices: - version: 3.11.2 + version: 3.11.3 node: v12 - tox: env: test-py311 diff --git a/test.Dockerfile b/test.Dockerfile index da44b8129..87d1bf407 100644 --- a/test.Dockerfile +++ b/test.Dockerfile @@ -13,7 +13,7 @@ ENV DEBIAN_FRONTEND=noninteractive \ LANG=en_US.UTF-8 \ PYENV_ROOT="/.pyenv" \ PATH="/.pyenv/bin:/.pyenv/shims:$PATH" \ - PYTHON_VERSIONS="3.9.16 3.8.16 3.7.16 3.6.15 3.10.10 3.11.2" + PYTHON_VERSIONS="3.9.16 3.8.16 3.7.16 3.6.15 3.10.11 3.11.3" RUN apt-get update && \ apt-get install -y --no-install-recommends \ @@ -95,7 +95,7 @@ RUN pyenv update && \ find / -xdev -name __pycache__ -type d -exec rm -r {} \+ && \ rm -rf /tmp/* /var/tmp/* && \ # This makes duplicate python library files hardlinks of each other \ - rdfind -minsize 1048576 -makehardlinks true -makeresultsfile false /.pyenv + rdfind -minsize 524288 -makehardlinks true -makeresultsfile false /.pyenv RUN for ver in $PYTHON_VERSIONS; do \ pyenv local $ver && \ @@ -105,11 +105,22 @@ RUN for ver in $PYTHON_VERSIONS; do \ done && \ pyenv rehash && \ find / -xdev -name __pycache__ -type d -exec rm -r {} \+ && \ - rm -rf /tmp/* /var/tmp/* + rm -rf /tmp/* /var/tmp/* && \ + rdfind -minsize 524288 -makehardlinks true -makeresultsfile false /.pyenv -RUN curl -sL https://deb.nodesource.com/setup_12.x | bash - && \ - apt-get install -y nodejs && \ - find / -xdev -name __pycache__ -type d -exec rm -r {} \+ && \ - apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* +# Use nvm to install node +RUN curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash + +# Default node version +RUN . ~/.bashrc && \ + nvm install 12 && \ + nvm alias default 12 && \ + nvm use default && \ + rm /usr/local/bin/node || true && \ + rm /usr/local/bin/npm || true && \ + rm /usr/local/bin/npx || true && \ + ln -s `which node` /usr/local/bin/. && \ + ln -s `which npm` /usr/local/bin/. && \ + ln -s `which npx` /usr/local/bin/. WORKDIR /app