summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJiajun Xu <jiajun.xu@intel.com>2011-06-24 15:53:45 +0800
committerRichard Purdie <richard.purdie@linuxfoundation.org>2011-06-24 11:28:32 +0100
commitd08a341af77ac0ad618d4033a18f33ac1fc98fb2 (patch)
treeb4693a9bb284efb662f6b6f69f0dc74fac87a7e0
parent7b4eb14c541bb41655c4340f6fbf190db1c346ed (diff)
downloadpoky-d08a341af77ac0ad618d4033a18f33ac1fc98fb2.tar.gz
qemuimagetest: update cvs and iptables to newer version for toolchain test
The old versions of cvs and iptables may meet compile error under some architecture - cvs 1.11.23 fails on x86-64 host and iptables 1.4.9 fails on arm host. Update them to latest version could solve these build error. Meanwhile, 240s timeout is set for sudoku becasue 120s is not enough to finish compile. Signed-off-by Jiajun Xu <jiajun.xu@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--meta/classes/imagetest-qemu.bbclass2
-rwxr-xr-xscripts/qemuimage-testlib52
-rwxr-xr-xscripts/qemuimage-tests/toolchain/sudoku-savant2
3 files changed, 44 insertions, 12 deletions
diff --git a/meta/classes/imagetest-qemu.bbclass b/meta/classes/imagetest-qemu.bbclass
index e259ae9baa..25304de5ef 100644
--- a/meta/classes/imagetest-qemu.bbclass
+++ b/meta/classes/imagetest-qemu.bbclass
@@ -33,7 +33,7 @@ def qemuimagetest_main(d):
33 Test Controller for automated testing. 33 Test Controller for automated testing.
34 """ 34 """
35 35
36 casestr = re.compile(r'(?P<scen>\w+\b):(?P<case>\w+$)') 36 casestr = re.compile(r'(?P<scen>\w+\b):(?P<case>\S+$)')
37 resultstr = re.compile(r'\s*(?P<case>\w+)\s*(?P<pass>\d+)\s*(?P<fail>\d+)\s*(?P<noresult>\d+)') 37 resultstr = re.compile(r'\s*(?P<case>\w+)\s*(?P<pass>\d+)\s*(?P<fail>\d+)\s*(?P<noresult>\d+)')
38 machine = bb.data.getVar('MACHINE', d, 1) 38 machine = bb.data.getVar('MACHINE', d, 1)
39 pname = bb.data.getVar('PN', d, 1) 39 pname = bb.data.getVar('PN', d, 1)
diff --git a/scripts/qemuimage-testlib b/scripts/qemuimage-testlib
index c39fb7ae21..c2dbf6027f 100755
--- a/scripts/qemuimage-testlib
+++ b/scripts/qemuimage-testlib
@@ -32,14 +32,14 @@ PID=0
32TARGET_IPADDR=0 32TARGET_IPADDR=0
33 33
34# Global variable for test project version during toolchain test 34# Global variable for test project version during toolchain test
35# Version of cvs is 1.11.23 35# Version of cvs is 1.12.13
36# Version of iptables is 1.4.9 36# Version of iptables is 1.4.11
37# Version of sudoku-savant is 1.3 37# Version of sudoku-savant is 1.3
38PROJECT_PV=0 38PROJECT_PV=0
39 39
40# Global variable for test project download URL during toolchain test 40# Global variable for test project download URL during toolchain test
41# URL of cvs is http://ftp.gnu.org/non-gnu/cvs/source/stable/1.11.23/cvs-1.11.23.tar.bz2 41# URL of cvs is http://ftp.gnu.org/non-gnu/cvs/source/feature/1.12.13/cvs-1.12.13.tar.bz2
42# URL of iptables is http://netfilter.org/projects/iptables/files/iptables-1.4.9.tar.bz2 42# URL of iptables is http://netfilter.org/projects/iptables/files/iptables-1.4.11.tar.bz2
43# URL of sudoku-savant is http://downloads.sourceforge.net/project/sudoku-savant/sudoku-savant/sudoku-savant-1.3/sudoku-savant-1.3.tar.bz2 43# URL of sudoku-savant is http://downloads.sourceforge.net/project/sudoku-savant/sudoku-savant/sudoku-savant-1.3/sudoku-savant-1.3.tar.bz2
44PROJECT_DOWNLOAD_URL=0 44PROJECT_DOWNLOAD_URL=0
45 45
@@ -641,14 +641,46 @@ Test_Time_Out()
641 local date=0 641 local date=0
642 local tmp=`mktemp` 642 local tmp=`mktemp`
643 local ret=1 643 local ret=1
644 local pid=0
645 local ppid=0
646 local i=0
647 declare local pid_l
644 648
645 # Run command in background 649 # Run command in background
646 ($command; echo $? > $tmp) & 650 ($command; echo $? > $tmp) &
647 while ps -e -o pid | grep -qw $!; do 651 pid=$!
652 while ps -e -o pid | grep -qw $pid; do
648 if [ $date -ge $timeout ]; then 653 if [ $date -ge $timeout ]; then
649 Test_Info "$timeout Timeout when running command $command" 654 Test_Info "$timeout Timeout when running command $command"
650 rm -rf $tmp 655 rm -rf $tmp
651 return 1 656
657 # Find all child processes of pid and kill them
658 ppid=$pid
659 ps -f --ppid $ppid
660 ret=$?
661
662 while [ $ret -eq 0 ]
663 do
664 # If yes, get the child pid and check if the child pid has other child pid
665 # Continue the while loop until there is no child pid found
666 pid_l[$i]=`ps -f --ppid $ppid | awk '{if ($2 != "PID") print $2}'`
667 ppid=${pid_l[$i]}
668 i=$((i+1))
669 ps -f --ppid $ppid
670 ret=$?
671 done
672
673 # Kill these children pids from the last one
674 while [ $i -ne 0 ]
675 do
676 i=$((i-1))
677 kill ${pid_l[$i]}
678 sleep 2
679 done
680
681 # Kill the parent id
682 kill $pid
683 return 1
652 fi 684 fi
653 sleep 5 685 sleep 5
654 date=`expr $date + 5` 686 date=`expr $date + 5`
@@ -672,11 +704,11 @@ Test_Toolchain()
672 704
673 # Set value for PROJECT_PV and PROJECT_DOWNLOAD_URL accordingly 705 # Set value for PROJECT_PV and PROJECT_DOWNLOAD_URL accordingly
674 if [ $test_project == "cvs" ]; then 706 if [ $test_project == "cvs" ]; then
675 PROJECT_PV=1.11.23 707 PROJECT_PV=1.12.13
676 PROJECT_DOWNLOAD_URL="http://ftp.gnu.org/non-gnu/cvs/source/stable/1.11.23/cvs-1.11.23.tar.bz2" 708 PROJECT_DOWNLOAD_URL="http://ftp.gnu.org/non-gnu/cvs/source/feature/1.12.13/cvs-1.12.13.tar.bz2"
677 elif [ $test_project == "iptables" ]; then 709 elif [ $test_project == "iptables" ]; then
678 PROJECT_PV=1.4.9 710 PROJECT_PV=1.4.11
679 PROJECT_DOWNLOAD_URL="http://netfilter.org/projects/iptables/files/iptables-1.4.9.tar.bz2" 711 PROJECT_DOWNLOAD_URL="http://netfilter.org/projects/iptables/files/iptables-1.4.11.tar.bz2"
680 elif [ $test_project == "sudoku-savant" ]; then 712 elif [ $test_project == "sudoku-savant" ]; then
681 PROJECT_PV=1.3 713 PROJECT_PV=1.3
682 PROJECT_DOWNLOAD_URL="http://downloads.sourceforge.net/project/sudoku-savant/sudoku-savant/sudoku-savant-1.3/sudoku-savant-1.3.tar.bz2" 714 PROJECT_DOWNLOAD_URL="http://downloads.sourceforge.net/project/sudoku-savant/sudoku-savant/sudoku-savant-1.3/sudoku-savant-1.3.tar.bz2"
diff --git a/scripts/qemuimage-tests/toolchain/sudoku-savant b/scripts/qemuimage-tests/toolchain/sudoku-savant
index 603afe63ee..3d149dea27 100755
--- a/scripts/qemuimage-tests/toolchain/sudoku-savant
+++ b/scripts/qemuimage-tests/toolchain/sudoku-savant
@@ -11,7 +11,7 @@
11# 11#
12. $COREBASE/scripts/qemuimage-testlib 12. $COREBASE/scripts/qemuimage-testlib
13 13
14TIMEOUT=120 14TIMEOUT=240
15 15
16# Extract and test toolchain tarball 16# Extract and test toolchain tarball
17Test_Toolchain sudoku-savant ${TIMEOUT} 17Test_Toolchain sudoku-savant ${TIMEOUT}