case13.py 6.22 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#******************************************************************************

#  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 

47
NUM_UE=1
48
49
50
NUM_eNB=1
NUM_TRIALS=3

nikaeinn's avatar
nikaeinn committed
51
PRB=[25,50,100]
52
53
MCS=[3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28]
#MCS=[0,4,9,10,13,16,17,22,27]
54
55
#PRB=[100]
#MCS=[16]
56
ANT_TX=2  # 2 
57
ANT_RX=2  # 2 
58
59
CHANNEL=["N"]
#CHANNEL=["C","E","F","G","H","I","L","M"] # A,B,C,D,E,F,
60
TX_MODE=2 # 2, 
61
MIN_SNR=10 
62
MAX_SNR=40
63
PERF=75
64
OPT="-L"
nikaeinn's avatar
nikaeinn committed
65
FRAME=2000
66
67
68
69
#OPT="-L -d" # 8bit decoder , activate dci decoding at UE



nikaeinn's avatar
nikaeinn committed
70
def execute(oai, user, pw, host,logfile,logdir,debug,cpu):
71
    
72
    case = '10'
73
74
75
    oai.send('cd $OPENAIR_TARGETS;')     
    oai.send('cd bin;')   
    oai.send('cp ./ulsim.Rel10 ./ulsim.Rel10.'+host)
76
    try:
77
        log.start()
78
        test = '300'
79
80
81
        name = 'Run oai.ulsim.sanity'
        conf = '-a -n 100'
        diag = 'ulsim is not running normally (Segmentation fault / Exiting / FATAL), debugging might be needed'
82
        trace = logdir + '/log_' + host + case + test + '_1.txt;'
83
        tee = ' 2>&1 | tee ' + trace
84
        oai.send_expect_false('./ulsim.Rel10.'+ host + ' ' + conf + tee, 'Segmentation fault', 30)
85
        trace = logdir + '/log_' + host + case + test + '_2.txt;'
86
        tee = ' 2>&1 | tee ' + trace
87
        oai.send_expect_false('./ulsim.Rel10.'+ host + ' ' + conf + tee, 'Exiting', 30)
88
        trace = logdir + '/log_' + host + case + test + '_3.txt;'
89
        tee = ' 2>&1 | tee ' + trace
90
        oai.send_expect_false('./ulsim.Rel10.'+ host + ' ' + conf + tee, 'FATAL', 30)
91
92
93
94
95
96
97

    except log.err, e:
        log.fail(case, test, name, conf, e.value, diag, logfile,trace)
    else:
        log.ok(case, test, name, conf, '', logfile)
    
    try:
98
        log.start()
99
        test = 310
100
101
102
        name = 'Run oai.ulsim.perf.'+str(PERF)+'%'
        diag = 'no diagnostic is available, check the log file'
        for i in range(len(PRB)):
103
            for o in range(len(CHANNEL)):
104
                MIN_SNR=10
105
106
                for j in range(len(MCS)):
                    for m in range (1,ANT_RX):
107
                        for p in range(1,TX_MODE):
108
109
110
111
112
113
                              for r in range(5,PRB[i]):
                                  for q in range(MIN_SNR,MAX_SNR): 
                              
                                  
                                    if r ==7 or r ==11 or r ==14 or r == 17 or r==19 or r == 21 or r == 23 or r == 26 or r == 28  : 
                                        continue
114
                                
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
                                    conf = '-B' + str(PRB[i]) + ' -r'+str(r) + ' -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])+ '_rb'+str(r)+'_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.Rel10.'+ host + ' ' + conf + tee
                                    else :
                                        cmd = './ulsim.Rel10.'+ 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
132
                                        test+=1
133
134
135
136
137
138
139
140
141
142
143
144
                                        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))
                                            
145
                                
146
147
148
149
150
151
                                            
    except log.err, e:
        log.fail(case, str(test), name, conf, e.value, diag, logfile,trace)
    #else:
    #    log.ok(case, test, name, conf, '', logfile)