Skip to content

Commit

Permalink
Add type hints for parameters and return
Browse files Browse the repository at this point in the history
Signed-off-by: jishi <jishi@redhat.com>
  • Loading branch information
linup2011 committed Nov 13, 2023
1 parent 3e8cb1d commit 89951e8
Show file tree
Hide file tree
Showing 13 changed files with 297 additions and 186 deletions.
15 changes: 8 additions & 7 deletions ovn-fake-multinode-utils/generate-hosts.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import yaml
import sys
from pathlib import Path
from typing import Dict


def usage(name):
Expand All @@ -18,13 +19,13 @@ def usage(name):
)


def generate_node_string(host, **kwargs):
def generate_node_string(host: str, **kwargs) -> None:
args = ' '.join(f"{key}={value}" for key, value in kwargs.items())
print(f"{host} {args}")


def generate_node(config, internal_iface, **kwargs):
host = config['name']
def generate_node(config: Dict, internal_iface: str, **kwargs) -> None:
host: str = config['name']
internal_iface = config.get('internal-iface', internal_iface)
generate_node_string(
host,
Expand All @@ -33,7 +34,7 @@ def generate_node(config, internal_iface, **kwargs):
)


def generate_tester(config, internal_iface):
def generate_tester(config: Dict, internal_iface: str) -> None:
ssh_key = config["ssh_key"]
ssh_key = Path(ssh_key).resolve()
generate_node(
Expand All @@ -44,11 +45,11 @@ def generate_tester(config, internal_iface):
)


def generate_controller(config, internal_iface):
def generate_controller(config: Dict, internal_iface: str) -> None:
generate_node(config, internal_iface, ovn_central="true")


def generate_workers(nodes_config, internal_iface):
def generate_workers(nodes_config: Dict, internal_iface: str):
for node_config in nodes_config:
host, node_config = helpers.get_node_config(node_config)
iface = node_config.get('internal-iface', internal_iface)
Expand All @@ -58,7 +59,7 @@ def generate_workers(nodes_config, internal_iface):
)


def generate(input_file, target, repo, branch):
def generate(input_file: str, target: str, repo: str, branch: str) -> None:
with open(input_file, 'r') as yaml_file:
config = yaml.safe_load(yaml_file)
user = config.get('user', 'root')
Expand Down
4 changes: 2 additions & 2 deletions ovn-fake-multinode-utils/get-config-value.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
import yaml


def parser_setup(parser):
def parser_setup(parser: argparse.ArgumentParser) -> None:
group = parser.add_argument_group()
group.add_argument(
"config",
Expand All @@ -23,7 +23,7 @@ def parser_setup(parser):
)


def get_config_value(args):
def get_config_value(args: argparse.Namespace) -> str:
with open(args.config, 'r') as config_file:
parsed = yaml.safe_load(config_file)

Expand Down
5 changes: 3 additions & 2 deletions ovn-fake-multinode-utils/process-monitor.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,13 @@
import psutil
import time

from typing import Dict

process_names = ['ovn-', 'ovs-', 'ovsdb-', 'etcd']


def monitor(suffix, out_file, exit_file):
data = {}
def monitor(suffix: str, out_file: str, exit_file: str) -> None:
data: Dict = {}
while True:
try:
if os.path.exists(exit_file):
Expand Down
88 changes: 59 additions & 29 deletions ovn-tester/cms/ovn_kubernetes/ovn_kubernetes.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@

from ovn_utils import DualStackSubnet
from ovn_workload import ChassisNode, Cluster
from typing import List, Optional

log = logging.getLogger(__name__)
ClusterBringupCfg = namedtuple('ClusterBringupCfg', ['n_pods_per_node'])
Expand All @@ -25,11 +26,11 @@


class Namespace:
def __init__(self, clusters, name, global_cfg):
def __init__(self, clusters, name: str, global_cfg):
self.clusters = clusters
self.nbctl = [cluster.nbctl for cluster in clusters]
self.ports = [[] for _ in range(len(clusters))]
self.enforcing = False
self.enforcing: bool = False
self.pg_def_deny_igr = [
nbctl.port_group_create(f'pg_deny_igr_{name}')
for nbctl in self.nbctl
Expand Down Expand Up @@ -65,7 +66,7 @@ def __init__(self, clusters, name, global_cfg):
self.name = name

@ovn_stats.timeit
def add_ports(self, ports, az=0):
def add_ports(self, ports: List[ovn_utils.LSPort], az: int = 0):
self.ports[az].extend(ports)
# Always add port IPs to the address set but not to the PGs.
# Simulate what OpenShift does, which is: create the port groups
Expand Down Expand Up @@ -105,7 +106,7 @@ def unprovision(self):
nbctl.port_group_del(self.sub_pg[i])
nbctl.address_set_del(self.sub_as[i])

def unprovision_ports(self, ports, az=0):
def unprovision_ports(self, ports: List[ovn_utils.LSPort], az: int = 0):
'''Unprovision a subset of ports in the namespace without having to
unprovision the entire namespace or any of its network policies.'''

Expand All @@ -123,7 +124,12 @@ def enforce(self):
nbctl.port_group_add_ports(self.pg_def_deny_egr[i], self.ports[i])
nbctl.port_group_add_ports(self.pg[i], self.ports[i])

def create_sub_ns(self, ports, global_cfg, az=0):
def create_sub_ns(
self,
ports: List[ovn_utils.LSPort],
global_cfg,
az: int = 0
):
n_sub_pgs = len(self.sub_pg[az])
suffix = f'{self.name}_{n_sub_pgs}'
pg = self.nbctl[az].port_group_create(f'sub_pg_{suffix}')
Expand All @@ -145,7 +151,7 @@ def create_sub_ns(self, ports, global_cfg, az=0):
return n_sub_pgs

@ovn_stats.timeit
def default_deny(self, family, az=0):
def default_deny(self, family: str, az: int = 0):
self.enforce()

addr_set = f'self.addr_set{family}.name'
Expand Down Expand Up @@ -185,7 +191,7 @@ def default_deny(self, family, az=0):
)

@ovn_stats.timeit
def allow_within_namespace(self, family, az=0):
def allow_within_namespace(self, family: str, az: int = 0):
self.enforce()

addr_set = f'self.addr_set{family}.name'
Expand All @@ -207,7 +213,7 @@ def allow_within_namespace(self, family, az=0):
)

@ovn_stats.timeit
def allow_cross_namespace(self, ns, family):
def allow_cross_namespace(self, ns, family: str):
self.enforce()

for az, nbctl in enumerate(self.nbctl):
Expand Down Expand Up @@ -235,7 +241,13 @@ def allow_cross_namespace(self, ns, family):
)

@ovn_stats.timeit
def allow_sub_namespace(self, src, dst, family, az=0):
def allow_sub_namespace(
self,
src: str,
dst: str,
family: str,
az: int = 0
):
self.nbctl[az].acl_add(
self.pg[az].name,
'to-lport',
Expand Down Expand Up @@ -280,7 +292,7 @@ def allow_from_external(
)

@ovn_stats.timeit
def check_enforcing_internal(self, az=0):
def check_enforcing_internal(self, az: int = 0):
# "Random" check that first pod can reach last pod in the namespace.
if len(self.ports[az]) > 1:
src = self.ports[az][0]
Expand All @@ -292,14 +304,14 @@ def check_enforcing_internal(self, az=0):
worker.ping_port(self.clusters[az], src, dst.ip6)

@ovn_stats.timeit
def check_enforcing_external(self, az=0):
def check_enforcing_external(self, az: int = 0):
if len(self.ports[az]) > 0:
dst = self.ports[az][0]
worker = dst.metadata
worker.ping_external(self.clusters[az], dst)

@ovn_stats.timeit
def check_enforcing_cross_ns(self, ns, az=0):
def check_enforcing_cross_ns(self, ns, az: int = 0):
if len(self.ports[az]) > 0 and len(ns.ports[az]) > 0:
dst = ns.ports[az][0]
src = self.ports[az][0]
Expand All @@ -309,13 +321,18 @@ def check_enforcing_cross_ns(self, ns, az=0):
if src.ip6 and dst.ip6:
worker.ping_port(self.clusters[az], src, dst.ip6)

def create_load_balancer(self, az=0):
def create_load_balancer(self, az: int = 0):
self.load_balancer = lb.OvnLoadBalancer(
f'lb_{self.name}', self.nbctl[az]
)

@ovn_stats.timeit
def provision_vips_to_load_balancers(self, backend_lists, version, az=0):
def provision_vips_to_load_balancers(
self,
backend_lists,
version: int,
az: int = 0
):
vip_ns_subnet = DEFAULT_NS_VIP_SUBNET
if version == 6:
vip_ns_subnet = DEFAULT_NS_VIP_SUBNET6
Expand Down Expand Up @@ -349,13 +366,13 @@ def __init__(self, cluster_cfg, central, brex_cfg, az):
cluster_cfg.gw_net,
az * (cluster_cfg.n_workers // cluster_cfg.n_az),
)
self.router = None
self.load_balancer = None
self.load_balancer6 = None
self.join_switch = None
self.last_selected_worker = 0
self.n_ns = 0
self.ts_switch = None
self.router: Optional[ovn_utils.LRouter] = None
self.load_balancer: Optional[lb.OvnLoadBalancer] = None
self.load_balancer6: Optional[lb.OvnLoadBalancer] = None
self.join_switch: Optional[ovn_utils.LSwitch] = None
self.last_selected_worker: int = 0
self.n_ns: int = 0
self.ts_switch: Optional[ovn_utils.LSwitch] = None

def add_cluster_worker_nodes(self, workers):
cluster_cfg = self.cluster_cfg
Expand Down Expand Up @@ -391,7 +408,7 @@ def add_cluster_worker_nodes(self, workers):
]
)

def create_cluster_router(self, rtr_name):
def create_cluster_router(self, rtr_name: str) -> None:
self.router = self.nbctl.lr_add(rtr_name)
self.nbctl.lr_set_options(
self.router,
Expand All @@ -400,7 +417,7 @@ def create_cluster_router(self, rtr_name):
},
)

def create_cluster_load_balancer(self, lb_name, global_cfg):
def create_cluster_load_balancer(self, lb_name: str, global_cfg):
if global_cfg.run_ipv4:
self.load_balancer = lb.OvnLoadBalancer(
lb_name, self.nbctl, self.cluster_cfg.vips
Expand All @@ -413,7 +430,7 @@ def create_cluster_load_balancer(self, lb_name, global_cfg):
)
self.load_balancer6.add_vips(self.cluster_cfg.static_vips6)

def create_cluster_join_switch(self, sw_name):
def create_cluster_join_switch(self, sw_name: str):
self.join_switch = self.nbctl.ls_add(sw_name, net_s=self.gw_net)

self.join_rp = self.nbctl.lr_port_add(
Expand Down Expand Up @@ -447,7 +464,7 @@ def unprovision_vips(self):
self.load_balancer6.clear_vips()
self.load_balancer6.add_vips(self.cluster_cfg.static_vips6)

def provision_lb_group(self, name='cluster-lb-group'):
def provision_lb_group(self, name: str = 'cluster-lb-group'):
self.lb_group = lb.OvnLoadBalancerGroup(name, self.nbctl)
for w in self.worker_nodes:
self.nbctl.ls_add_lbg(w.switch, self.lb_group.lbg)
Expand Down Expand Up @@ -484,7 +501,7 @@ def configure(self, physical_net):
)

@ovn_stats.timeit
def provision(self, cluster):
def provision(self, cluster: OVNKubernetesCluster):
self.connect(cluster.get_relay_connection_string())
self.wait(cluster.sbctl, cluster.cluster_cfg.node_timeout_s)

Expand Down Expand Up @@ -576,7 +593,11 @@ def provision(self, cluster):
cluster.nbctl.nat_add(self.gw_router, gr_gw, cluster.net)

@ovn_stats.timeit
def provision_port(self, cluster, passive=False):
def provision_port(
self,
cluster: OVNKubernetesCluster,
passive: bool = False
) -> ovn_utils.LSPort:
name = f'lp-{self.id}-{self.next_lport_index}'

log.info(f'Creating lport {name}')
Expand All @@ -597,7 +618,12 @@ def provision_port(self, cluster, passive=False):
return lport

@ovn_stats.timeit
def provision_load_balancers(self, cluster, ports, global_cfg):
def provision_load_balancers(
self,
cluster: OVNKubernetesCluster,
ports,
global_cfg
) -> None:
# Add one port IP as a backend to the cluster load balancer.
if global_cfg.run_ipv4:
port_ips = (
Expand Down Expand Up @@ -638,7 +664,11 @@ def provision_load_balancers(self, cluster, ports, global_cfg):
self.gw_load_balancer6.add_to_routers([self.gw_router.name])

@ovn_stats.timeit
def ping_external(self, cluster, port):
def ping_external(
self,
cluster: OVNKubernetesCluster,
port: ovn_utils.LSPort
):
if port.ip:
self.run_ping(cluster, 'ext-ns', port.ip)
if port.ip6:
Expand Down
10 changes: 6 additions & 4 deletions ovn-tester/ovn_context.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
import ovn_stats
import time

from typing import List

log = logging.getLogger(__name__)

active_context = None
Expand All @@ -13,10 +15,10 @@
class Context:
def __init__(
self,
clusters,
test_name,
max_iterations=1,
brief_report=False,
clusters: List,
test_name: str,
max_iterations: int = 1,
brief_report: bool = False,
test=None,
):
self.iteration = -1
Expand Down
3 changes: 2 additions & 1 deletion ovn-tester/ovn_ext_cmd.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,11 @@
from fnmatch import fnmatch
from io import StringIO
from itertools import chain
from typing import Dict, List


class ExtCmdUnit:
def __init__(self, conf, clusters):
def __init__(self, conf: Dict, clusters: List):
self.iteration = conf.get('iteration')
self.cmd = conf.get('cmd')
self.test = conf.get('test')
Expand Down
Loading

0 comments on commit 89951e8

Please sign in to comment.