Extract worker setup into own shell script, as much as possible
This also changes DJANGO_REQUIREMENT to be a single file arg.
This commit is contained in:
@@ -12,13 +12,13 @@ python scripts/xdist/pytest_worker_manager.py -a up -n ${XDIST_NUM_WORKERS} \
|
||||
|
||||
# Install the correct version of Django depending on which tox environment (if any) is in use
|
||||
if [[ -z ${TOXENV+x} ]] || [[ ${TOXENV} == 'null' ]]; then
|
||||
DJANGO_REQUIREMENT="-r requirements/edx/django.txt"
|
||||
DJANGO_REQUIREMENT="requirements/edx/django.txt"
|
||||
elif [[ ${TOXENV} == *'django20'* ]]; then
|
||||
DJANGO_REQUIREMENT="-r requirements/edx/django20.txt"
|
||||
DJANGO_REQUIREMENT="requirements/edx/django20.txt"
|
||||
elif [[ ${TOXENV} == *'django21'* ]]; then
|
||||
DJANGO_REQUIREMENT="-r requirements/edx/django21.txt"
|
||||
DJANGO_REQUIREMENT="requirements/edx/django21.txt"
|
||||
elif [[ ${TOXENV} == *'django22'* ]]; then
|
||||
DJANGO_REQUIREMENT="-r requirements/edx/django.txt"
|
||||
DJANGO_REQUIREMENT="requirements/edx/django.txt"
|
||||
fi
|
||||
|
||||
ip_list=$(<pytest_worker_ips.txt)
|
||||
@@ -27,10 +27,7 @@ do
|
||||
worker_reqs_cmd="ssh -o StrictHostKeyChecking=no jenkins@$ip
|
||||
'git clone --branch master --depth 1 -q https://github.com/edx/edx-platform.git; cd edx-platform;
|
||||
git fetch -fq origin ${XDIST_GIT_REFSPEC}; git checkout -q ${XDIST_GIT_BRANCH};
|
||||
rm -rf /home/jenkins/edx-venv-${PYTHON_VERSION}/edx-venv;
|
||||
tar -C /home/jenkins/edx-venv-${PYTHON_VERSION} -xf /home/jenkins/edx-venv_clean-${PYTHON_VERSION}.tar.gz;
|
||||
source ../edx-venv-${PYTHON_VERSION}/edx-venv/bin/activate;
|
||||
pip install -q ${DJANGO_REQUIREMENT} -r requirements/edx/testing.txt; mkdir reports' & "
|
||||
scripts/xdist/setup_worker.sh -p $PYTHON_VERSION -d $DJANGO_REQUIREMENT' & "
|
||||
|
||||
cmd=$cmd$worker_reqs_cmd
|
||||
done
|
||||
|
||||
23
scripts/xdist/setup_worker.sh
Executable file
23
scripts/xdist/setup_worker.sh
Executable file
@@ -0,0 +1,23 @@
|
||||
#!/usr/bin/env bash
|
||||
# Set up worker node.
|
||||
|
||||
while getopts 'p:d:' opt; do
|
||||
case "$opt" in
|
||||
p) PYTHON_VERSION="$OPTARG";;
|
||||
d) DJANGO_REQUIREMENT="$OPTARG";;
|
||||
[?])
|
||||
print >&2 "Usage: $0 -p python-version -d django-reqs-file"
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
venv_parent=/home/jenkins/edx-venv-${PYTHON_VERSION}
|
||||
venv=$venv_parent/edx-venv
|
||||
rm -rf $venv
|
||||
tar -C $venv_parent -xf /home/jenkins/edx-venv_clean-${PYTHON_VERSION}.tar.gz
|
||||
source $venv/bin/activate
|
||||
|
||||
pip install -q -r ${DJANGO_REQUIREMENT} -r requirements/edx/testing.txt
|
||||
|
||||
mkdir reports
|
||||
Reference in New Issue
Block a user