#****************************************************************************** # Eurecom OpenAirInterface # Copyright(c) 1999 - 2013 Eurecom # This program is free software; you can redistribute it and/or modify it # under the terms and conditions of the GNU General Public License, # version 2, as published by the Free Software Foundation. # This program is distributed in the hope it will be useful, but WITHOUT # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for # more details. # You should have received a copy of the GNU General Public License along with # this program; if not, write to the Free Software Foundation, Inc., # 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA. # The full GNU General Public License is included in this distribution in # the file called "COPYING". # Contact Information # Openair Admin: openair_admin@eurecom.fr # Openair Tech : openair_tech@eurecom.fr # Forums : http://forums.eurecom.fsr/openairinterface # Address : Eurecom, Compus SophiaTech 450, route des chappes, 06451 Biot, France #***************************************************************************** # \file case02.py # \brief test case 02 for OAI: executions # \author Navid Nikaein # \date 2013 # \version 0.1 # @ingroup _test import time import random import log import openair import core import os import shutil # copy file NUM_UE=1 NUM_eNB=1 NUM_TRIALS=3 PRB=[25,50,100] MCS=[0,4,9,10,13,16,17,22,27] #PRB=[100] #MCS=[16] ANT_TX=1 # 2 ANT_RX=2 # 2 CHANNEL=["N"] #CHANNEL=["C","E","F","G","H","I","L","M"] # A,B,C,D,E,F, TX_MODE=2 # 2, MIN_SNR=0 MAX_SNR=40 PERF=75 OPT="-L" FRAME=2000 #OPT="-L -d" # 8bit decoder , activate dci decoding at UE def execute(oai, user, pw, host,logfile,logdir,debug,cpu): case = '10' oai.send('cd $OPENAIR1_DIR;') oai.send('cd SIMULATION/LTE_PHY;') try: log.start() test = '300' name = 'Run oai.ulsim.sanity' conf = '-a -n 100' diag = 'ulsim is not running normally (Segmentation fault / Exiting / FATAL), debugging might be needed' trace = logdir + '/log_' + host + case + test + '_1.txt;' tee = ' 2>&1 | tee ' + trace oai.send_expect_false('./ulsim.rel8.'+ host + ' ' + conf + tee, 'Segmentation fault', 30) trace = logdir + '/log_' + host + case + test + '_2.txt;' tee = ' 2>&1 | tee ' + trace oai.send_expect_false('./ulsim.rel8.'+ host + ' ' + conf + tee, 'Exiting', 30) trace = logdir + '/log_' + host + case + test + '_3.txt;' tee = ' 2>&1 | tee ' + trace oai.send_expect_false('./ulsim.rel8.'+ host + ' ' + conf + tee, 'FATAL', 30) except log.err, e: log.fail(case, test, name, conf, e.value, diag, logfile,trace) else: log.ok(case, test, name, conf, '', logfile) try: log.start() test = 310 name = 'Run oai.ulsim.perf.'+str(PERF)+'%' diag = 'no diagnostic is available, check the log file' for i in range(len(PRB)): for o in range(len(CHANNEL)): MIN_SNR=0 for j in range(len(MCS)): for m in range (1,ANT_RX): for p in range(1,TX_MODE): for q in range(MIN_SNR,MAX_SNR): #if if PRB[i] : conf = '-B' + str(PRB[i]) + ' -m'+str(MCS[j]) + ' -y'+str(m) + ' -g'+str(CHANNEL[o]) + ' -x'+str(p) + ' -s'+str(q) + ' -w1.0 -e.1 -P -n'+str(FRAME)+' -O'+str(PERF)+' '+ OPT trace = logdir + '/time_meas' + '_prb'+str(PRB[i])+'_mcs'+ str(MCS[j])+ '_antrx' + str(m) + '_channel' +str(CHANNEL[o]) + '_tx' +str(p) + '_snr' +str(q)+'.'+case+str(test)+ '.log' tee = ' 2>&1 | tee ' + trace if cpu > -1 : cmd = 'taskset -c ' + str(cpu) + ' ./ulsim.rel8.'+ host + ' ' + conf + tee else : cmd = './ulsim.rel8.'+ host + ' ' + conf + tee if debug : print cmd # match = oai.send_expect_re(cmd, 'passed', 0, 1000) match =1 if match : log.ok(case, str(test), name, conf, '', logfile) MIN_SNR = q - 1 # just to speed up the test test+=1 break # found the smallest snr else : if q == MAX_SNR -1 : log.skip(case,str(test), name, conf,'','',logfile) test+=1 break try: if os.path.isfile(trace) : os.remove(trace) except OSError, e: ## if failed, report it back to the user ## print ("Error: %s - %s." % (e.filename,e.strerror)) except log.err, e: log.fail(case, str(test), name, conf, e.value, diag, logfile,trace) #else: # log.ok(case, test, name, conf, '', logfile)