forked from cnti-testcatalog/testsuite
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
config: introduce new config format and parser
For supporting multiple deployments in one cnf and improving overall config usability and structure - new config format has to be introduced. Some existing parameters usage need to be changed for easier adaptation. This change does not replace the old config format. Refs: cnti-testcatalog#2121 Signed-off-by: Konstantin Yarovoy <[email protected]>
- Loading branch information
Konstantin Yarovoy
committed
Aug 19, 2024
1 parent
11aeb49
commit 1d0b3c9
Showing
13 changed files
with
284 additions
and
88 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
--- | ||
config_version: "v2" | ||
common: | ||
container_names: | ||
- name: coredns | ||
rolling_update_test_tag: "1.8.0" | ||
rolling_downgrade_test_tag: 1.6.7 | ||
rolling_version_change_test_tag: 1.8.0 | ||
rollback_from_tag: 1.8.0 | ||
|
||
deployments: | ||
helm_charts: | ||
- name: coredns | ||
helm_repo_name: stable | ||
helm_repo_url: https://cncf.gitlab.io/stable | ||
helm_chart_name: coredns | ||
# helm_dirs: | ||
# - name: envoy | ||
# helm_directory: ../example-cnfs/envoy/envoy/ | ||
# manifests: | ||
# - name: nginx | ||
# manifest_directory: ../sample_cnfs/ndn-mutable-configmap/manifests | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,211 @@ | ||
require "yaml" | ||
require "../utils.cr" | ||
|
||
module CNFInstall | ||
module Config | ||
@[YAML::Serializable::Options(emit_nulls: true)] | ||
alias AnyDeploymentConfig = HelmChartConfig | HelmDirectoryConfig | ManifestDirectoryConfig | ||
|
||
class ConfigBase | ||
include YAML::Serializable | ||
include YAML::Serializable::Strict | ||
end | ||
|
||
class Config < ConfigBase | ||
getter config_version : String, | ||
common : CommonParameters = CommonParameters.new(), | ||
dynamic : DynamicParameters = DynamicParameters.new(), | ||
deployments : DeploymentsConfig | ||
end | ||
|
||
class CommonParameters < ConfigBase | ||
getter container_names : Array(ContainerParameters) | Nil, | ||
white_list_container_names : Array(String) | Nil, | ||
docker_insecure_registries : Array(String) | Nil, | ||
image_registry_fqdns : Hash(String, String) | Nil, | ||
five_g_parameters : FiveGParameters | Nil | ||
def initialize() | ||
end | ||
end | ||
|
||
class DynamicParameters < ConfigBase | ||
property source_cnf_dir : String?, | ||
destination_cnf_dir : String?, | ||
install_method : Tuple(CNFInstall::InstallMethod, String) | Nil | ||
def initialize() | ||
end | ||
end | ||
|
||
class DeploymentsConfig < ConfigBase | ||
getter helm_charts : Array(HelmChartConfig) = [] of HelmChartConfig, | ||
helm_dirs : Array(HelmDirectoryConfig) = [] of HelmDirectoryConfig, | ||
manifests : Array(ManifestDirectoryConfig) = [] of ManifestDirectoryConfig | ||
# deployments.current and all related functionality should be removed with new installation process. | ||
@@current : AnyDeploymentConfig | Nil | ||
|
||
def after_initialize | ||
if @helm_charts.empty? && @helm_dirs.empty? && @manifests.empty? | ||
raise YAML::Error.new("At least one deployment should be configured") | ||
end | ||
|
||
# To be removed with new installation process. | ||
if @helm_charts.size + @helm_dirs.size + @manifests.size > 1 | ||
raise YAML::Error.new("Multiple deployments are not supported yet") | ||
end | ||
|
||
deployment_names = Set(String).new | ||
{@helm_charts, @helm_dirs, @manifests}.each do |deployment_array| | ||
if deployment_array && !deployment_array.empty? | ||
|
||
# To be removed with new installation process. | ||
@@current = deployment_array[0] | ||
|
||
deployment_array.each do |deployment| | ||
if deployment_names.includes?(deployment.name) | ||
raise YAML::Error.new("Deployment names should be unique: \"#{deployment.name}\"") | ||
else | ||
deployment_names.add(deployment.name) | ||
end | ||
end | ||
end | ||
end | ||
end | ||
|
||
def get_deployment_param(param : Symbol) : String | ||
current = @@current.not_nil! | ||
result = case current | ||
when HelmChartConfig | ||
case param | ||
when :name then current.name | ||
when :helm_repo_name then current.helm_repo_name | ||
when :helm_repo_url then current.helm_repo_url | ||
when :helm_chart_name then current.helm_chart_name | ||
when :helm_values then current.helm_values | ||
when :namespace then current.namespace | ||
else raise ArgumentError.new("Unknown symbol for #{current.class}: #{param}") | ||
end | ||
when HelmDirectoryConfig | ||
case param | ||
when :name then current.name | ||
when :helm_directory then current.helm_directory | ||
when :helm_values then current.helm_values | ||
when :namespace then current.namespace | ||
else raise ArgumentError.new("Unknown symbol for #{current.class}: #{param}") | ||
end | ||
when ManifestDirectoryConfig | ||
case param | ||
when :name then current.name | ||
when :manifest_directory then current.manifest_directory | ||
else raise ArgumentError.new("Unknown symbol for #{current.class}: #{param}") | ||
end | ||
end | ||
result || "" | ||
end | ||
|
||
def get_install_method | ||
case @@current | ||
when HelmChartConfig | ||
{CNFInstall::InstallMethod::HelmChart, get_deployment_param(:helm_chart_name)} | ||
when HelmDirectoryConfig | ||
full_helm_directory = Path[CNF_DIR + "/" + get_deployment_param(:name) + "/" + CNFManager.sandbox_helm_directory(get_deployment_param(:helm_directory))].expand.to_s | ||
{CNFInstall::InstallMethod::HelmDirectory, full_helm_directory} | ||
when ManifestDirectoryConfig | ||
full_manifest_directory = Path[CNF_DIR + "/" + get_deployment_param(:name) + "/" + CNFManager.sandbox_helm_directory(get_deployment_param(:manifest_directory))].expand.to_s | ||
{CNFInstall::InstallMethod::ManifestDirectory, full_manifest_directory} | ||
else | ||
raise YAML::Error.new("At least one deployment should be configured") | ||
end | ||
end | ||
end | ||
|
||
class DeploymentConfig < ConfigBase | ||
getter name : String | ||
end | ||
|
||
class HelmDeploymentConfig < DeploymentConfig | ||
getter helm_values : String?, | ||
namespace : String? | ||
end | ||
|
||
class HelmChartConfig < HelmDeploymentConfig | ||
getter helm_repo_name : String, | ||
helm_repo_url : String, | ||
helm_chart_name : String | ||
end | ||
|
||
class HelmDirectoryConfig < HelmDeploymentConfig | ||
getter helm_directory : String | ||
end | ||
|
||
class ManifestDirectoryConfig < DeploymentConfig | ||
getter manifest_directory : String | ||
end | ||
|
||
class FiveGParameters < ConfigBase | ||
getter amf_label : String?, | ||
smf_label : String?, | ||
upf_label : String?, | ||
ric_label : String?, | ||
amf_service_name : String?, | ||
mmc : String?, | ||
mnc : String?, | ||
sst : String?, | ||
sd : String?, | ||
tac : String?, | ||
protectionScheme : String?, | ||
publicKey : String?, | ||
publicKeyId : String?, | ||
routingIndicator : String?, | ||
enabled : String?, | ||
count : String?, | ||
initialMSISDN : String?, | ||
key : String?, | ||
op : String?, | ||
opType : String?, | ||
type : String?, | ||
apn : String?, | ||
emergency : String? | ||
end | ||
|
||
class ContainerParameters < ConfigBase | ||
getter name : String?, | ||
rolling_update_test_tag : String?, | ||
rolling_downgrade_test_tag : String?, | ||
rolling_version_change_test_tag : String?, | ||
rollback_from_tag : String? | ||
end | ||
|
||
def self.parse_cnf_config_from_file(path_to_config) | ||
yaml_content = File.read(path_to_config) | ||
config_dir = CNFManager.ensure_cnf_testsuite_dir(path_to_config) | ||
begin | ||
parse_cnf_config_from_yaml(yaml_content, config_dir) | ||
rescue exception | ||
stdout_failure "Error during parsing CNF config on #{path_to_config}" | ||
stdout_failure exception.message | ||
stdout_failure "Please check your config according to the config template." | ||
exit 1 | ||
end | ||
end | ||
|
||
def self.parse_cnf_config_from_yaml(yaml_content, config_dir) | ||
config = Config.from_yaml(yaml_content) | ||
|
||
unless config.dynamic.source_cnf_dir | ||
config.dynamic.source_cnf_dir = config_dir | ||
end | ||
|
||
unless config.dynamic.install_method | ||
config.dynamic.install_method = config.deployments.get_install_method | ||
end | ||
|
||
unless config.dynamic.destination_cnf_dir | ||
deployment_name = config.deployments.get_deployment_param(:name) | ||
current_dir = FileUtils.pwd | ||
config.dynamic.destination_cnf_dir = "#{current_dir}/#{CNF_DIR}/#{deployment_name}" | ||
end | ||
|
||
config | ||
end | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.