/
How to run a weekly tests?

How to run a weekly tests?

Weekly tests are daily tests + additional tests.

These additional tests are

  • internal certificate (infrastructure-healthcheck)

  • versions (security)

  • basic_vm_stability and basic_cds_stability stability tests

  • cpu hog, memory hog, node_eviction (resiliency)

  • tern scan (sbom management and license scanning created by @Former user (Deleted) replaced by scancode.io)

internal certificates, versions and tern are described in https://docs.onap.org/projects/onap-integration/en/latest/usecases/release_automated_usecases.html

Stability and resiliency tests are documented in the official documentation: https://docs.onap.org/projects/onap-integration/en/latest/integration-tests.html#stability-resiliency-tests



if you want to run a full weekly chain, you can use the existing chained-ci schedule.

it will deploy a weekly lab then execute the test.

Please note that the tests executed in weekly chains could be executed also in daily, it is just by configuration.

The configuration can be at 2 levels....

At the moment all the constraints are done at the CI level

The core (daily test), versions (weekly defined at the CI level), are defined as follows:

ore: <<: *core <<: *trigger_rules



security_versions: <<: *security_versions <<: *security_rules <<: *weekly_rules



the weekly rules consist in looking for weekly in the pod name

.weekly_rules: &weekly_rules rules: - if: '$pod =~ /^onap_weekly.*/' when: always



Even if a stability and resiliency stage have been created, the management is the same (via the weekly rules)

onap_stability: <<: *onap_stability <<: *weekly_rules onap_resiliency: <<: *onap_resiliency <<: *weekly_rules

If the pod does not included weekly in its name, the stages are not triggered.

internal_certificate_check (kubernetes jobs) and versions (docker) are run exactly as any daily, see How to re-run a test on a daily platform?.

Stability, resiliency and tern testing require both some pre-installation steps performed by ansible roles.

For example onap-chaos-tests install the litmus chaos engine on the namespace.

Some scripts are also deployed through the ansible scripts:

Executing these tests consist then to execute these scripts that are deployed respectively in /home/debian/run_stability_tests.sh , /tmp/resiliency/run_chaos_tests.sh and /home/debian/run_tern.sh



The dashboard (https://gitlab.com/Orange-OpenSource/lfn/onap/xtesting-onap/-/blob/master/doc/generate_status.py) must also be adapted accordingly.

if ARGS.pod is not None: PODS = [ARGS.pod] # adapt tests according to the typ of tests: daily/weekly/gating if "weekly" in ARGS.pod: # Complete the list with weekly tests SECURITY_USECASES['tests'].add('versions') INFRA_HEALTHCHECK['tests'].add('internal_check_certs') PERIOD = 7 if "gating" in ARGS.pod: SECURITY_USECASES['tests'].remove('kube_hunter') # adapt test according to the version: guilin / honolulu / master if "guilin" in ARGS.pod: HEALTHCHECK['tests'].remove('dcaemod') HEALTHCHECK['tests'].remove('cps-healthcheck') SMOKE_USECASES['tests'].remove('basic_clamp') SMOKE_USECASES['tests'].remove('cds_resource_resolution') SMOKE_USECASES['tests'].remove('basic_cnf_macro') if "honolulu" in ARGS.pod: HEALTHCHECK['tests'].remove('cps-healthcheck') SMOKE_USECASES['tests'].remove('cds_resource_resolution') SMOKE_USECASES['tests'].remove('basic_cnf_macro') if "istanbul" in ARGS.pod: SMOKE_USECASES['tests'].remove('cds_resource_resolution') SMOKE_USECASES['tests'].remove('basic_cnf_macro') # Exclude Cloudify based use cases in Master (after istanbul) # TO BE updated as it is possible to perform gating on old versions # We should exclude cases according to the version not the pod name if "master" in ARGS.pod or "gating" in ARGS.pod: HEALTHCHECK['tests'].remove('dcaemod') SMOKE_USECASES['tests'].remove('5gbulkpm') SMOKE_USECASES['tests'].remove('cmpv2') SMOKE_USECASES['tests'].remove('basic_clamp')