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
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
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
spbro
OpenXG-RAN
Commits
85befc1c
Commit
85befc1c
authored
Nov 02, 2023
by
Raphael Defosseux
Committed by
Robert Schmidt
Nov 29, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
chore(ci): enable ASAN images build and push on Ubuntu
Signed-off-by:
Raphael Defosseux
<
raphael.defosseux@eurecom.fr
>
parent
2a82e36e
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
39 additions
and
30 deletions
+39
-30
ci-scripts/cls_containerize.py
ci-scripts/cls_containerize.py
+39
-30
No files found.
ci-scripts/cls_containerize.py
View file @
85befc1c
...
@@ -58,7 +58,7 @@ import cls_oaicitest
...
@@ -58,7 +58,7 @@ import cls_oaicitest
# Helper functions used here and in other classes
# Helper functions used here and in other classes
# (e.g., cls_cluster.py)
# (e.g., cls_cluster.py)
#-----------------------------------------------------------
#-----------------------------------------------------------
IMAGES
=
[
'oai-enb'
,
'oai-lte-ru'
,
'oai-lte-ue'
,
'oai-gnb'
,
'oai-nr-cuup'
,
'oai-gnb-aw2s'
,
'oai-nr-ue'
]
IMAGES
=
[
'oai-enb'
,
'oai-lte-ru'
,
'oai-lte-ue'
,
'oai-gnb'
,
'oai-nr-cuup'
,
'oai-gnb-aw2s'
,
'oai-nr-ue'
,
'oai-gnb-asan'
,
'oai-nr-ue-asan'
,
'oai-nr-cuup-asan'
]
def
CreateWorkspace
(
sshSession
,
sourcePath
,
ranRepository
,
ranCommitID
,
ranTargetBranch
,
ranAllowMerge
):
def
CreateWorkspace
(
sshSession
,
sourcePath
,
ranRepository
,
ranCommitID
,
ranTargetBranch
,
ranAllowMerge
):
if
ranCommitID
==
''
:
if
ranCommitID
==
''
:
...
@@ -364,25 +364,30 @@ class Containerize():
...
@@ -364,25 +364,30 @@ class Containerize():
self
.
cliBuildOptions
=
'--no-cache --disable-compression'
self
.
cliBuildOptions
=
'--no-cache --disable-compression'
# we always build the ran-build image with all targets
# we always build the ran-build image with all targets
imageNames
=
[(
'ran-build'
,
'build'
)]
# Creating a tupple with the imageName, the DockerFile prefix pattern, targetName and sanitized option
imageNames
=
[(
'ran-build'
,
'build'
,
'ran-build'
,
''
)]
result
=
re
.
search
(
'eNB'
,
self
.
imageKind
)
result
=
re
.
search
(
'eNB'
,
self
.
imageKind
)
# Creating a tupple with the imageName and the DockerFile prefix pattern on obelix
if
result
is
not
None
:
if
result
is
not
None
:
imageNames
.
append
((
'oai-enb'
,
'eNB'
))
imageNames
.
append
((
'oai-enb'
,
'eNB'
,
'oai-enb'
,
''
))
result
=
re
.
search
(
'gNB'
,
self
.
imageKind
)
result
=
re
.
search
(
'gNB'
,
self
.
imageKind
)
if
result
is
not
None
:
if
result
is
not
None
:
imageNames
.
append
((
'oai-gnb'
,
'gNB'
))
imageNames
.
append
((
'oai-gnb'
,
'gNB'
,
'oai-gnb'
,
''
))
result
=
re
.
search
(
'all'
,
self
.
imageKind
)
result
=
re
.
search
(
'all'
,
self
.
imageKind
)
if
result
is
not
None
:
if
result
is
not
None
:
imageNames
.
append
((
'oai-enb'
,
'eNB'
))
imageNames
.
append
((
'oai-enb'
,
'eNB'
,
'oai-enb'
,
''
))
imageNames
.
append
((
'oai-gnb'
,
'gNB'
))
imageNames
.
append
((
'oai-gnb'
,
'gNB'
,
'oai-gnb'
,
''
))
imageNames
.
append
((
'oai-nr-cuup'
,
'nr-cuup'
))
imageNames
.
append
((
'oai-nr-cuup'
,
'nr-cuup'
,
'oai-nr-cuup'
,
''
))
imageNames
.
append
((
'oai-lte-ue'
,
'lteUE'
))
imageNames
.
append
((
'oai-lte-ue'
,
'lteUE'
,
'oai-lte-ue'
,
''
))
imageNames
.
append
((
'oai-nr-ue'
,
'nrUE'
))
imageNames
.
append
((
'oai-nr-ue'
,
'nrUE'
,
'oai-nr-ue'
,
''
))
if
self
.
host
==
'Red Hat'
:
if
self
.
host
==
'Red Hat'
:
imageNames
.
append
((
'oai-physim'
,
'phySim'
))
imageNames
.
append
((
'oai-physim'
,
'phySim'
,
'oai-physim'
,
''
))
if
self
.
host
==
'Ubuntu'
:
if
self
.
host
==
'Ubuntu'
:
imageNames
.
append
((
'oai-lte-ru'
,
'lteRU'
))
imageNames
.
append
((
'oai-lte-ru'
,
'lteRU'
,
'oai-lte-ru'
,
''
))
# Building again the 5G images with Address Sanitizer
imageNames
.
append
((
'ran-build'
,
'build'
,
'ran-build-asan'
,
'--build-arg "SANITIZE_OPTION=--sanitize"'
))
imageNames
.
append
((
'oai-gnb'
,
'gNB'
,
'oai-gnb-asan'
,
'--build-arg "SANITIZE_OPTION=--sanitize"'
))
imageNames
.
append
((
'oai-nr-ue'
,
'nrUE'
,
'oai-nr-ue-asan'
,
'--build-arg "SANITIZE_OPTION=--sanitize"'
))
imageNames
.
append
((
'oai-nr-cuup'
,
'nr-cuup'
,
'oai-nr-cuup-asan'
,
'--build-arg "SANITIZE_OPTION=--sanitize"'
))
result
=
re
.
search
(
'build_cross_arm64'
,
self
.
imageKind
)
result
=
re
.
search
(
'build_cross_arm64'
,
self
.
imageKind
)
if
result
is
not
None
:
if
result
is
not
None
:
self
.
dockerfileprefix
=
'.ubuntu20.cross-arm64'
self
.
dockerfileprefix
=
'.ubuntu20.cross-arm64'
...
@@ -421,8 +426,8 @@ class Containerize():
...
@@ -421,8 +426,8 @@ class Containerize():
cmd
.
run
(
f"
{
self
.
cli
}
image prune --force"
)
cmd
.
run
(
f"
{
self
.
cli
}
image prune --force"
)
if
forceBaseImageBuild
:
if
forceBaseImageBuild
:
cmd
.
run
(
f"
{
self
.
cli
}
image rm
{
baseImage
}
:
{
baseTag
}
"
)
cmd
.
run
(
f"
{
self
.
cli
}
image rm
{
baseImage
}
:
{
baseTag
}
"
)
for
image
,
pattern
in
imageNames
:
for
image
,
pattern
,
name
,
option
in
imageNames
:
cmd
.
run
(
f"
{
self
.
cli
}
image rm
{
imag
e
}
:
{
imageTag
}
"
)
cmd
.
run
(
f"
{
self
.
cli
}
image rm
{
nam
e
}
:
{
imageTag
}
"
)
# Build the base image only on Push Events (not on Merge Requests)
# Build the base image only on Push Events (not on Merge Requests)
# On when the base image docker file is being modified.
# On when the base image docker file is being modified.
...
@@ -460,46 +465,50 @@ class Containerize():
...
@@ -460,46 +465,50 @@ class Containerize():
# Build the target image(s)
# Build the target image(s)
status
=
True
status
=
True
attemptedImages
=
[
'ran-base'
]
attemptedImages
=
[
'ran-base'
]
for
image
,
pattern
in
imageNames
:
for
image
,
pattern
,
name
,
option
in
imageNames
:
attemptedImages
+=
[
imag
e
]
attemptedImages
+=
[
nam
e
]
# the archived Dockerfiles have "ran-base:latest" as base image
# the archived Dockerfiles have "ran-base:latest" as base image
# we need to update them with proper tag
# we need to update them with proper tag
cmd
.
run
(
f'git checkout -- docker/Dockerfile.
{
pattern
}{
self
.
dockerfileprefix
}
'
)
cmd
.
run
(
f'sed -i -e "s#
{
baseImage
}
:latest#
{
baseImage
}
:
{
baseTag
}
#" docker/Dockerfile.
{
pattern
}{
self
.
dockerfileprefix
}
'
)
cmd
.
run
(
f'sed -i -e "s#
{
baseImage
}
:latest#
{
baseImage
}
:
{
baseTag
}
#" docker/Dockerfile.
{
pattern
}{
self
.
dockerfileprefix
}
'
)
if
image
!=
'ran-build'
:
# target images should use the proper ran-build image
if
image
!=
'ran-build'
and
"-asan"
in
name
:
cmd
.
run
(
f'sed -i -e "s#ran-build:latest#ran-build-asan:
{
imageTag
}
#" docker/Dockerfile.
{
pattern
}{
self
.
dockerfileprefix
}
'
)
elif
image
!=
'ran-build'
:
cmd
.
run
(
f'sed -i -e "s#ran-build:latest#ran-build:
{
imageTag
}
#" docker/Dockerfile.
{
pattern
}{
self
.
dockerfileprefix
}
'
)
cmd
.
run
(
f'sed -i -e "s#ran-build:latest#ran-build:
{
imageTag
}
#" docker/Dockerfile.
{
pattern
}{
self
.
dockerfileprefix
}
'
)
ret
=
cmd
.
run
(
f'
{
self
.
cli
}
build
{
self
.
cliBuildOptions
}
--target
{
image
}
--tag
{
image
}
:
{
imageTag
}
--file docker/Dockerfile.
{
pattern
}{
self
.
dockerfileprefix
}
. > cmake_targets/log/
{
imag
e
}
.log 2>&1'
,
timeout
=
1200
)
ret
=
cmd
.
run
(
f'
{
self
.
cli
}
build
{
self
.
cliBuildOptions
}
--target
{
image
}
--tag
{
name
}
:
{
imageTag
}
--file docker/Dockerfile.
{
pattern
}{
self
.
dockerfileprefix
}
{
option
}
. > cmake_targets/log/
{
nam
e
}
.log 2>&1'
,
timeout
=
1200
)
if
image
==
'ran-build'
and
ret
.
returncode
==
0
:
if
image
==
'ran-build'
and
ret
.
returncode
==
0
:
cmd
.
run
(
f"docker run --name test-log -d
{
imag
e
}
:
{
imageTag
}
/bin/true"
)
cmd
.
run
(
f"docker run --name test-log -d
{
nam
e
}
:
{
imageTag
}
/bin/true"
)
cmd
.
run
(
f"docker cp test-log:/oai-ran/cmake_targets/log/ cmake_targets/log/
{
imag
e
}
/"
)
cmd
.
run
(
f"docker cp test-log:/oai-ran/cmake_targets/log/ cmake_targets/log/
{
nam
e
}
/"
)
cmd
.
run
(
f"docker rm -f test-log"
)
cmd
.
run
(
f"docker rm -f test-log"
)
else
:
else
:
cmd
.
run
(
f"mkdir -p cmake_targets/log/
{
imag
e
}
"
)
cmd
.
run
(
f"mkdir -p cmake_targets/log/
{
nam
e
}
"
)
# check the status of the build
# check the status of the build
ret
=
cmd
.
run
(
f"
{
self
.
cli
}
image inspect --format=
\'
Size = {{{{.Size}}}} bytes
\'
{
imag
e
}
:
{
imageTag
}
"
)
ret
=
cmd
.
run
(
f"
{
self
.
cli
}
image inspect --format=
\'
Size = {{{{.Size}}}} bytes
\'
{
nam
e
}
:
{
imageTag
}
"
)
if
ret
.
returncode
!=
0
:
if
ret
.
returncode
!=
0
:
logging
.
error
(
'
\u001B
[1m Could not build properly '
+
imag
e
+
'
\u001B
[0m'
)
logging
.
error
(
'
\u001B
[1m Could not build properly '
+
nam
e
+
'
\u001B
[0m'
)
status
=
False
status
=
False
# Here we should check if the last container corresponds to a failed command and destroy it
# Here we should check if the last container corresponds to a failed command and destroy it
cmd
.
run
(
f"
{
self
.
cli
}
ps --quiet --filter
\"
status=exited
\"
-n1 | xargs --no-run-if-empty
{
self
.
cli
}
rm -f"
)
cmd
.
run
(
f"
{
self
.
cli
}
ps --quiet --filter
\"
status=exited
\"
-n1 | xargs --no-run-if-empty
{
self
.
cli
}
rm -f"
)
allImagesSize
[
imag
e
]
=
'N/A -- Build Failed'
allImagesSize
[
nam
e
]
=
'N/A -- Build Failed'
break
break
else
:
else
:
result
=
re
.
search
(
'Size *= *(?P<size>[0-9\-]+) *bytes'
,
cmd
.
getBefore
())
result
=
re
.
search
(
'Size *= *(?P<size>[0-9\-]+) *bytes'
,
cmd
.
getBefore
())
if
result
is
not
None
:
if
result
is
not
None
:
size
=
float
(
result
.
group
(
"size"
))
/
1000000
# convert to MB
size
=
float
(
result
.
group
(
"size"
))
/
1000000
# convert to MB
imageSizeStr
=
f'
{
size
:.
1
f
}
'
imageSizeStr
=
f'
{
size
:.
1
f
}
'
logging
.
debug
(
f'
\u001B
[1m
{
imag
e
}
size is
{
imageSizeStr
}
Mbytes
\u001B
[0m'
)
logging
.
debug
(
f'
\u001B
[1m
{
nam
e
}
size is
{
imageSizeStr
}
Mbytes
\u001B
[0m'
)
allImagesSize
[
imag
e
]
=
f'
{
imageSizeStr
}
Mbytes'
allImagesSize
[
nam
e
]
=
f'
{
imageSizeStr
}
Mbytes'
else
:
else
:
logging
.
debug
(
f'
{
imag
e
}
size is unknown'
)
logging
.
debug
(
f'
{
nam
e
}
size is unknown'
)
allImagesSize
[
imag
e
]
=
'unknown'
allImagesSize
[
nam
e
]
=
'unknown'
# Now pruning dangling images in between target builds
# Now pruning dangling images in between target builds
cmd
.
run
(
f"
{
self
.
cli
}
image prune --force"
)
cmd
.
run
(
f"
{
self
.
cli
}
image prune --force"
)
# Remove all intermediate build images and clean up
# Remove all intermediate build images and clean up
if
self
.
ranAllowMerge
and
forceBaseImageBuild
:
if
self
.
ranAllowMerge
and
forceBaseImageBuild
:
cmd
.
run
(
f"
{
self
.
cli
}
image rm
{
baseImage
}
:
{
baseTag
}
"
)
cmd
.
run
(
f"
{
self
.
cli
}
image rm
{
baseImage
}
:
{
baseTag
}
"
)
cmd
.
run
(
f"
{
self
.
cli
}
image rm ran-build:
{
imageTag
}
"
)
cmd
.
run
(
f"
{
self
.
cli
}
image rm ran-build:
{
imageTag
}
ran-build-asan:
{
imageTag
}
"
)
cmd
.
run
(
f"
{
self
.
cli
}
volume prune --force"
)
cmd
.
run
(
f"
{
self
.
cli
}
volume prune --force"
)
# create a zip with all logs
# create a zip with all logs
...
@@ -698,7 +707,7 @@ class Containerize():
...
@@ -698,7 +707,7 @@ class Containerize():
orgTag
=
'develop'
orgTag
=
'develop'
if
self
.
ranAllowMerge
:
if
self
.
ranAllowMerge
:
orgTag
=
'ci-temp'
orgTag
=
'ci-temp'
imageNames
=
[
'oai-enb'
,
'oai-gnb'
,
'oai-lte-ue'
,
'oai-nr-ue'
,
'oai-lte-ru'
,
'oai-nr-cuup'
]
imageNames
=
[
'oai-enb'
,
'oai-gnb'
,
'oai-lte-ue'
,
'oai-nr-ue'
,
'oai-lte-ru'
,
'oai-nr-cuup'
,
'oai-gnb-asan'
,
'oai-nr-ue-asan'
,
'oai-nr-cuup-asan'
]
for
image
in
imageNames
:
for
image
in
imageNames
:
tagToUse
=
ImageTagToUse
(
image
,
self
.
ranCommitID
,
self
.
ranBranch
,
self
.
ranAllowMerge
)
tagToUse
=
ImageTagToUse
(
image
,
self
.
ranCommitID
,
self
.
ranBranch
,
self
.
ranAllowMerge
)
mySSH
.
command
(
f'docker image tag
{
image
}
:
{
orgTag
}
{
imagePrefix
}
/
{
tagToUse
}
'
,
'\$'
,
5
)
mySSH
.
command
(
f'docker image tag
{
image
}
:
{
orgTag
}
{
imagePrefix
}
/
{
tagToUse
}
'
,
'\$'
,
5
)
...
...
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