Skip to content

Latest commit

 

History

History

ztp

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 

Ecosystem Edge Core Team - Assisted ZTP

Overview

Assisted ZTP tests are developed for the purpose of testing the infrastructure operator and spoke cluster features

Prerequisites for running these tests:

  1. Infrastructure or assisted-service operator deployed via upstream or through multicluster engine or advanced cluster management operators
  2. Operand in healthy state 1

Test suites:

Name Description
operator Tests that are run directly against the operator on the hub cluster without need of spoke cluster resources
spoke Tests that are run on a combination of hub and spoke cluster resources

Internal pkgs

ztpconfig

  • Configuration structure used for embedding global test configuration
  • Contains configuration for spoke cluster under test and contains inputs for spoke kubeconfig and clusterimageset

find

  • Helper for finding various resources on the hub and spoke clusters such as pods, cluster versions and spoke names

installconfig

  • Utility for creating InstallConfig structs from unstructured representations of install-configs

meets

  • Tool for discovering various details about the environment
  • Used for determining if a given environment meets the criteria required by the test
  • Examples include minimum OCP versions to run against, connected or disconnected environments, network configuration of the cluster, etc.

Eco-goinfra pkgs

Inputs

  • ECO_ASSISTED_ZTP_SPOKE_KUBECONFIG: Location of the spoke cluster kubeconfig file
  • ECO_ASSISTED_ZTP_SPOKE_CLUSTERIMAGESET: The clusterimageset that should be used by real/mocked spoke cluster resources

Please refer to the project README for a list of global inputs - How to run

Running Assisted ZTP Test Suites

# export KUBECONFIG=</path/to/hub/kubeconfig>
# export ECO_TEST_FEATURES=ztp
# export ECO_TEST_LABELS="assisted,ztp"
# export ECO_ASSISTED_ZTP_SPOKE_KUBECONFIG=</path/to/spoke/kubeconfig>
# export ECO_ASSISTED_ZTP_SPOKE_CLUSTERIMAGESET=4.14
# make run-tests

Additional Information

Assisted ZTP tests have two different modes:

  1. Tests that can run on any cluster regardless of the cluster's configuration

These are test that can fully encompass their own setup and teardown

Example: Test that an AgentClusterInstall validation fails due to a specific input. (Reference)

Users can create the resources necessary to produce the desired state, check that the values are reported as intended, and then teardown the test resources.

  1. Tests that run against a cluster that has a specific configuration

These tests inspect the environment that they are running on and selectively include or exclude tests based on how the cluster is configured

Example: Test that a spoke can successfully be deployed with the OpenShiftSDN network type. (Reference)

After reading the AgentClusterInstall .spec.networking.NetworkType value, users can infer if the spoke was deployed with OpenShiftSDN or not. If true, the user can continue with the test. If false, the user will skip the test since the environment doesn't match the configuration needed.

Footnotes

  1. assisted-service and assisted-image-service pods in Ready state