Merge pull request #508 from LeastAuthority/circleci-slackware

Replace the magic-folder CircleCI job with a Slackware job

Supporting Slackware involves tweaking some of the test environment setup steps.  With luck, these are all general changes for the better.  Because supporting Ubuntu 14.04 and Slackware 14.2 at the same time is tricky, don't even try.  Instead, rely on a separate change to the BuildBot configuration to focus more on magic-folder testing.
This commit is contained in:
Jean-Paul Calderone 2018-07-05 12:10:33 -04:00 committed by GitHub
commit 5205dd3487
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 83 additions and 39 deletions

View File

@ -5,16 +5,28 @@ workflows:
version: 2 version: 2
ci: ci:
jobs: jobs:
- "lint" # Platforms
- "debian-8"
- "debian-9" - "debian-9"
- "ubuntu-16.04" - "debian-8":
requires:
- "debian-9"
- "ubuntu-18.04" - "ubuntu-18.04"
- "centos-7" - "ubuntu-16.04":
- "fedora-27" requires:
- "ubuntu-18.04"
- "fedora-28"
- "fedora-27":
requires:
- "fedora-28" - "fedora-28"
- "magic-folder-ubuntu-14.04" - "centos-7"
- "slackware-14.2"
# Other assorted tasks and configurations
- "lint"
- "deprecations" - "deprecations"
- "c-locale" - "c-locale"
@ -119,7 +131,6 @@ jobs:
LANG: "C" LANG: "C"
deprecations: deprecations:
<<: *DEBIAN <<: *DEBIAN
docker: docker:
@ -219,42 +230,68 @@ jobs:
- image: "fedora" - image: "fedora"
magic-folder-ubuntu-14.04: slackware-14.2:
machine: docker:
enabled: true - image: "vbatts/slackware:14.2"
image: "circleci/classic:201711-01"
environment: environment: *UTF_8_ENVIRONMENT
<<: *UTF_8_ENVIRONMENT
EXTRA_PACKAGES: "python-virtualenv"
TAHOE_LAFS_TOX_ARGS: "-- allmydata.test.test_magic_folder"
# Unfortunately, duplicate all the steps here but run with `sudo`.
steps: steps:
- run: - run:
node: "Install Git" node: "Install Git"
command: | command: |
sudo apt-get --quiet update slackpkg update
sudo apt-get --quiet --yes install git slackpkg install openssh-7.4p1 git-2.14.4 </dev/null
- "checkout" - "checkout"
- run: - run:
<<: *BOOTSTRAP_TEST_ENVIRONMENT name: "Bootstrap test environment"
working_directory: "/tmp"
command: | command: |
sudo ~/project/.circleci/bootstrap-test-environment.sh ~/project "${EXTRA_PACKAGES}" # Avoid the /nonexistent home directory in nobody's /etc/passwd
# entry.
usermod --home /tmp/nobody nobody
- run: # Grant read access to nobody, the user which will eventually try
<<: *SETUP_VIRTUALENV # to test this checkout.
command: | mv /root/project /tmp/project
env
sudo /tmp/project/.circleci/setup-virtualenv.sh "${TAHOE_LAFS_TOX_ENVIRONMENT}" "${TAHOE_LAFS_TOX_ARGS}"
- run: # Python build/install toolchain wants to write to the source
<<: *RUN_TESTS # checkout, too.
command: | chown --recursive nobody:nobody /tmp/project
env
sudo /tmp/project/.circleci/run-tests.sh "${TAHOE_LAFS_TOX_ENVIRONMENT}" "${TAHOE_LAFS_TOX_ARGS}" slackpkg install \
sudo-1.8.20p2 \
make-4.1 \
automake-1.15 \
kernel-headers \
glibc-2.23 \
binutils-2.26 \
gcc-5.5.0 \
gcc-g++-5.5.0 \
python-2.7.15 \
libffi-3.2.1 \
libyaml-0.1.6 \
sqlite-3.13.0 \
icu4c-56.1 \
libmpc-1.0.3 </dev/null
slackpkg upgrade \
openssl-1.0 </dev/null
# neither virtualenv nor pip is packaged.
# do it the hard way.
# and it is extra hard since it is slackware.
slackpkg install \
cyrus-sasl-2.1.26 \
curl-7.60 </dev/null
curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py
python get-pip.py
pip install virtualenv
- run: *SETUP_VIRTUALENV
- run: *RUN_TESTS
- store_artifacts: *STORE_TEST_LOG - store_artifacts: *STORE_TEST_LOG
- store_artifacts: *STORE_OTHER_ARTIFACTS - store_artifacts: *STORE_OTHER_ARTIFACTS

View File

@ -9,6 +9,12 @@ shift || :
# Set up the virtualenv as a non-root user so we can run the test suite as a # Set up the virtualenv as a non-root user so we can run the test suite as a
# non-root user. See below. # non-root user. See below.
sudo --set-home -u nobody virtualenv --python python2.7 /tmp/tests sudo --set-home -u nobody virtualenv --python python2.7 /tmp/tests
# Slackware has non-working SSL support in setuptools until certifi is
# installed. SSL support in setuptools is needed in case packages use
# `setup_requires` which gets satisfied by setuptools instead of by pip.
# txi2p (vcversioner) is one such package. Twisted (incremental) is another.
sudo --set-home -u nobody /tmp/tests/bin/pip install tox codecov sudo --set-home -u nobody /tmp/tests/bin/pip install tox codecov
# Get everything installed in it, too.
# Get everything else installed in it, too.
sudo --set-home -u nobody /tmp/tests/bin/tox -c /tmp/project/tox.ini --workdir /tmp --notest -e "${TAHOE_LAFS_TOX_ENVIRONMENT}" ${TAHOE_LAFS_TOX_ARGS} sudo --set-home -u nobody /tmp/tests/bin/tox -c /tmp/project/tox.ini --workdir /tmp --notest -e "${TAHOE_LAFS_TOX_ENVIRONMENT}" ${TAHOE_LAFS_TOX_ARGS}

13
tox.ini
View File

@ -14,12 +14,13 @@ skipsdist = True
[testenv] [testenv]
basepython=python2.7 basepython=python2.7
passenv = TAHOE_LAFS_* USERPROFILE HOMEDRIVE HOMEPATH passenv = TAHOE_LAFS_* USERPROFILE HOMEDRIVE HOMEPATH
# Pre-install "incremental" to avoid bug #2913. Basically if Twisted's # Get "certifi" to avoid bug #2913. Basically if a `setup_requires=...` causes
# setup_requires=["incremental"] causes this to be installed (with # a package to be installed (with setuptools) then it'll fail on certain
# setuptools), then it'll fail on travis's OS-X 10.12 machines when PyPI # platforms (travis's OX-X 10.12, Slackware 14.2) because PyPI's TLS
# disables access with TLS-1.1 or older, so we have to install it ahead of # requirements (TLS >= 1.2) are incompatible with the old TLS clients
# time (with pip). # available to those systems. Installing it ahead of time (with pip) avoids
deps = incremental # this problem.
deps = certifi
# We add usedevelop=True for speed, and extras=test to get things like "mock" # We add usedevelop=True for speed, and extras=test to get things like "mock"
# that are required for our unit tests. # that are required for our unit tests.
usedevelop = True usedevelop = True