813 lines
28 KiB
Plaintext
Raw Normal View History

2014-03-19 00:15:48 -04:00
#!/usr/bin/env perl
# IBM(c) 2010 EPL license http://www.eclipse.org/legal/epl-v10.html
#
#############################################################################################################################################
#
2014-03-25 02:00:50 -07:00
# This script will be used to run xCAT daily regression
2014-03-19 00:15:48 -04:00
#
2014-03-25 02:00:50 -07:00
# Usage:xCATreg - Run xCAT daily regression
2014-03-19 00:15:48 -04:00
# xCATreg [-?|-h]
# xCATreg [-b branch][-m MN][-f configure file][-a][-V]
2014-03-25 02:00:50 -07:00
#
2014-03-19 00:15:48 -04:00
# -?/-h: help information for the xCATreg usage.
# -b: when -b is specified, the regression will be done against the specified branch. You can use 2.7, 2.8,master.The default value is master.
# -m: when -m is specified, the regression will be done the specified mn. The default value is all the mn in configuration file.
# -f :specify the configuration file,default value is /xCATreg/regresson.conf
# -a: when -a is specified, run the regression even there is no code updates
# -V: log and message in verbose mode
#
# Example usage:
2014-03-25 02:00:50 -07:00
# ./xCATreg Run regressoins on master branch and on all platforms in configuration file
# ./xCATreg -b 2.8 -m slesmn -f /root/regressoin.conf -a Run regression on 2.8 branch on slesmn even when there is no code updates.
2014-03-19 00:15:48 -04:00
#
#############################################################################################################################################
2014-03-25 02:00:50 -07:00
2014-03-24 18:51:30 -07:00
use strict;
use warnings;
use Getopt::Long;
use Data::Dumper;
use Term::ANSIColor;
use Time::Local;
BEGIN
{
$::XCATROOT = $ENV{'XCATROOT'} ? $ENV{'XCATROOT'} : -d '/opt/xcat' ? '/opt/xcat' : '/usr';
}
use lib "$::XCATROOT/lib/perl";
2014-04-03 01:24:15 -07:00
2014-03-25 02:00:50 -07:00
#######################################
2014-03-28 00:16:49 -07:00
# usage for arguments
2014-03-25 02:00:50 -07:00
#######################################
2014-03-24 18:51:30 -07:00
sub usage
{
2014-03-28 00:16:49 -07:00
print "Usage:xCATreg - Run xcat autotest test cases.\n
2014-03-24 18:51:30 -07:00
Explanation for the options:
-b: when -b is specified, the regression will be done against the specified branch. The default value is master.\n
-m: when -m is specified, run regression on the specified mn. The default value is all the mn in configuration file.\n
-f: specify the configuration file location.\n
-U: when -U is specified, only code updates can trigger the regression.\n
-V: log and message in verbose mode.\n
-e: <email_addr> send the test result to email_addr\n";
2014-03-28 00:16:49 -07:00
print " xCATreg [-?|-h]\n";
print " xCATreg [-f configure file] [-b branch] [-m mangement node][-V][-e] install mn \n";
print " xCATreg [-f configure file] [-b branch] [-m mangement node ] [-U][-V][-e] if code updates there will be regression.\n";
2014-03-24 18:51:30 -07:00
print "\n";
return;
}
2014-04-03 01:24:15 -07:00
2014-03-24 01:39:31 -07:00
#######################################
2014-03-28 00:16:49 -07:00
# config for rhppc64env
2014-03-24 01:39:31 -07:00
#######################################
2014-03-28 00:16:49 -07:00
sub config_rhppc64 {
send_msg("******************************");
send_msg("Reading Configure");
send_msg("******************************");
2014-03-24 18:51:30 -07:00
if(!(-e $configfile)){
2014-03-28 00:16:49 -07:00
send_msg("Warning: The xCAT test Configure file doesn't exist!");
send_msg("Warning: The xCAT test Configure file doesn't exist!");
return 0;
2014-03-24 18:51:30 -07:00
}
my $sub_type = undef; # The string after $type_
# Script-->
# Script_Prev
# Script_Post
# Table--->
# Table_xxxxx
# Object-->
# Object_xxxx
# System---->
# Custom---->
my $name = undef;
my $attr = undef;
my $value = undef;
my $c = 0;
my $cmd = undef;
my $mgt_name = undef;
open(FILE, "$configfile") or die "can't to open $configfile";
2014-03-28 00:16:49 -07:00
while(my $line = <FILE>) {
2014-03-24 18:51:30 -07:00
$line = &trim($line);
next if(length($line) == 0);
#Table name can not contain "_"
if($line =~ /\[\s*(\w+)\_(\w+)\s*\]/) {
$type = $1;
2014-03-28 00:16:49 -07:00
$sub_type = $2;
2014-03-24 18:51:30 -07:00
$name = undef;
$c = 0;
}elsif($line =~ /\[\s*rhppc64System|Custom\s*\]/){
2014-03-28 00:16:49 -07:00
$type = "rhppc64Varible";
2014-03-24 18:51:30 -07:00
}elsif ($type eq "rhppc64Table") {
##TABLE BLOCK##
if($line =~ /(\w+)\s*=\s*([\w\.\-]+)/) {
$attr = $1;
$value = $2;
2014-03-28 00:16:49 -07:00
if($name&&($rhppc64config{table}{$sub_type}{$name}{__KEY__} ne $attr)){
2014-03-24 18:51:30 -07:00
$rhppc64config{table}{$sub_type}{$name}{$attr}=$value;
} else {
$name = $value;
$rhppc64config{table}{$sub_type}{$name}{__KEY__}=$attr;
}
}
}elsif ($type eq "rhppc64Object") {
##OBJECT BLOCK##
if($line =~ /(\w+)\s*=\s*([\w\.\-]+)/) {
$attr = $1;
$value = $2;
2014-03-28 00:16:49 -07:00
#print "rhppc64node attr is $attr\n";
#print "rhppc64node value is $value\n";
2014-03-24 18:51:30 -07:00
if($attr eq "Name"){
$name = $value;
} elsif(!defined($name)){
print "Please give name for Object\n";
2014-03-28 00:16:49 -07:00
close FILE;
2014-03-24 18:51:30 -07:00
return 1;
} else {
$rhppc64config{object}{$sub_type}{$name}{$attr}=$value;
}
}
}elsif ($type eq "rhppc64Script") {
##SCRIPT_BLOCK##
if($sub_type eq "Prev") {
$rhppc64config{script_prev}->[$c] = $line;
2014-03-28 00:16:49 -07:00
$c = $c + 1;
2014-03-24 18:51:30 -07:00
}
elsif ($sub_type eq "rhppc64Post") {
$rhppc64config{script_post}->[$c] = $line;
$c = $c + 1;
}
} elsif ($type eq "rhppc64Varible") {
##NODE_BLOCK##
if($line =~ /(\w+)\s*=\s*([\w\.\-\/]+)/) {
$rhppc64config{var}{$1} = $2;
2014-03-28 00:16:49 -07:00
print "var $1,$2\n";
2014-03-24 18:51:30 -07:00
}
}
}
if(exists $rhppc64config{object}){
foreach my $type (keys %{$rhppc64config{object}}){
foreach my $name (keys %{$rhppc64config{object}{$type}}){
2014-03-28 00:16:49 -07:00
send_msg("OBJECT:$name,TYPE:$type");
#print "$name,TYPE:$type \n";
2014-03-24 18:51:30 -07:00
foreach my $attr (keys %{$rhppc64config{object}{$type}{$name}}){
2014-03-28 00:16:49 -07:00
send_msg(" $attr = $config{object}{$type}{$name}{$attr};");
2014-03-24 18:51:30 -07:00
}
}
}
}
if(exists $rhppc64config{table}){
foreach my $type (keys %{$rhppc64config{table}}){
2014-03-28 00:16:49 -07:00
send_msg("TABLE:$type");
2014-03-24 18:51:30 -07:00
foreach my $name (keys %{$rhppc64config{table}{$type}}){
2014-03-28 00:16:49 -07:00
send_msg(" $rhppc64config{table}{$type}{$name}{__KEY__} = $name");
2014-03-24 18:51:30 -07:00
foreach my $attr (keys %{$rhppc64config{table}{$type}{$name}}){
if($attr ne '__KEY__'){
2014-03-28 00:16:49 -07:00
send_msg(" $attr = $rhppc64config{table}{$type}{$name}{$attr}");
2014-03-24 18:51:30 -07:00
}
}
2014-03-28 00:16:49 -07:00
rhppc64 send_msg("\n");
2014-03-24 18:51:30 -07:00
}
}
}
if(exists $rhppc64config{script_prev}){
2014-03-28 00:16:49 -07:00
send_msg("Script_Prev:");
foreach $cmd (@{$config{script_prev}}){
send_msg(" $cmd");
}
2014-03-24 18:51:30 -07:00
}
if(exists $rhppc64config{script_post}){
2014-03-28 00:16:49 -07:00
send_msg("Script_Post:");
foreach $cmd (@{$config{script_post}}){
send_msg(" $cmd");
}
2014-03-24 18:51:30 -07:00
}
if (exists $rhppc64config{var}){
#my $MN=$rhppc64config{var}{MN};
#my $MNIP=$rhppc64config{var}{MNIP};
#&runcmd( "echo $MN $MN.$DOMAIN $MNIP>>/etc/hosts");
#print "MN is $MN\n";}
2014-03-28 00:16:49 -07:00
send_msg("Varible:");
foreach my $varname (keys %{$rhppc64config{var}}){
send_msg(" $varname = $config{var}{$varname}");
2014-03-24 18:51:30 -07:00
#print "var is $rhppc64config{var}\n";
}
}
close FILE;
return 0;
}
2014-04-03 01:24:15 -07:00
2014-03-24 01:39:31 -07:00
#######################################
2014-03-28 00:16:49 -07:00
# install xcat and init rhppc64 env
2014-03-24 01:39:31 -07:00
#######################################
2014-03-28 00:16:49 -07:00
sub init
{
if (exists $rhppc64config{var}){
my $MN=$rhppc64config{var}{MN};
my $MNIP=$rhppc64config{var}{MNIP};
my $CN=$rhppc64config{var}{CN};
my $CNIP=$rhppc64config{var}{CNIP};
my $SN=$rhppc64config{var}{SN};
my $SNIP=$rhppc64config{var}{SNIP};
my $SNCN=$rhppc64config{var}{SNCN};
my $SNCNIP=$rhppc64config{var}{SNCNIP};
my $HMC=$rhppc64config{var}{HMC};
my $HMCIP=$rhppc64config{var}{HMCIP};
my $MOUNTIP=$rhppc64config{var}{MOUNTIP};
my $DOMAIN=$rhppc64config{var}{DOMAIN};
my $nodedir=$rhppc64config{var}{nodedir};
system("xdsh $MN mkdir -p /iso/mountpoint");
print "--prepareing redhat iso file.......\n";
2014-03-24 18:51:30 -07:00
print "--mount NF .......";
2014-03-28 00:16:49 -07:00
system ("scp -r /iso/RHEL6.4-20130130.0-Server-ppc64-DVD1.iso $MNIP:/iso/mountpoint");
system("xdsh $MN mount -o loop /iso/mountpoint/RHEL6.4-20130130.0-Server-ppc64-DVD1.iso /iso");
&runcmd( " echo $HMCIP $HMC.$DOMAIN $HMC>>/etc/hosts.rhppc64");
&runcmd( " echo $MNIP $MN.$DOMAIN $MN>>/etc/hosts.rhppc64");
&runcmd( " echo $CNIP $CN.$DOMAIN $CN>>/etc/hosts.rhppc64");
&runcmd( " echo $SNCNIP $SNCN.$DOMAIN $SNCN>>/etc/hosts.rhppc64");
system ("scp -r /etc/hosts.rhppc64 $MN:/etc/hosts");
&runcmd(" cp /etc/resolve.conf /etc/resolve.config.rhppc64");
&runcmd(" echo nameserver $MNIP >>/etc/resolve.config.rhppc64");
system ("scp -r /etc/resolve.conf.rhppc64 $MOUNTIP:/etc/resolve.conf");
print "[OK]\n";
print "--get the latest XCAT tarball.......\n";
system("xdsh $MN rm -rf /etc/yum.repos.d/*");
system("scp -r rhel6.4.repo $MN:/etc/yum.repos.d/rhel6.4.repo"); ######## redhat 6.4
system("xdsh $MN perl $nodedir/xcatbuild/xcat-core/mklocalrepo.sh");
system("xdsh $MN perl $nodedir/xcatbuild/xcat-dep/rh6/ppc64/mklocalrepo.sh");
print "--install XCAT .......\n";
system("xdsh $MN yum clean metadata");
system("xdsh $MN rpm --import /iso/mountpoint/RPM-GPG-KEY-redhat-release");
system("xdsh $MN yum -y install xCAT");
print "--install XCATTEST .......\n";
system("xdsh $MN yum -y install xCAT-test");
2014-03-24 18:51:30 -07:00
print "--install createrepo .......\n";
system("xdsh $MN yum -y install createrepo");
system("xdsh $MN yum -y install screen");
system("xdsh $MN yum -y install mysql-server mysql mysql-bench mysql-devel mysql-connector-odbc");
system("xdsh $MN rm -rf ./result");
system("xdsh $MN mkdir result");
system("xdsh $MN sysctl -n net.ipv4.ip_forward=1");
2014-03-28 00:16:49 -07:00
send_msg( " rhppc64 env is ready\n");
2014-03-24 18:51:30 -07:00
}
# if($restore){
2014-03-28 00:16:49 -07:00
# send_msg("******************************");
# send_msg("Backup current xCAT database");
# sned_msg("******************************");
2014-03-24 18:51:30 -07:00
# &runcmd("mkdir -p /tmp/xCATdbbackup");
# &runcmd("dumpxCATdb -p /tmp/xCATdbbackup");
# if($::RUNCMD_RC != 0){
2014-03-28 00:16:49 -07:00
# &send_msg("Fail to backup xCAT database");
2014-03-24 18:51:30 -07:00
# &runcmd("rm -rf /tmp/xCATdbbackup");
# $restore = 0;
# return 1;
#}
#}
2014-03-28 00:16:49 -07:00
# send_msg("******************************");
# send_msg("Initialize xCAT test evironment");
# send_msg("******************************");
my $cmd = undef;
foreach $cmd (@{$rhppc64config{script_prev}}){
send_msg("$cmd");
2014-03-24 18:51:30 -07:00
# &runcmd($cmd);
2014-03-28 00:16:49 -07:00
system("xdsh $MN $cmd");
if($::RUNCMD_RC != 0){
&send_msg("Fail to run $cmd");
return 1;
}
}
2014-03-24 18:51:30 -07:00
if(exists $rhppc64config{object}){
foreach my $type (keys %{$rhppc64config{object}}){
foreach my $name (keys %{$rhppc64config{object}{$type}}){
$cmd = "chdef -t $type -o $name";
foreach my $attr (keys %{$rhppc64config{object}{$type}{$name}}){
$cmd = $cmd." $attr=$rhppc64config{object}{$type}{$name}{$attr}";
}
send_msg($cmd);
2014-03-28 00:16:49 -07:00
my $MN=$rhppc64config{var}{MN};
2014-03-24 18:51:30 -07:00
# xdsh $MN &runcmd($cmd);
2014-03-28 00:16:49 -07:00
system("xdsh $MN $cmd");
2014-03-24 18:51:30 -07:00
if($::RUNCMD_RC != 0){
2014-03-28 00:16:49 -07:00
send_msg("Fail to run var $cmd");
2014-03-24 18:51:30 -07:00
return 1;
}
}
}
}
if(exists $rhppc64config{table}){
foreach my $type (keys %{$rhppc64config{table}}){
foreach my $name (keys %{$rhppc64config{table}{$type}}){
$cmd = "chtab $rhppc64config{table}{$type}{$name}{__KEY__}=$name";
foreach my $attr (keys %{$rhppc64config{table}{$type}{$name}}){
if($attr ne '__KEY__'){
$cmd = $cmd." $type.$attr=$rhppc64config{table}{$type}{$name}{$attr}";
}
}
send_msg($cmd);
# &runcmd($cmd);
2014-03-28 00:16:49 -07:00
system("xdsh $MN $cmd");
2014-03-24 18:51:30 -07:00
if($::RUNCMD_RC != 0){
2014-03-28 00:16:49 -07:00
&send_msg("Fail to run table $cmd");
2014-03-24 18:51:30 -07:00
return 1;
}
}
}
}
return 0;
}
2014-04-03 01:24:15 -07:00
2014-03-28 00:16:49 -07:00
#######################################
# run all test
#######################################
sub do_test
{
2014-03-24 18:51:30 -07:00
my $MN=$rhppc64config{var}{MN};
$fullinst=0;
$dsklsinst=0;
$bundlerun=1;
$stateliteinst=0;
$snfullinst=0;
$dsklscnsninst=0;
$fullcnsninst=0;
$statelitecnsninst=0;
print "Start to run diskless installation ...\n";
2014-03-28 00:16:49 -07:00
send_msg("******************************");
send_msg("start diskless test");
send_msg("******************************");
system("xdsh $MN mkdir -p /autotest/result");
2014-03-24 18:51:30 -07:00
if($dsklsinst){
system("xdsh $MN rm -f /opt/xcat/share/xcat/tools/autotest/testcase/installation/linux_diskless_installation_vm");
system("xdsh $MN /opt/xcat/bin/xcattest -t Linux_diskless_installation_flat_ppc64");
$output = system("xdsh $MN ls /opt/xcat/share/xcat/tools/autotest/result/failedcases.*");
if($output =~ /failedcases.(\d+)/){
$timestamp=$1;
}
system("xdsh $MN mv /opt/xcat/share/xcat/tools/autotest/result/* /autotest/result/");
$output = ("xdsh $MN tail /autotest/result/xcattest.log.$timestamp");
if($output =~ /Failed: (\d+)/){
if($1 != 0){
2014-03-28 00:16:49 -07:00
$send_msg{linux_diskless_installation_flat}{pass} = 0;
$send_msg{linux_diskless_installation_flat}{timestamp} = $timestamp;
2014-03-24 18:51:30 -07:00
} else {
2014-03-28 00:16:49 -07:00
$send_msg{linux_diskless_installation_flat}{pass} = 1;
2014-03-24 18:51:30 -07:00
}
}
}
if($bundlerun){
2014-03-28 00:16:49 -07:00
print "Start to run the automation test bucket ....\n";
2014-03-24 18:51:30 -07:00
system("xdsh $MN mkdir -p /autotest/result");
2014-03-28 00:16:49 -07:00
system("xdsh $MN /opt/xcat/bin/xcattest -b /opt/xcat/share/xcat/tools/autotest/bundle/bat.bundle");
$output = system("xdsh $MN ls /opt/xcat/share/xcat/tools/autotest/result/xcattest.log.*");
2014-03-24 18:51:30 -07:00
if($output =~ /xcattest\.log\.(\d+)/){
$timestamp = $1;
}
2014-03-28 00:16:49 -07:00
system("xdsh $MN mv /opt/xcat/share/xcat/tools/autotest/result/* /autotest/result/");
system("xdsh $MN cp /autotest/result/xcattest.log.$timestamp /autotest/result/log/xcattest.log.$timestamp.current");
$output = ("xdsh $MN tail /autotest/result/xcattest.log.$timestamp");
2014-03-24 18:51:30 -07:00
if($output =~ /Total: (\d+) , Failed: (\d+)/){
2014-03-28 00:16:49 -07:00
$send_msg{command}{total} = $1;
$send_msg{command}{fail} = $2;
$send_msg{command}{timestamp} = $timestamp;
if($send_msg{command}{fail} != 0){
$send_msg{command}{failcase} = "| | | Failed cases:"."\n";
$output = (xdsh $MN cat /autotest/result/failedcases.$timestamp | grep END);
2014-03-24 18:51:30 -07:00
while($output =~ /END::(\w+)/g){
2014-03-28 00:16:49 -07:00
$send_msg{command}{failcase} = $send_msg{command}{failcase}."| | | ".$1."\n";
2014-03-24 18:51:30 -07:00
# print "$msg{command}{failcase}";
}
2014-03-28 00:16:49 -07:00
print "$send_msg{command}{failcase}";
2014-03-24 18:51:30 -07:00
}
}
}
if($stateliteinst){
2014-03-28 00:16:49 -07:00
system("xdsh $MN /opt/xcat/bin/xcattest -t Linux_statelite_installation_flat_ppc64");
$output = (xdsh $MN ls /opt/xcat/share/xcat/tools/autotest/result/failedcases.*");
2014-03-24 18:51:30 -07:00
if($output =~ /failedcases\.(\d+)/){
$timestamp = $1;
}
2014-03-28 00:16:49 -07:00
system(xdsh $MN mv /opt/xcat/share/xcat/tools/autotest/result/* /autotest/result/");
system(xdsh $MN cp /autotest/result/xcattest.log.$timestamp /autotest/result/log/xcattest.log.$timestamp.current");
$output = xdsh $MN tail /autotest/result/xcattest.log.$timestamp;
2014-03-24 18:51:30 -07:00
if($output =~ /Failed: (\d+)/){
if($1 != 0){
2014-03-28 00:16:49 -07:00
$send_msg{linux_statelite_installation_flat}{pass} = 0;
$send_msg{linux_statelite_installation_flat}{timestamp} = $timestamp;
2014-03-24 18:51:30 -07:00
} else {
2014-03-28 00:16:49 -07:00
$send_msg{linux_statelite_installation_flat}{pass} = 1;
2014-03-24 18:51:30 -07:00
}
}
}
if($fullinst){
2014-03-28 00:16:49 -07:00
system("xdsh $MN /opt/xcat/bin/xcattest -t Linux_full_installation_flat_ppc64");
$output = xdsh $MN ls /opt/xcat/share/xcat/tools/autotest/result/failedcases.*;
2014-03-24 18:51:30 -07:00
if($output =~ /failedcases\.(\d+)/){
$timestamp = $1;
}
2014-03-28 00:16:49 -07:00
system(xdsh $MN mv /opt/xcat/share/xcat/tools/autotest/result/* /autotest/result/");
system(xdsh $MN cp /autotest/result/xcattest.log.$timestamp /autotest/result/log/xcattest.log.$timestamp.current");
$output = xdsh $MN tail /autotest/result/xcattest.log.$timestamp;
2014-03-24 18:51:30 -07:00
if($output =~ /Failed: (\d+)/){
if($1 != 0){
2014-03-28 00:16:49 -07:00
$send_msg{linux_full_installation_flat}{pass} = 0;
$send_msg{linux_full_installation_flat}{timestamp} = $timestamp;
2014-03-24 18:51:30 -07:00
} else {
2014-03-28 00:16:49 -07:00
$send_msg{linux_full_installation_flat}{pass} = 1;
2014-03-24 18:51:30 -07:00
}
}
}
if($snfullinst){
2014-03-28 00:16:49 -07:00
system("xdsh $MN /opt/xcat/bin/xcattest -t Linux_sn_installation_flat_x86_vm");
$output = xdsh $MN ls /opt/xcat/share/xcat/tools/autotest/result/failedcases.*;
2014-03-24 18:51:30 -07:00
if($output =~ /failedcases\.(\d+)/){
$timestamp = $1;
}
2014-03-28 00:16:49 -07:00
xdsh $MN mv /opt/xcat/share/xcat/tools/autotest/result/* /autotest/result/;
xdsh $MN cp /autotest/result/xcattest.log.$timestamp /autotest/result/log/xcattest.log.$timestamp.current`;
$output = xdsh $MN tail /autotest/result/xcattest.log.$timestamp;
2014-03-24 18:51:30 -07:00
if($output =~ /Failed: (\d+)/){
if($1 != 0){
2014-03-28 00:16:49 -07:00
$send_msg{linux_sn_installation_flat}{pass} = 0;
$send_msg{linux_sn_installation_flat}{timestamp} = $timestamp;
2014-03-24 18:51:30 -07:00
} else {
2014-03-28 00:16:49 -07:00
$send_msg{linux_sn_installation_flat}{pass} = 1;
2014-03-24 18:51:30 -07:00
}
}
}
if($dsklscnsninst){
2014-03-28 00:16:49 -07:00
system("xdsh $MN /opt/xcat/bin/xcattest -t Linux_cn_with_sn_diskless_installation_flat_x86_vm");
$output = xdsh $MN ls /opt/xcat/share/xcat/tools/autotest/result/failedcases.*;
2014-03-24 18:51:30 -07:00
if($output =~ /failedcases\.(\d+)/){
$timestamp = $1;
}
2014-03-28 00:16:49 -07:00
xdsh $MN mv /opt/xcat/share/xcat/tools/autotest/result/* /autotest/result/;
xdsh $MN cp /autotest/result/xcattest.log.$timestamp /autotest/result/log/xcattest.log.$timestamp.current;
$output = xdsh $MN tail /autotest/result/xcattest.log.$timestamp;
2014-03-24 18:51:30 -07:00
if($output =~ /Failed: (\d+)/){
if($1 != 0){
2014-03-28 00:16:49 -07:00
$send_msg{linux_cn_with_sn_diskless_installation_flat}{pass} = 0;
$send_msg{linux_cn_with_sn_diskless_installation_flat}{timestamp} = $timestamp;
2014-03-24 18:51:30 -07:00
} else {
2014-03-28 00:16:49 -07:00
$send_msg{linux_cn_with_sn_diskless_installation_flat}{pass} = 1;
2014-03-24 18:51:30 -07:00
}
}
}
if($statelitecnsninst){
2014-03-28 00:16:49 -07:00
system("xdsh $MN /opt/xcat/bin/xcattest -t Linux_cn_with_sn_statelite_installation_flat_x86_vm");
$output = xdsh $MN ls /opt/xcat/share/xcat/tools/autotest/result/failedcases.*;
2014-03-24 18:51:30 -07:00
if($output =~ /failedcases\.(\d+)/){
$timestamp = $1;
}
2014-03-28 00:16:49 -07:00
xdsh $MN mv /opt/xcat/share/xcat/tools/autotest/result/* /autotest/result/;
xdsh $MN cp /autotest/result/xcattest.log.$timestamp /autotest/result/log/xcattest.log.$timestamp.current;
$output = xdsh $MN tail /autotest/result/xcattest.log.$timestamp;
2014-03-24 18:51:30 -07:00
if($output =~ /Failed: (\d+)/){
if($1 != 0){
2014-03-28 00:16:49 -07:00
$send_msg{linux_cn_with_sn_statelite_installation_flat}{pass} = 0;
$send_msg{linux_cn_with_sn_statelite_installation_flat}{timestamp} = $timestamp;
2014-03-24 18:51:30 -07:00
} else {
2014-03-28 00:16:49 -07:00
$send_msg{linux_cn_with_sn_statelite_installation_flat}{pass} = 1;
2014-03-24 18:51:30 -07:00
}
}
}
if($fullcnsninst){
2014-03-28 00:16:49 -07:00
system("xdsh $MN /opt/xcat/bin/xcattest -t Linux_cn_with_sn_full_installation_flat_x86_vm");
$output = xdsh $MN ls /opt/xcat/share/xcat/tools/autotest/result/failedcases.*;
2014-03-24 18:51:30 -07:00
if($output =~ /failedcases\.(\d+)/){
$timestamp = $1;
}
2014-03-28 00:16:49 -07:00
xdsh $MN mv /opt/xcat/share/xcat/tools/autotest/result/* /autotest/result/;
xdsh $MN cp /autotest/result/xcattest.log.$timestamp /autotest/result/log/xcattest.log.$timestamp.current;
$output = xdsh $MN tail /autotest/result/xcattest.log.$timestamp;
2014-03-24 18:51:30 -07:00
if($output =~ /Failed: (\d+)/){
if($1 != 0){
2014-03-28 00:16:49 -07:00
$send_msg{linux_cn_with_sn_full_installation_flat}{pass} = 0;
$send_msg{linux_cn_with_sn_full_installation_flat}{timestamp} = $timestamp;
2014-03-24 18:51:30 -07:00
} else {
2014-03-28 00:16:49 -07:00
$send_msg{linux_cn_with_sn_full_installation_flat}{pass} = 1;
2014-03-24 18:51:30 -07:00
}
}
}
2014-03-28 00:16:49 -07:00
system("mkdir -p $nodedir/result");
system("scp -r $MN:/autotest/result $nodedir/result");
2014-03-24 18:51:30 -07:00
2014-03-28 00:16:49 -07:00
}
2014-03-28 22:48:12 +08:00
2014-04-03 01:24:15 -07:00
#######################################
# mn_install to install all mn
#######################################
2014-03-28 22:48:12 +08:00
sub mn_install {
my osimage="management_1408a";
my mn="the_name_of_mn";
`nodeset $mn osimage=$osimage`;
$output = system("rpower $mn off");
do {
sleep 5;
$output = system("rpower $mn state");
} while ($output =~ /off/);
$output = system("rpower $mn on");
do {
sleep 5;
$output = system("rpower $mn state");
} while ($output =~ /on/);
do (
sleep 5 * 60;
$output = system("xdsh $mn date");
} while ($output =~ /$mn/);
}
2014-03-28 00:16:49 -07:00
#######################################
# runcmd
#######################################
2014-04-03 01:24:15 -07:00
sub runcmd {
2014-03-24 18:51:30 -07:00
2014-03-28 00:16:49 -07:00
my ($cmd) = @_;
my $rc = 0;
$::RUNCMD_RC = 0;
my $outref = [];
@$outref = `$cmd 2>&1`;
if ($?)
{
$rc = $? ;
$::RUNCMD_RC = $rc;
}
chomp(@$outref);
return @$outref;
2014-03-24 18:51:30 -07:00
}
2014-03-28 00:16:49 -07:00
2014-04-03 01:24:15 -07:00
#######################################
# trim
#######################################
sub trim {
2014-03-28 00:16:49 -07:00
my $str = shift @_;
if($str){
# $str =~ s/\#/__wellnumber__/g;
$str =~ s/^\s+|#.+|\s+$//g;
# $str =~ s/__wellnumber__/#/g;
}
return $str;
2014-03-24 18:51:30 -07:00
}
2014-04-03 01:24:15 -07:00
#######################################
# send messages
#######################################
sub send_msg {
my $msg = shift;
print "xcatreg message: $msg.\n";
}
#######################################
# read_conf
#######################################
sub read_conf{
my %confkeys;
my $keys;
if (!open($keys, "<$confile")) {
send_msg("Open configuration file error");
}
my $line;
while ($line = <$keys>) {
if ($line =~ /end/) {
last;
}
if ($line =~ /^\s*log\s*=\s*(\S*)\s*/) {
$confkeys{log} = $1;
}
if ($line =~ /^\s*mailgroup\s*=\s*(\S*)\s*/) {
$confkeys{mailgroup} = $1;
}
if ($line =~ /^\s*srcdir\s*=\s*(\S*)\s*/) {
$confkeys{srcdir} = $1;
}
if ($line =~ /^\s*rhpdir\s*=\s*(\S*)\s*/) {
$confkeys{rhpdir} = $1;
}
if ($line =~ /^\s*slespdir\s*=\s*(\S*)\s*/) {
$confkeys{slespdir} = $1;
}
if ($line =~ /^\s*aixdir\s*=\s*(\S*)\s*/) {
$confkeys{aixdir} = $1;
}
if ($line =~ /^\s*rhxdir\s*=\s*(\S*)\s*/) {
$confkeys{rhxdir} = $1;
}
if ($line =~ /^\s*slesxdir\s*=\s*(\S*)\s*/) {
$confkeys{slesxdir} = $1;
}
if ($line =~ /^\s*ubuntudir\s*=\s*(\S*)\s*/) {
$confkeys{ubuntudir} = $1;
}
if ($line =~ /^\s*xcattestconf\s*=\s*(\S*)\s*/) {
$confkeys{xcattestconf} = $1;
}
2014-04-03 01:24:15 -07:00
}
return %confkeys;
}
################################################################Main function######################################################################################
2014-03-24 18:51:30 -07:00
2014-03-28 00:16:49 -07:00
#######################################
# step 0. Parse input arguments
#######################################
my $rootdir = "$::XCATROOT/share/xcat/tools/autotest";
my $needhelp = 0;
my $configfile = "$::XCATROOT/share/xcat/tools/autotest";
my $branch = 0;
my $configfile = "$rootdir/default.conf";
my $management_node = undef;
my $verbose_mode = 0;
my $updates_regression = 0;
my $send_msg = 0;
my $ret = 0;
my $string1 = undef;
if (
!GetOptions("h|?" => \$needhelp,
"f=s" => \$configfile,
"b=s" => \$branch,
"m=s" => \$management_node,
"V" => \$verbose_mode,
"U" => \$updates_regression,
"e=s" => \$send_msg)
)
{
&usage;
send_msg("PARSE ARGUMENTS returns error, exit");
exit 1;
2014-03-24 18:51:30 -07:00
}
2014-03-28 00:16:49 -07:00
if ($needhelp)
{
&usage;
exit 0;
2014-03-24 18:51:30 -07:00
}
2014-03-28 00:16:49 -07:00
#######################################
2014-04-03 01:24:15 -07:00
# step 1. Read configuration files
2014-03-28 00:16:49 -07:00
#######################################
2014-04-03 01:24:15 -07:00
my %confhash = read_conf();
unless (%confhash) {
send_msg(" returns error, exit");
exit;
2014-03-24 18:51:30 -07:00
}
2014-03-28 00:16:49 -07:00
#######################################
2014-04-03 01:24:15 -07:00
# step 2. git update
2014-03-28 00:16:49 -07:00
#######################################
2014-04-03 01:24:15 -07:00
send_msg("begin to do git update");
my $gitup;
$gitup="/tmp/gitup";
#Do checkout in git repo
$res = system(cd $confkeys{srcdir});
if ($res !=0) {
send_msg("no source code directory,exit");
2014-03-28 00:16:49 -07:00
exit;
2014-03-24 18:51:30 -07:00
}
2014-04-03 01:24:15 -07:00
$res = system("git checkout $branch");
if ($res != 0){
send_msg("git checkout failed");
exit 1;
#}
$res = system("git pull >$gitup");
if ($res != 0){
send_msg("git pull failed");
exit 1;
}
$res = system("grep 'Already up-to-date' $gitup");
if (($res == 0)&&( $updates_regression == 1)) {
send_msg("code is already at latest version. exit regresson\n");
exit 1;
2014-03-24 18:51:30 -07:00
}
2014-04-03 01:24:15 -07:00
2014-03-28 00:16:49 -07:00
#######################################
# step 3. Install MNs
#######################################
2014-04-03 01:24:15 -07:00
#$res = mn_install();
#if ($res) {
# send_msg("INSTALL MNS returns error, exit");
# exit;
#}
2014-03-24 18:51:30 -07:00
2014-03-28 00:16:49 -07:00
#######################################
# step 4. Copy code to MNs
#######################################
2014-04-03 01:24:15 -07:00
##will modify to $confkeys{srcdir};
my $codedir = "/regression/code";
##will modify to $rhppc64config{var}{MNIP}
my $mn="aixmn"
#install dep for buildlocal
$res = system("xdsh $mn yum install -y rpm-build perl-Time-HiRes perl-DBI createrepo");
#need to copy /etc/hosts to mn
system("scp /etc/hosts $mn:/etc");
system("echo begin copy code");
$res = system("scp -r root\@$mn:/");
if ($res != 0){
send_msg("code copy failed");
exit 1;
2014-03-24 18:51:30 -07:00
}
2014-04-03 01:24:15 -07:00
2014-03-28 00:16:49 -07:00
#######################################
# step 5. Build xcat code in MNs
#######################################
2014-04-03 01:24:15 -07:00
#for temp usage
system("echo began build xcat on mn");
#will changed /code/xcat-core to $confkeys{srcdir}
$res = system("xdsh $mn /code/xcat-core/buildlocal.sh CURDIR=/code/xcat-core");
if ($res != 0){
send_msg("build failed on mn");
exit 1;
}
system("echo build done");
sleep 20;
2014-03-24 18:51:30 -07:00
2014-03-28 00:16:49 -07:00
#######################################
2014-04-03 01:24:15 -07:00
# step 6. Read xCAT MN's configuration
2014-03-28 00:16:49 -07:00
#######################################
mkdir $resultdir unless -d $resultdir;
my $timestamp = `date +"%Y%m%d%H%M%S"`;
my %rhppc64config=();
my %slesppc64config=();
my %rhx8664config=();
my %slesx8664config=();
my @osname = &runcmd("uname -a");
if ( $osname [0] =~ /^Linux\s*/ && -f "/etc/redhat-release" && $osname [0] =~ /ppc64/){
print "ppc64 redhat env\n";
$os="rhels6.4";
$arch="ppc64";
print "os is $os,arch is $arch\n";
$res = &config_rhppc64();
if ($res) {
send_msg("CONFIGURE MN returns error, exit");
exit;
}
2014-03-24 18:51:30 -07:00
}
2014-03-28 00:16:49 -07:00
#######################################
2014-04-03 01:24:15 -07:00
# step 7. Genrate local configuration file for xcattest
2014-03-28 00:16:49 -07:00
# Do test
# Write log
#######################################
# step 7.1 Install xcat and init mn
$res = &init;
if ($res != 0){
goto EXIT;
}
2014-03-24 18:51:30 -07:00
2014-03-28 00:16:49 -07:00
$res = &do_test();
if ($res) {
send_msg("DO TEST returns error, exit");
exit;
2014-03-24 18:51:30 -07:00
}
2014-03-24 01:39:31 -07:00
#######################################
2014-04-03 01:24:15 -07:00
# step 8. process result
2014-03-24 01:39:31 -07:00
#######################################
$res = pro_result();
if ($res) {
send_msg("PROCESS RESULT returns error, exit");
exit;
}
2014-03-19 00:15:48 -04:00
2014-03-25 02:00:50 -07:00