SD-Core Testing
Test Framework
NG40
NG40 tool is used as RAN emulator in SD-Core testing. NG40 runs inside a VM which is connected to both Aether control plane and data plane. In testing scenarios that involve data plane verification, NG40 also emulates a few application servers which serve as the destinations of data packets.
A typical NG40 test case involves UE attaching, data plane verification and UE detaching. During the test NG40 acts as UEs and eNBs and talks to the mobile core to complete attach procedures for each UE it emulates. Then NG40 verifies that data plane works for each attached UE by sending traffic between UEs and application servers. Before finishing each test NG40 performs detach procedures for each attached UE.
Test cases
Currently the following NG40 test cases are implemented:
4G Tests:
4G_M2AS_PING_FIX
(attach, dl ping, detach)4G_M2AS_UDP
(attach, dl+ul udp traffic, detach)4G_M2AS_TCP
(attach, release, service request, dl+ul tcp traffic, detach)4G_AS2M_PAGING
(attach, release, dl udp traffic, detach)4G_M2AS_SRQ_UDP
(attach, release, service request, dl+ul udp traffic)4G_M2CN_PS
(combined IMSI/PTMSI attach, detach)4G_HO
(attach, relocate and dl ping, detach)4G_SCALE
(attach, dl ping, detach with multiple UEs)
5G Tests:
5G_SA_Register_Deregister
(registration, deregistration)5G_SA_Register
(registration, session establishment, deregistration)5G_SA_Release
(registration, session establishment, dl ping, release, deregistration)5G_SA_Activate_Release
(registration, session establishment, dl ping, release, service request, dl ping, deregistration)5G_SA_Scale
(registration, session establishment, dl ping, deregistration for multiple UEs)5G_SA_M2AS_ICMP
(registration, session establishment, dl ping, deregistration)5G_SA_M2AS_TCP
(registration, session establishment, dl+ul tcp traffic, deregistration)5G_SA_M2AS_UDP
(registration, session establishment, dl+ul udp traffic, deregistration)
All the test cases are parameterized and can take arguments to specify number
of UEs, attach/detach rate, traffic type/rate etc. For example, 4G_SCALE
test case can be configured as a mini scalability test which performs only 5
UE attaches in a patchset pre-merge test, while in the nightly tests it can
take different arguments to run 10K UE attaches with a high attach rate.
Test suites
The test cases are atomic testing units and can be combined to build test suites. The following test suites have been built so far:
functionality test suite
verifies basic functionality of the mobile core. 4G functionality suite runs 4G test case #1 to #8 including4G_SCALE
which attaches 5 UEs with 1/s attach rate. 5G functionality suite runs 5G test case #1 to #8 including5G_SA_Scale
which attaches 100 UEs with 1/s attach rate.scalability test suite
tests the system by scale and verifies system stability. It runs4G_SCALE
(or5G_SA_Scale
) which attaches a large number of UEs with high attach rate (16k UEs with 100/s rate on 4G CI pod, 1k UEs with 10/s rate on 4G staging pod, and 1k UEs with 1/s rate on 5G CI pod).performance test suite
measures performance of the control and data plane. It runs4G_SCALE
multiple times with different attach rates to understand how the system performs under different loads.
Robot Framework
Robot Framework was chosen to build test cases that involve interacting with not only NG40 but also other parts of the system. In these scenarios Robot Framework acts as a high level orchestrator which drives various components of the system using component specific libraries including NG40.
Currently the Integration test suite
is implemented using Robot
Framework. In the integration tests Robot Framework calls the ng40 library to
perform normal attach/detach procedures. Meanwhile it injects failures into
the system (container restarts, link down etc.) by calling functions
implemented in the k8s library.
The following integration tests are implemented at the moment:
Subscriber Attach with HSS Restart
Subscriber Attach with MME Restart
Subscriber Attach with SPGWC Restart
Subscriber Attach with PFCP Agent Restart
Note
More integration tests are being developed as part of Robot Framework
Test Schedules
Nightly Tests
SD-Core nightly tests are a set of jobs managed by Aether Jenkins. All four test suites we mentioned above are scheduled to run nightly.
functionality job (func)
runs NG40 test cases included in the functionality suite and verifies all tests pass.scalability job (scale)
runs the scalability test suite and reports the number of successful/failed attaches, detaches and pings.performance job (perf)
runs the performance test suite and reports SCTP heartbeat RTT, GTP ICMP RTT and call setup latency numbers.
And all these jobs can be scheduled on any of the Aether PODs including
ci-4g
pod, ci-5g
pod, staging
pod and qa
pod. By combining
the test type and test pod the following Jenkins jobs are generated:
1. ci-4g
pod: sdcore_func_ci-4g, sdcore_scale_ci-4g, sdcore_perf_ci-4g, sdcore_integ_ci-4g
1. ci-5g
pod: sdcore_func_ci-5g, sdcore_scale_ci-5g
2. staging
pod: func_staging, scale_staging, perf_staging, integ_staging
3. qa
pod: func_qa, scale_qa, perf_qa, integ_qa
Nightly Job structure
Take sdcore_scale_ci-4g job as an example. It runs the following downstream jobs:
omec_deploy_ci-4g: this job re-deploys the
ci-4g
pod with latest OMEC images.
Note
only the ci-4g
and ci-5g
pod jobs trigger deployment downstream job. No
re-deployment is performed on the staging and qa pod before the tests
ng40-test_ci-4g: this job executes the scalability test suite.
archive-artifacts_ci-4g: this job collects and uploads k8s and container logs.
post-results_ci-4g: this job collects the NG40 test logs/pcaps and pushes the test data to database. It also generates plots using Rscript for func and scale tests
The integration tests are written using Robot Framework so have a slightly different Jenkins Job structure. Take sdcore_integ_ci-4g as an example. It runs the following downstream jobs:
omec_deploy_ci-4g: this job executes the scalability test suite.
robotframework-test_ci-4g: this job is similar to ng40-test_ci-4g with the exception that instead of directly executing NG40 commands it calls robot framework to execute the test cases and publishes the test results using RobotPublisher Jenkins plugin. The robot results will also be copied to the upstream job and published there.
archive-artifacts_ci-4g: this job collects and uploads k8s and container logs.
post-results_ci-4g: this job collects the NG40 test logs/pcaps and pushes the test data to database. It also generates plots using Rscript for func and scale tests
Patchset Tests
SD-Core pre-merge verification covers the following public Github repos: c3po
,
Nucleus
, upf-epc
and the following private Github repos: spgw
. amf
,
smf
, ausf
, nssf
, nrf
, pcf
, udm
, udr
, webconsole
.
SD-Core CI verifies the following:
ONF CLA verification
License verification (FOSSA/Reuse)
NG40 tests
These jobs are automatically triggered by submitted or updated PR to the repos
above. They can also be triggered manually by commenting retest this please
to the PR. At this moment only CLI and NG40 verification are mandatory.
The NG40 verification are a set of jobs running on both opencord Jenkins and Aether Jenkins (private). The jobs run on opencord Jenkins include
omec_c3po_container_remote (public)
omec_Nucleus_container_remote (public)
omec_upf-epc_container_remote (public)
omec_spgw_container_remote (private, under member-only folder)
And the jobs run on Aether Jenkins include
c3po_premerge_ci-4g
Nucleus_premerge_ci-4g
upf-epc_premerge_ci-4g
spgw_premerge_ci-4g
amf_premerge_ci-5g
smf_premerge_ci-5g
ausf_premerge_ci-5g
nssf_premerge_ci-5g
nrf_premerge_ci-5g
pcf_premerge_ci-5g
udm_premerge_ci-5g
udr_premerge_ci-5g
webconsole_premerge_ci-5g
Patchset Job structure
Take c3po
jobs as an example. c3po
PR triggers a public job
omec_c3po_container_remote job running
on opencord Jenkins through Github webhooks, which then triggers a private job
c3po_premerge_ci-4g running on Aether Jenkins using a Jenkins plugin called
Parameterized Remote Trigger Plugin.
The private c3po
job runs the following downstream jobs sequentially:
docker-publish-github_c3po: this job downloads the
c3po
PR, runs docker build and publishes thec3po
docker images to Aether registry.omec_deploy_ci-4g: this job deploys the images built from previous job onto the omec
ci-4g
pod.ng40-test_ci-4g: this job executes the functionality test suite.
archive-artifacts_ci-4g: this job collects and uploads k8s and container logs.
After all the downstream jobs are finished, the upstream job (c3po_premerge_ci-4g) copies artifacts including k8s/container/ng40 logs and pcap files from downstream jobs and saves them as Jenkins job artifacts.
These artifacts are also copied to and published by the public job (omec_c3po_container_remote) on opencord Jenkins so that they can be accessed by the OMEC community.
Pre-merge jobs for other SD-Core repos share the same structure.
Post-merge
The following jobs are triggered as post-merge jobs when PRs are merged to SD-Core repos:
docker-publish-github-merge_c3po
docker-publish-github-merge_Nucleus
docker-publish-github-merge_upf-epc
docker-publish-github-merge_spgw
docker-publish-github-merge_amf
docker-publish-github-merge_smf
docker-publish-github-merge_ausf
docker-publish-github-merge_nssf
docker-publish-github-merge_nrf
docker-publish-github-merge_pcf
docker-publish-github-merge_udm
docker-publish-github-merge_udr
docker-publish-github-merge_webconsole
Again take the c3po
job as an example. The post-merge job (docker-publish-github-merge_c3po)
runs the following downstream jobs sequentially:
docker-publish-github_c3po: this is the same job as the one in pre-merge section. It checks out the latest
c3po
code, runs docker build and publishes thec3po
docker images to docker hub.
Note
the images for private repos are published to Aether registry instead of docker hub
c3po_postrelease: this job submits a patchset to aether-pod-configs repo for updating the CD pipeline with images published in the job above.
Post-merge jobs for other SD-Core repos share the same structure.