Merge pull request #41 from matelakat/separate-test-runner
Extract run_tests.sh script
This commit is contained in:
commit
c9a7329aa9
110
launch-node.sh
110
launch-node.sh
@ -9,6 +9,7 @@ IMAGE="node"
|
||||
INSTANCE_NAME="$3"
|
||||
FLAVOR="$4"
|
||||
APPLIANCE_NAME="Devstack"
|
||||
RUN_TESTS_SCRIPT="$THISDIR/run_tests.sh"
|
||||
|
||||
. $THISDIR/functions
|
||||
|
||||
@ -34,114 +35,7 @@ ssh-add $KEY_PATH
|
||||
|
||||
set +x
|
||||
|
||||
SSH_DOM0="sudo -u domzero ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null root@192.168.33.2"
|
||||
FEED_WITH_NOTHING="< /dev/null"
|
||||
|
||||
{
|
||||
cat << EOF
|
||||
set -eux
|
||||
# Get some parameters
|
||||
APP=\$($SSH_DOM0 xe vm-list name-label=$APPLIANCE_NAME --minimal $FEED_WITH_NOTHING)
|
||||
|
||||
# Create a vm network
|
||||
VMNET=\$($SSH_DOM0 xe network-create name-label=vmnet $FEED_WITH_NOTHING)
|
||||
VMVIF=\$($SSH_DOM0 xe vif-create vm-uuid=\$APP network-uuid=\$VMNET device=3 $FEED_WITH_NOTHING)
|
||||
$SSH_DOM0 xe vif-plug uuid=\$VMVIF $FEED_WITH_NOTHING
|
||||
|
||||
# Create pub network
|
||||
PUBNET=\$($SSH_DOM0 xe network-create name-label=pubnet $FEED_WITH_NOTHING)
|
||||
PUBVIF=\$($SSH_DOM0 xe vif-create vm-uuid=\$APP network-uuid=\$PUBNET device=4 $FEED_WITH_NOTHING)
|
||||
$SSH_DOM0 xe vif-plug uuid=\$PUBVIF $FEED_WITH_NOTHING
|
||||
|
||||
# Hack iSCSI SR
|
||||
$SSH_DOM0 << SRHACK
|
||||
set -eux
|
||||
sed -ie "s/'phy'/'aio'/g" /opt/xensource/sm/ISCSISR.py
|
||||
SRHACK
|
||||
|
||||
# This is important, otherwise dhcp client will fail
|
||||
for dev in eth0 eth1 eth2 eth3 eth4; do
|
||||
sudo ethtool -K \$dev tx off
|
||||
done
|
||||
|
||||
# Add a separate disk
|
||||
SR=\$($SSH_DOM0 xe sr-list type=ext --minimal $FEED_WITH_NOTHING)
|
||||
VDI=\$($SSH_DOM0 xe vdi-create name-label=disk-for-volumes virtual-size=10GiB sr-uuid=\$SR type=user $FEED_WITH_NOTHING)
|
||||
VBD=\$($SSH_DOM0 xe vbd-create vm-uuid=\$APP vdi-uuid=\$VDI device=1 $FEED_WITH_NOTHING)
|
||||
$SSH_DOM0 xe vbd-plug uuid=\$VBD $FEED_WITH_NOTHING
|
||||
|
||||
# For development:
|
||||
export SKIP_DEVSTACK_GATE_PROJECT=1
|
||||
|
||||
sudo pip install -i https://pypi.python.org/simple/ XenAPI
|
||||
|
||||
# These came from the Readme
|
||||
export REPO_URL=https://review.openstack.org/p
|
||||
export ZUUL_URL=/home/jenkins/workspace-cache
|
||||
export ZUUL_REF=HEAD
|
||||
export WORKSPACE=/home/jenkins/workspace/testing
|
||||
|
||||
# Check out a custom branch
|
||||
(
|
||||
cd workspace-cache/devstack-gate/
|
||||
git remote add mate https://github.com/matelakat/devstack-gate
|
||||
git fetch mate
|
||||
git checkout xenserver-integration
|
||||
)
|
||||
mkdir -p \$WORKSPACE
|
||||
|
||||
export ZUUL_PROJECT=openstack/nova
|
||||
export ZUUL_BRANCH=master
|
||||
|
||||
git clone \$REPO_URL/\$ZUUL_PROJECT \$ZUUL_URL/\$ZUUL_PROJECT
|
||||
cd \$ZUUL_URL/\$ZUUL_PROJECT
|
||||
git checkout remotes/origin/\$ZUUL_BRANCH
|
||||
|
||||
# Plugins
|
||||
tar -czf - -C /home/jenkins/workspace-cache/nova/plugins/xenserver/xenapi/etc/xapi.d/plugins/ ./ |
|
||||
$SSH_DOM0 \
|
||||
'tar -xzf - -C /etc/xapi.d/plugins/ && chmod a+x /etc/xapi.d/plugins/*'
|
||||
|
||||
# Console log
|
||||
tar -czf - -C /home/jenkins/workspace-cache/nova/tools/xenserver/ rotate_xen_guest_logs.sh |
|
||||
$SSH_DOM0 \
|
||||
'tar -xzf - -C /root/ && chmod +x /root/rotate_xen_guest_logs.sh && mkdir -p /var/log/xen/guest'
|
||||
$SSH_DOM0 crontab - << CRONTAB
|
||||
* * * * * /root/rotate_xen_guest_logs.sh
|
||||
CRONTAB
|
||||
|
||||
# Insert a rule as the first position - allow all traffic on the mgmt interface
|
||||
# Other rules are inserted by config/modules/iptables/templates/rules.erb
|
||||
sudo iptables -I INPUT 1 -i eth2 -s 192.168.33.0/24 -j ACCEPT
|
||||
|
||||
(
|
||||
cd /home/jenkins/workspace-cache/devstack
|
||||
{
|
||||
echo "set -eux"
|
||||
cat tools/xen/functions
|
||||
echo "create_directory_for_images"
|
||||
echo "create_directory_for_kernels"
|
||||
} | $SSH_DOM0
|
||||
)
|
||||
|
||||
cd \$WORKSPACE
|
||||
git clone https://github.com/matelakat/devstack-gate -b xenserver-integration
|
||||
|
||||
#( sudo mkdir -p /opt/stack/new && sudo chown -R jenkins:jenkins /opt/stack/new && cd /opt/stack/new && git clone https://github.com/matelakat/devstack-gate -b xenserver-integration )
|
||||
|
||||
# Values from the job template
|
||||
export PYTHONUNBUFFERED=true
|
||||
export DEVSTACK_GATE_TEMPEST=1
|
||||
export DEVSTACK_GATE_TEMPEST_FULL=1
|
||||
#export DEVSTACK_GATE_TEMPEST_FULL=0
|
||||
export DEVSTACK_GATE_VIRT_DRIVER=xenapi
|
||||
# Set gate timeout to 2 hours
|
||||
export DEVSTACK_GATE_TIMEOUT=240
|
||||
|
||||
cp devstack-gate/devstack-vm-gate-wrap.sh ./safe-devstack-vm-gate-wrap.sh
|
||||
./safe-devstack-vm-gate-wrap.sh
|
||||
EOF
|
||||
} | remote-bash jenkins@$IP
|
||||
cat $RUN_TESTS_SCRIPT | remote-bash jenkins@$IP
|
||||
|
||||
RESULT="$?"
|
||||
set -x
|
||||
|
107
run_tests.sh
Normal file
107
run_tests.sh
Normal file
@ -0,0 +1,107 @@
|
||||
#!/bin/bash
|
||||
|
||||
set -eux
|
||||
|
||||
SSH_DOM0="sudo -u domzero ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null root@192.168.33.2"
|
||||
FEED_WITH_NOTHING="< /dev/null"
|
||||
|
||||
# Get some parameters
|
||||
APP=$($SSH_DOM0 xe vm-list name-label=$APPLIANCE_NAME --minimal $FEED_WITH_NOTHING)
|
||||
|
||||
# Create a vm network
|
||||
VMNET=$($SSH_DOM0 xe network-create name-label=vmnet $FEED_WITH_NOTHING)
|
||||
VMVIF=$($SSH_DOM0 xe vif-create vm-uuid=$APP network-uuid=$VMNET device=3 $FEED_WITH_NOTHING)
|
||||
$SSH_DOM0 xe vif-plug uuid=$VMVIF $FEED_WITH_NOTHING
|
||||
|
||||
# Create pub network
|
||||
PUBNET=$($SSH_DOM0 xe network-create name-label=pubnet $FEED_WITH_NOTHING)
|
||||
PUBVIF=$($SSH_DOM0 xe vif-create vm-uuid=$APP network-uuid=$PUBNET device=4 $FEED_WITH_NOTHING)
|
||||
$SSH_DOM0 xe vif-plug uuid=$PUBVIF $FEED_WITH_NOTHING
|
||||
|
||||
# Hack iSCSI SR
|
||||
$SSH_DOM0 << SRHACK
|
||||
set -eux
|
||||
sed -ie "s/'phy'/'aio'/g" /opt/xensource/sm/ISCSISR.py
|
||||
SRHACK
|
||||
|
||||
# This is important, otherwise dhcp client will fail
|
||||
for dev in eth0 eth1 eth2 eth3 eth4; do
|
||||
sudo ethtool -K $dev tx off
|
||||
done
|
||||
|
||||
# Add a separate disk
|
||||
SR=$($SSH_DOM0 xe sr-list type=ext --minimal $FEED_WITH_NOTHING)
|
||||
VDI=$($SSH_DOM0 xe vdi-create name-label=disk-for-volumes virtual-size=10GiB sr-uuid=$SR type=user $FEED_WITH_NOTHING)
|
||||
VBD=$($SSH_DOM0 xe vbd-create vm-uuid=$APP vdi-uuid=$VDI device=1 $FEED_WITH_NOTHING)
|
||||
$SSH_DOM0 xe vbd-plug uuid=$VBD $FEED_WITH_NOTHING
|
||||
|
||||
# For development:
|
||||
export SKIP_DEVSTACK_GATE_PROJECT=1
|
||||
|
||||
sudo pip install -i https://pypi.python.org/simple/ XenAPI
|
||||
|
||||
# These came from the Readme
|
||||
export REPO_URL=https://review.openstack.org/p
|
||||
export ZUUL_URL=/home/jenkins/workspace-cache
|
||||
export ZUUL_REF=HEAD
|
||||
export WORKSPACE=/home/jenkins/workspace/testing
|
||||
|
||||
# Check out a custom branch
|
||||
(
|
||||
cd workspace-cache/devstack-gate/
|
||||
git remote add mate https://github.com/matelakat/devstack-gate
|
||||
git fetch mate
|
||||
git checkout xenserver-integration
|
||||
)
|
||||
mkdir -p $WORKSPACE
|
||||
|
||||
export ZUUL_PROJECT=openstack/nova
|
||||
export ZUUL_BRANCH=master
|
||||
|
||||
git clone $REPO_URL/$ZUUL_PROJECT $ZUUL_URL/$ZUUL_PROJECT
|
||||
cd $ZUUL_URL/$ZUUL_PROJECT
|
||||
git checkout remotes/origin/$ZUUL_BRANCH
|
||||
|
||||
# Plugins
|
||||
tar -czf - -C /home/jenkins/workspace-cache/nova/plugins/xenserver/xenapi/etc/xapi.d/plugins/ ./ |
|
||||
$SSH_DOM0 \
|
||||
'tar -xzf - -C /etc/xapi.d/plugins/ && chmod a+x /etc/xapi.d/plugins/*'
|
||||
|
||||
# Console log
|
||||
tar -czf - -C /home/jenkins/workspace-cache/nova/tools/xenserver/ rotate_xen_guest_logs.sh |
|
||||
$SSH_DOM0 \
|
||||
'tar -xzf - -C /root/ && chmod +x /root/rotate_xen_guest_logs.sh && mkdir -p /var/log/xen/guest'
|
||||
$SSH_DOM0 crontab - << CRONTAB
|
||||
* * * * * /root/rotate_xen_guest_logs.sh
|
||||
CRONTAB
|
||||
|
||||
# Insert a rule as the first position - allow all traffic on the mgmt interface
|
||||
# Other rules are inserted by config/modules/iptables/templates/rules.erb
|
||||
sudo iptables -I INPUT 1 -i eth2 -s 192.168.33.0/24 -j ACCEPT
|
||||
|
||||
(
|
||||
cd /home/jenkins/workspace-cache/devstack
|
||||
{
|
||||
echo "set -eux"
|
||||
cat tools/xen/functions
|
||||
echo "create_directory_for_images"
|
||||
echo "create_directory_for_kernels"
|
||||
} | $SSH_DOM0
|
||||
)
|
||||
|
||||
cd $WORKSPACE
|
||||
git clone https://github.com/matelakat/devstack-gate -b xenserver-integration
|
||||
|
||||
#( sudo mkdir -p /opt/stack/new && sudo chown -R jenkins:jenkins /opt/stack/new && cd /opt/stack/new && git clone https://github.com/matelakat/devstack-gate -b xenserver-integration )
|
||||
|
||||
# Values from the job template
|
||||
export PYTHONUNBUFFERED=true
|
||||
export DEVSTACK_GATE_TEMPEST=1
|
||||
export DEVSTACK_GATE_TEMPEST_FULL=1
|
||||
#export DEVSTACK_GATE_TEMPEST_FULL=0
|
||||
export DEVSTACK_GATE_VIRT_DRIVER=xenapi
|
||||
# Set gate timeout to 2 hours
|
||||
export DEVSTACK_GATE_TIMEOUT=240
|
||||
|
||||
cp devstack-gate/devstack-vm-gate-wrap.sh ./safe-devstack-vm-gate-wrap.sh
|
||||
./safe-devstack-vm-gate-wrap.sh
|
Loading…
Reference in New Issue
Block a user