Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-RAN
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
OpenXG
OpenXG-RAN
Commits
8ac2c874
Commit
8ac2c874
authored
Jul 19, 2024
by
Jaroslava Fiedlerova
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/ci-iperf2-func' into integration_2024_w29
parents
140ac7d4
c9a40c46
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
75 additions
and
35 deletions
+75
-35
ci-scripts/cls_oaicitest.py
ci-scripts/cls_oaicitest.py
+62
-33
ci-scripts/main.py
ci-scripts/main.py
+10
-0
ci-scripts/xml_class_list.yml
ci-scripts/xml_class_list.yml
+1
-0
ci-scripts/xml_files/container_4g_rfsim_fembms.xml
ci-scripts/xml_files/container_4g_rfsim_fembms.xml
+2
-2
No files found.
ci-scripts/cls_oaicitest.py
View file @
8ac2c874
...
@@ -202,8 +202,6 @@ def Iperf_analyzeV2UDP(server_filename, iperf_bitrate_threshold, iperf_packetlos
...
@@ -202,8 +202,6 @@ def Iperf_analyzeV2UDP(server_filename, iperf_bitrate_threshold, iperf_packetlos
with
open
(
server_filename
,
'r'
)
as
server_file
:
with
open
(
server_filename
,
'r'
)
as
server_file
:
for
line
in
server_file
.
readlines
():
for
line
in
server_file
.
readlines
():
result
=
re
.
search
(
statusTemplate
,
str
(
line
))
result
=
re
.
search
(
statusTemplate
,
str
(
line
))
if
result
is
not
None
:
break
if
result
is
None
:
if
result
is
None
:
return
(
False
,
'Could not parse server report!'
)
return
(
False
,
'Could not parse server report!'
)
bitrate
=
float
(
result
.
group
(
'bitrate'
))
bitrate
=
float
(
result
.
group
(
'bitrate'
))
...
@@ -790,10 +788,8 @@ class OaiCiTest():
...
@@ -790,10 +788,8 @@ class OaiCiTest():
udpIperf
=
re
.
search
(
'-u'
,
iperf_opt
)
is
not
None
udpIperf
=
re
.
search
(
'-u'
,
iperf_opt
)
is
not
None
bidirIperf
=
re
.
search
(
'--bidir'
,
iperf_opt
)
is
not
None
bidirIperf
=
re
.
search
(
'--bidir'
,
iperf_opt
)
is
not
None
client_filename
=
f'iperf_client_
{
self
.
testCase_id
}
_
{
ue
.
getName
()
}
.log'
client_filename
=
f'iperf_client_
{
self
.
testCase_id
}
_
{
ue
.
getName
()
}
.log'
server_filename
=
f'iperf_server_
{
self
.
testCase_id
}
_
{
ue
.
getName
()
}
.log'
ymlPath
=
CONTAINERS
.
yamlPath
[
0
].
split
(
'/'
)
ymlPath
=
CONTAINERS
.
yamlPath
[
0
].
split
(
'/'
)
logPath
=
f'../cmake_targets/log/
{
ymlPath
[
1
]
}
'
logPath
=
f'../cmake_targets/log/
{
ymlPath
[
1
]
}
'
if
udpIperf
:
if
udpIperf
:
target_bitrate
,
iperf_opt
=
Iperf_ComputeModifiedBW
(
idx
,
ue_num
,
self
.
iperf_profile
,
self
.
iperf_args
)
target_bitrate
,
iperf_opt
=
Iperf_ComputeModifiedBW
(
idx
,
ue_num
,
self
.
iperf_profile
,
self
.
iperf_args
)
# note: for UDP testing we don't want to use json report - reports 0 Mbps received bitrate
# note: for UDP testing we don't want to use json report - reports 0 Mbps received bitrate
...
@@ -805,36 +801,29 @@ class OaiCiTest():
...
@@ -805,36 +801,29 @@ class OaiCiTest():
# hack: the ADB UEs don't have iperf in $PATH, so we need to hardcode for the moment
# hack: the ADB UEs don't have iperf in $PATH, so we need to hardcode for the moment
iperf_ue
=
'/data/local/tmp/iperf3'
if
re
.
search
(
'adb'
,
ue
.
getName
())
else
'iperf3'
iperf_ue
=
'/data/local/tmp/iperf3'
if
re
.
search
(
'adb'
,
ue
.
getName
())
else
'iperf3'
ue_header
=
f'UE
{
ue
.
getName
()
}
(
{
ueIP
}
)'
ue_header
=
f'UE
{
ue
.
getName
()
}
(
{
ueIP
}
)'
# create log directory on executor node
if
svr
.
getName
()
==
"rfsim4g_enb_fembms"
:
with
cls_cmd
.
getConnection
(
'localhost'
)
as
local
:
with
cls_cmd
.
getConnection
(
ue
.
getHost
())
as
cmd_ue
,
cls_cmd
.
getConnection
(
EPC
.
IPAddress
)
as
cmd_svr
:
local
.
run
(
f'mkdir -p
{
logPath
}
'
)
port
=
5002
+
idx
with
cls_cmd
.
getConnection
(
ue
.
getHost
())
as
cmd_ue
,
cls_cmd
.
getConnection
(
EPC
.
IPAddress
)
as
cmd_svr
:
cmd_ue
.
run
(
f'
{
ue
.
getCmdPrefix
()
}
iperf -B
{
ueIP
}
-s -u -i1 >>
{
server_filename
}
&'
,
timeout
=
iperf_time
*
1.5
)
port
=
5002
+
idx
cmd_svr
.
run
(
f'
{
svr
.
getCmdPrefix
()
}
iperf -c
{
ueIP
}
-B
{
svrIP
}
{
iperf_opt
}
-i1 2>&1 | tee
{
client_filename
}
'
,
timeout
=
iperf_time
*
2.5
)
# note: some core setups start an iperf3 server automatically, indicated in ci_infra by runIperf3Server: False`
cmd_ue
.
run
(
f'cp
{
client_filename
}
{
logPath
}
/
{
client_filename
}
'
)
t
=
iperf_time
*
2.5
cmd_ue
.
run
(
f'cp
{
server_filename
}
{
logPath
}
/
{
server_filename
}
'
)
cmd_ue
.
run
(
f'rm /tmp/
{
client_filename
}
'
,
reportNonZero
=
False
)
status
,
msg
=
Iperf_analyzeV2UDP
(
server_filename
,
self
.
iperf_bitrate_threshold
,
self
.
iperf_packetloss_threshold
,
target_bitrate
)
if
runIperf3Server
:
cmd_svr
.
run
(
f'
{
svr
.
getCmdPrefix
()
}
nohup timeout -vk3
{
t
}
iperf3 -s -B
{
svrIP
}
-p
{
port
}
-1
{
jsonReport
}
&'
,
timeout
=
t
)
cmd_ue
.
run
(
f'
{
ue
.
getCmdPrefix
()
}
timeout -vk3
{
t
}
{
iperf_ue
}
-B
{
ueIP
}
-c
{
svrIP
}
-p
{
port
}
{
iperf_opt
}
{
jsonReport
}
{
serverReport
}
-O 5 >> /tmp/
{
client_filename
}
'
,
timeout
=
t
)
localPath
=
f'
{
os
.
getcwd
()
}
'
# note: copy iperf3 log to the directory for log collection, used by pipelines running on executor machine
cmd_ue
.
copyin
(
f'/tmp/
{
client_filename
}
'
,
f'
{
localPath
}
/
{
logPath
}
/
{
client_filename
}
'
)
# note: copy iperf3 log to the current directory for log analysis and log collection
cmd_ue
.
copyin
(
f'/tmp/
{
client_filename
}
'
,
f'
{
localPath
}
/
{
client_filename
}
'
)
cmd_ue
.
run
(
f'rm /tmp/
{
client_filename
}
'
,
reportNonZero
=
False
)
if
udpIperf
:
status
,
msg
=
Iperf_analyzeV3UDP
(
client_filename
,
self
.
iperf_bitrate_threshold
,
self
.
iperf_packetloss_threshold
,
target_bitrate
)
elif
bidirIperf
:
status
,
msg
=
Iperf_analyzeV3BIDIRJson
(
client_filename
)
else
:
else
:
with
cls_cmd
.
getConnection
(
ue
.
getHost
())
as
cmd_ue
,
cls_cmd
.
getConnection
(
EPC
.
IPAddress
)
as
cmd_svr
:
status
,
msg
=
Iperf_analyzeV3TCPJson
(
client_filename
,
self
.
iperf_tcp_rate_target
)
port
=
5002
+
idx
# note: some core setups start an iperf3 server automatically, indicated in ci_infra by runIperf3Server: False`
t
=
iperf_time
*
2.5
if
runIperf3Server
:
cmd_svr
.
run
(
f'
{
svr
.
getCmdPrefix
()
}
nohup timeout -vk3
{
t
}
iperf3 -s -B
{
svrIP
}
-p
{
port
}
-1
{
jsonReport
}
&'
,
timeout
=
t
)
cmd_ue
.
run
(
f'rm /tmp/
{
client_filename
}
'
,
reportNonZero
=
False
)
cmd_ue
.
run
(
f'
{
ue
.
getCmdPrefix
()
}
timeout -vk3
{
t
}
{
iperf_ue
}
-B
{
ueIP
}
-c
{
svrIP
}
-p
{
port
}
{
iperf_opt
}
{
jsonReport
}
{
serverReport
}
-O 5 >> /tmp/
{
client_filename
}
'
,
timeout
=
t
)
if
svr
.
getHost
()
==
'localhost'
:
cmd_ue
.
run
(
f'mkdir -p
{
logPath
}
'
)
cmd_ue
.
run
(
f'cp /tmp/
{
client_filename
}
{
logPath
}
/
{
client_filename
}
'
)
cmd_ue
.
run
(
f'cp /tmp/
{
client_filename
}
{
client_filename
}
'
)
else
:
cmd_ue
.
copyin
(
f'/tmp/
{
client_filename
}
'
,
client_filename
)
if
udpIperf
:
status
,
msg
=
Iperf_analyzeV3UDP
(
client_filename
,
self
.
iperf_bitrate_threshold
,
self
.
iperf_packetloss_threshold
,
target_bitrate
)
elif
bidirIperf
:
status
,
msg
=
Iperf_analyzeV3BIDIRJson
(
client_filename
)
else
:
status
,
msg
=
Iperf_analyzeV3TCPJson
(
client_filename
,
self
.
iperf_tcp_rate_target
)
logging
.
info
(
f'
\u001B
[1;37;45m iperf result for
{
ue_header
}
\u001B
[0m'
)
logging
.
info
(
f'
\u001B
[1;37;45m iperf result for
{
ue_header
}
\u001B
[0m'
)
for
l
in
msg
.
split
(
'
\n
'
):
for
l
in
msg
.
split
(
'
\n
'
):
...
@@ -872,6 +861,46 @@ class OaiCiTest():
...
@@ -872,6 +861,46 @@ class OaiCiTest():
HTML
.
CreateHtmlTestRowQueue
(
self
.
iperf_args
,
'KO'
,
messages
)
HTML
.
CreateHtmlTestRowQueue
(
self
.
iperf_args
,
'KO'
,
messages
)
self
.
AutoTerminateUEandeNB
(
HTML
,
RAN
,
EPC
,
CONTAINERS
)
self
.
AutoTerminateUEandeNB
(
HTML
,
RAN
,
EPC
,
CONTAINERS
)
def
Iperf2_Unidir
(
self
,
HTML
,
RAN
,
EPC
,
CONTAINERS
):
if
self
.
ue_ids
==
[]
or
self
.
svr_id
==
None
or
len
(
self
.
ue_ids
)
!=
1
:
raise
Exception
(
"no module names in self.ue_ids or/and self.svr_id provided, multi UE scenario not supported"
)
ue
=
cls_module
.
Module_UE
(
self
.
ue_ids
[
0
].
strip
())
svr
=
cls_module
.
Module_UE
(
self
.
svr_id
)
ueIP
=
ue
.
getIP
()
if
not
ueIP
:
return
(
False
,
f"UE
{
ue
.
getName
()
}
has no IP address"
)
svrIP
=
svr
.
getIP
()
if
not
svrIP
:
return
(
False
,
f"Iperf server
{
ue
.
getName
()
}
has no IP address"
)
server_filename
=
f'iperf_server_
{
self
.
testCase_id
}
_
{
ue
.
getName
()
}
.log'
ymlPath
=
CONTAINERS
.
yamlPath
[
0
].
split
(
'/'
)
logPath
=
f'../cmake_targets/log/
{
ymlPath
[
-
1
]
}
'
iperf_time
=
Iperf_ComputeTime
(
self
.
iperf_args
)
target_bitrate
,
iperf_opt
=
Iperf_ComputeModifiedBW
(
0
,
1
,
self
.
iperf_profile
,
self
.
iperf_args
)
t
=
iperf_time
*
2.5
with
cls_cmd
.
getConnection
(
'localhost'
)
as
local
:
local
.
run
(
f'mkdir -p
{
logPath
}
'
)
with
cls_cmd
.
getConnection
(
ue
.
getHost
())
as
cmd_ue
,
cls_cmd
.
getConnection
(
EPC
.
IPAddress
)
as
cmd_svr
:
cmd_ue
.
run
(
f'rm /tmp/
{
server_filename
}
'
,
reportNonZero
=
False
)
cmd_ue
.
run
(
f'
{
ue
.
getCmdPrefix
()
}
timeout -vk3
{
t
}
iperf -B
{
ueIP
}
-s -u -i1 >> /tmp/
{
server_filename
}
&'
,
timeout
=
t
)
cmd_svr
.
run
(
f'
{
svr
.
getCmdPrefix
()
}
timeout -vk3
{
t
}
iperf -c
{
ueIP
}
-B
{
svrIP
}
{
iperf_opt
}
-i1'
,
timeout
=
t
)
localPath
=
f'
{
os
.
getcwd
()
}
'
# note: copy iperf2 log to the directory for log collection
cmd_ue
.
copyin
(
f'/tmp/
{
server_filename
}
'
,
f'
{
localPath
}
/
{
logPath
}
/
{
server_filename
}
'
)
# note: copy iperf2 log to the current directory for log analysis and log collection
cmd_ue
.
copyin
(
f'/tmp/
{
server_filename
}
'
,
f'
{
localPath
}
/
{
server_filename
}
'
)
cmd_ue
.
run
(
f'rm /tmp/
{
server_filename
}
'
,
reportNonZero
=
False
)
success
,
msg
=
Iperf_analyzeV2UDP
(
server_filename
,
self
.
iperf_bitrate_threshold
,
self
.
iperf_packetloss_threshold
,
target_bitrate
)
ue_header
=
f'UE
{
ue
.
getName
()
}
(
{
ueIP
}
)'
logging
.
info
(
f'
\u001B
[1;37;45m iperf result for
{
ue_header
}
\u001B
[0m'
)
for
l
in
msg
.
split
(
'
\n
'
):
logging
.
info
(
f'
\u001B
[1;35m
{
l
}
\u001B
[0m'
)
if
success
:
HTML
.
CreateHtmlTestRowQueue
(
self
.
iperf_args
,
'OK'
,
[
f'
{
ue_header
}
\n
{
msg
}
'
])
else
:
HTML
.
CreateHtmlTestRowQueue
(
self
.
iperf_args
,
'KO'
,
[
f'
{
ue_header
}
\n
{
msg
}
'
])
self
.
AutoTerminateUEandeNB
(
HTML
,
RAN
,
EPC
,
CONTAINERS
)
def
AnalyzeLogFile_UE
(
self
,
UElogFile
,
HTML
,
RAN
):
def
AnalyzeLogFile_UE
(
self
,
UElogFile
,
HTML
,
RAN
):
if
(
not
os
.
path
.
isfile
(
f'./
{
UElogFile
}
'
)):
if
(
not
os
.
path
.
isfile
(
f'./
{
UElogFile
}
'
)):
return
-
1
return
-
1
...
...
ci-scripts/main.py
View file @
8ac2c874
...
@@ -281,6 +281,14 @@ def GetParametersFromXML(action):
...
@@ -281,6 +281,14 @@ def GetParametersFromXML(action):
logging
.
error
(
'test-case has wrong option '
+
CiTestObj
.
iperf_options
)
logging
.
error
(
'test-case has wrong option '
+
CiTestObj
.
iperf_options
)
CiTestObj
.
iperf_options
=
'check'
CiTestObj
.
iperf_options
=
'check'
elif
action
==
'Iperf2_Unidir'
:
CiTestObj
.
iperf_args
=
test
.
findtext
(
'iperf_args'
)
CiTestObj
.
ue_ids
=
test
.
findtext
(
'id'
).
split
(
' '
)
CiTestObj
.
svr_id
=
test
.
findtext
(
'svr_id'
)
or
None
CiTestObj
.
iperf_packetloss_threshold
=
test
.
findtext
(
'iperf_packetloss_threshold'
)
CiTestObj
.
iperf_bitrate_threshold
=
test
.
findtext
(
'iperf_bitrate_threshold'
)
or
'90'
CiTestObj
.
iperf_profile
=
test
.
findtext
(
'iperf_profile'
)
or
'balanced'
elif
action
==
'IdleSleep'
:
elif
action
==
'IdleSleep'
:
string_field
=
test
.
findtext
(
'idle_sleep_time_in_sec'
)
string_field
=
test
.
findtext
(
'idle_sleep_time_in_sec'
)
if
(
string_field
is
None
):
if
(
string_field
is
None
):
...
@@ -770,6 +778,8 @@ elif re.match('^TesteNB$', mode, re.IGNORECASE) or re.match('^TestUE$', mode, re
...
@@ -770,6 +778,8 @@ elif re.match('^TesteNB$', mode, re.IGNORECASE) or re.match('^TestUE$', mode, re
CiTestObj
.
Ping
(
HTML
,
RAN
,
EPC
,
CONTAINERS
)
CiTestObj
.
Ping
(
HTML
,
RAN
,
EPC
,
CONTAINERS
)
elif
action
==
'Iperf'
:
elif
action
==
'Iperf'
:
CiTestObj
.
Iperf
(
HTML
,
RAN
,
EPC
,
CONTAINERS
)
CiTestObj
.
Iperf
(
HTML
,
RAN
,
EPC
,
CONTAINERS
)
elif
action
==
'Iperf2_Unidir'
:
CiTestObj
.
Iperf2_Unidir
(
HTML
,
RAN
,
EPC
,
CONTAINERS
)
elif
action
==
'Initialize_HSS'
:
elif
action
==
'Initialize_HSS'
:
EPC
.
InitializeHSS
(
HTML
)
EPC
.
InitializeHSS
(
HTML
)
elif
action
==
'Terminate_HSS'
:
elif
action
==
'Terminate_HSS'
:
...
...
ci-scripts/xml_class_list.yml
View file @
8ac2c874
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
-
CheckStatusUE
-
CheckStatusUE
-
Ping
-
Ping
-
Iperf
-
Iperf
-
Iperf2_Unidir
-
Deploy_EPC
-
Deploy_EPC
-
Undeploy_EPC
-
Undeploy_EPC
-
Initialize_HSS
-
Initialize_HSS
...
...
ci-scripts/xml_files/container_4g_rfsim_fembms.xml
View file @
8ac2c874
...
@@ -72,8 +72,8 @@
...
@@ -72,8 +72,8 @@
</testCase>
</testCase>
<testCase
id=
"030011"
>
<testCase
id=
"030011"
>
<class>
Iperf
</class>
<class>
Iperf
2_Unidir
</class>
<desc>
Iperf UDP DL
</desc>
<desc>
Iperf
2
UDP DL
</desc>
<id>
rfsim4g_ue_fembms
</id>
<id>
rfsim4g_ue_fembms
</id>
<svr_id>
rfsim4g_enb_fembms
</svr_id>
<svr_id>
rfsim4g_enb_fembms
</svr_id>
<iperf_args>
-u -t 30 -b 2M
</iperf_args>
<iperf_args>
-u -t 30 -b 2M
</iperf_args>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment