Skip to content

Commit

Permalink
Verify python source files with flake8.
Browse files Browse the repository at this point in the history
Fixes ceph#994

Signed-off-by: Gil Bregman <gbregman@il.ibm.com>
  • Loading branch information
gbregman committed Dec 26, 2024
1 parent db5a1d9 commit db7bb71
Showing 18 changed files with 483 additions and 506 deletions.
6 changes: 6 additions & 0 deletions .github/workflows/build-container.yml
Original file line number Diff line number Diff line change
@@ -31,6 +31,12 @@ jobs:
with:
submodules: recursive

- name: Install Flake8
run: pip install flake8

- name: Verify Python source files
run: make verify

- name: Build container images - spdk
run: make build SVC="spdk" SPDK_TARGET_ARCH=x86-64-v2

6 changes: 6 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
@@ -30,6 +30,12 @@ include mk/autohelp.mk
.DEFAULT_GOAL := all
all: setup $(ALL)

FLAKE_IGNORE = --extend-ignore E501,E251,E225,E711,E128,F541,W291,E211,E202,E265,E117,E111,E203,E127,E261,E222,E201,E262,E303,E302,E221,E231

verify: ## Run Python source files through flake8
@echo Verifying Python source files
flake8 $(FLAKE_IGNORE) control/*.py

setup: ## Configure huge-pages (requires sudo/root password)

@echo Setup core dump pattern as /tmp/coredump/core.*
13 changes: 7 additions & 6 deletions control/cephutils.py
Original file line number Diff line number Diff line change
@@ -32,6 +32,7 @@ def execute_ceph_monitor_command(self, cmd):
rply = cluster.mon_command(cmd, b'')
self.logger.debug(f"Monitor reply: {rply}")
return rply

def get_gw_id_owner_ana_group(self, pool, group, anagrp):
str = '{' + f'"prefix":"nvme-gw show", "pool":"{pool}", "group":"{group}"' + '}'
self.logger.debug(f"nvme-show string: {str}")
@@ -51,10 +52,10 @@ def get_gw_id_owner_ana_group(self, pool, group, anagrp):
return gw_id

def is_rebalance_supported(self):
return self.rebalance_supported
return self.rebalance_supported

def get_rebalance_ana_group(self):
return self.rebalance_ana_group
return self.rebalance_ana_group

def get_number_created_gateways(self, pool, group):
now = time.time()
@@ -168,13 +169,13 @@ def create_image(self, pool_name, image_name, size) -> bool:
rbd_inst = rbd.RBD()
try:
rbd_inst.create(ioctx, image_name, size)
except rbd.ImageExists as ex:
except rbd.ImageExists:
self.logger.exception(f"Image {pool_name}/{image_name} was created just now")
raise rbd.ImageExists(f"Image {pool_name}/{image_name} was just created by someone else, please retry",
errno = errno.EAGAIN)
except Exception as ex:
except Exception:
self.logger.exception(f"Can't create image {pool_name}/{image_name}")
raise ex
raise

return True

@@ -185,7 +186,7 @@ def get_image_size(self, pool_name, image_name) -> int:

with rados.Rados(conffile=self.ceph_conf, rados_id=self.rados_id) as cluster:
with cluster.open_ioctx(pool_name) as ioctx:
rbd_inst = rbd.RBD()
rbd.RBD()
try:
with rbd.Image(ioctx, image_name) as img:
image_size = img.size()
215 changes: 103 additions & 112 deletions control/discovery.py

Large diffs are not rendered by default.

621 changes: 310 additions & 311 deletions control/grpc.py

Large diffs are not rendered by default.

24 changes: 9 additions & 15 deletions control/rebalance.py
Original file line number Diff line number Diff line change
@@ -7,14 +7,8 @@
# Authors: leonidc@il.ibm.com
#

#import uuid
import errno
import threading
import time
import json
import re
from .utils import GatewayLogger
from .config import GatewayConfig
from .proto import gateway_pb2 as pb2

class Rebalance:
@@ -51,8 +45,8 @@ def auto_rebalance_task(self, death_event):
def find_min_loaded_group(self, grp_list)->int:
min_load = 2000
chosen_ana_group = 0
for ana_grp in self.gw_srv.ana_grp_ns_load :
if ana_grp in grp_list :
for ana_grp in self.gw_srv.ana_grp_ns_load:
if ana_grp in grp_list:
if self.gw_srv.ana_grp_ns_load[ana_grp] <= min_load:
min_load = self.gw_srv.ana_grp_ns_load[ana_grp]
chosen_ana_group = ana_grp
@@ -66,12 +60,12 @@ def find_min_loaded_group(self, grp_list)->int:
def find_min_loaded_group_in_subsys(self, nqn, grp_list)->int:
min_load = 2000
chosen_ana_group = 0
for ana_grp in grp_list :
if self.gw_srv.ana_grp_ns_load[ana_grp] == 0:
self.gw_srv.ana_grp_subs_load[ana_grp][nqn] = 0
return 0, ana_grp
for ana_grp in grp_list:
if self.gw_srv.ana_grp_ns_load[ana_grp] == 0:
self.gw_srv.ana_grp_subs_load[ana_grp][nqn] = 0
return 0, ana_grp
for ana_grp in self.gw_srv.ana_grp_subs_load :
if ana_grp in grp_list :
if ana_grp in grp_list:
if nqn in self.gw_srv.ana_grp_subs_load[ana_grp]:
if self.gw_srv.ana_grp_subs_load[ana_grp][nqn] <= min_load:
min_load = self.gw_srv.ana_grp_subs_load[ana_grp][nqn]
@@ -119,8 +113,8 @@ def rebalance_logic(self, request, context)->int:
self.logger.info(f"warning: empty group {ana_grp} of Deleting GW still appears Optimized")
return 1
else :
if not ongoing_scale_down_rebalance and (self.gw_srv.ana_grp_state[worker_ana_group] == pb2.ana_state.OPTIMIZED) :
# if my optimized ana group == worker-ana-group or worker-ana-group is also in optimized state on this GW machine
if not ongoing_scale_down_rebalance and (self.gw_srv.ana_grp_state[worker_ana_group] == pb2.ana_state.OPTIMIZED) :
# if my optimized ana group == worker-ana-group or worker-ana-group is also in optimized state on this GW machine
for nqn in self.gw_srv.ana_grp_subs_load[ana_grp] : #need to search all nqns not only inside the current load
num_ns_in_nqn = self.gw_srv.subsystem_nsid_bdev_and_uuid.get_namespace_count(nqn, None, 0)
target_subs_per_ana = num_ns_in_nqn/num_active_ana_groups
24 changes: 13 additions & 11 deletions control/utils.py
Original file line number Diff line number Diff line change
@@ -31,10 +31,13 @@ def get_value_from_key(e_type, keyval, ignore_case = False):
except IndexError:
pass

if ignore_case and val == None and type(keyval) == str:
val = get_value_from_key(e_type, keyval.lower(), False)
if ignore_case and val == None and type(keyval) == str:
val = get_value_from_key(e_type, keyval.upper(), False)
if val is not None or not ignore_case:
return val

if isinstance(keyval, str):
val = GatewayEnumUtils.get_value_from_key(e_type, keyval.lower(), False)
if val is None and isinstance(keyval, str):
val = GatewayEnumUtils.get_value_from_key(e_type, keyval.upper(), False)

return val

@@ -111,7 +114,7 @@ def is_valid_uuid(uuid_val) -> bool:

for u in uuid_parts:
try:
n = int(u, 16)
int(u, 16)
except ValueError:
return False

@@ -125,11 +128,11 @@ def is_valid_nqn(nqn):
NQN_UUID_PREFIX = "nqn.2014-08.org.nvmexpress:uuid:"
NQN_UUID_PREFIX_LENGTH = len(NQN_UUID_PREFIX)

if type(nqn) != str:
if not isinstance(nqn, str):
return (errno.EINVAL, f"Invalid type {type(nqn)} for NQN, must be a string")

try:
b = nqn.encode(encoding="utf-8")
nqn.encode(encoding="utf-8")
except UnicodeEncodeError:
return (errno.EINVAL, f"Invalid NQN \"{nqn}\", must have an UTF-8 encoding")

@@ -163,8 +166,8 @@ def is_valid_nqn(nqn):
year_part, month_part = date_part.split("-")
if len(year_part) != 4 or len(month_part) != 2:
return (errno.EINVAL, f"Invalid NQN \"{nqn}\": invalid date code")
n = int(year_part)
n = int(month_part)
int(year_part)
int(month_part)
except ValueError:
return (errno.EINVAL, f"Invalid NQN \"{nqn}\": invalid date code")

@@ -306,7 +309,7 @@ def rotate_backup_directories(dirname, count):
pass

def set_log_level(self, log_level):
if type(log_level) == str:
if isinstance(log_level, str):
log_level = log_level.upper()
self.logger.setLevel(log_level)
logger_parent = self.logger.parent
@@ -326,7 +329,6 @@ def log_file_rotate(src, dest):
GatewayLogger.logger.info(m)
for e in errs:
GatewayLogger.logger.error(e)

else:
os.rename(src, dest)

2 changes: 0 additions & 2 deletions tests/conftest.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
import pytest
import rados
from control.config import GatewayConfig
from control.state import OmapGatewayState


def pytest_addoption(parser):
3 changes: 2 additions & 1 deletion tests/ha/start_up.sh
Original file line number Diff line number Diff line change
@@ -13,7 +13,7 @@ if [ $# -ge 1 ]; then
fi
fi
echo ℹ️ Starting $SCALE nvmeof gateways
docker compose up -d --remove-orphans --scale nvmeof=$SCALE nvmeof
docker compose up -d --remove-orphans ceph

# Waiting for the ceph container to become healthy
while true; do
@@ -28,6 +28,7 @@ while true; do
fi
done
echo ✅ ceph is healthy
docker compose up -d --remove-orphans --scale nvmeof=$SCALE nvmeof

echo ℹ️ Increase debug logs level
docker compose exec -T ceph ceph config get mon.a
19 changes: 6 additions & 13 deletions tests/test_dhchap.py
Original file line number Diff line number Diff line change
@@ -4,13 +4,7 @@
from control.cli import main as cli
from control.cli import main_test as cli_test
from control.cephutils import CephUtils
from control.utils import GatewayUtils
from control.config import GatewayConfig
import grpc
from control.proto import gateway_pb2 as pb2
from control.proto import gateway_pb2_grpc as pb2_grpc
import os
import os.path

image = "mytestdevimage"
pool = "rbd"
@@ -64,15 +58,14 @@ def gateway(config):
gateway.serve()

# Bind the client and Gateway
channel = grpc.insecure_channel(f"{addr}:{port}")
grpc.insecure_channel(f"{addr}:{port}")
yield gateway.gateway_rpc

# Stop gateway
gateway.server.stop(grace=1)
gateway.gateway_rpc.gateway_state.delete_state()

def test_setup(caplog, gateway):
gw = gateway
caplog.clear()
cli(["subsystem", "add", "--subsystem", subsystem, "--no-group-append"])
assert f"create_subsystem {subsystem}: True" in caplog.text
@@ -196,13 +189,13 @@ def test_list_listeners(caplog, gateway):
listeners = cli_test(["listener", "list", "--subsystem", subsystem])
assert len(listeners.listeners) == 2
found = 0
for l in listeners.listeners:
if l.trsvcid == 5001:
for lstnr in listeners.listeners:
if lstnr.trsvcid == 5001:
found += 1
assert l.secure
elif l.trsvcid == 5002:
assert lstnr.secure
elif lstnr.trsvcid == 5002:
found += 1
assert not l.secure
assert not lstnr.secure
else:
assert False
assert found == 2
4 changes: 1 addition & 3 deletions tests/test_grpc.py
Original file line number Diff line number Diff line change
@@ -3,8 +3,6 @@
from control.server import GatewayServer
from control.cli import main as cli
from control.cephutils import CephUtils
import logging
import warnings

image = "mytestdevimage"
pool = "rbd"
@@ -69,7 +67,7 @@ def test_create_get_subsys(caplog, config):
"--r-megabytes-per-second", "5"])
assert f"Setting QOS limits of namespace 1 in {subsystem_prefix}0: Successful" in caplog.text
assert f"No previous QOS limits found, this is the first time the limits are set for namespace 1 on {subsystem_prefix}0" not in caplog.text

# add host to the first namespace
caplog.clear()
cli(["namespace", "add_host", "--subsystem", f"{subsystem_prefix}0", "--nsid", "1", "--host-nqn", f"{host_prefix}0"])
6 changes: 1 addition & 5 deletions tests/test_log_files.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
import pytest
from control.server import GatewayServer
from control.utils import GatewayLogger
import socket
from control.cli import main as cli
from control.cli import main_test as cli_test
import grpc
@@ -55,8 +53,7 @@ def gateway(config, request):
gateway.serve()

# Bind the client and Gateway
channel = grpc.insecure_channel(f"{addr}:{port}")
stub = pb2_grpc.GatewayStub(channel)
grpc.insecure_channel(f"{addr}:{port}")
yield gateway

# Stop gateway
@@ -82,7 +79,6 @@ def test_log_files(gateway):
assert f"spdk-{gw.name}" in spdk_files[0]

def test_log_files_disabled(gateway):
gw = gateway
cli(["subsystem", "add", "--subsystem", subsystem_prefix + "1"])
subs_list = cli_test(["--format", "text", "subsystem", "list"])
assert subs_list != None
1 change: 0 additions & 1 deletion tests/test_multi_gateway.py
Original file line number Diff line number Diff line change
@@ -134,4 +134,3 @@ def test_multi_gateway_coordination(config, image, conn):
assert nsListB[0]["uuid"] == uuid
assert nsListB[0]["rbd_image_name"] == image
assert nsListB[0]["rbd_pool_name"] == pool

2 changes: 0 additions & 2 deletions tests/test_nsid.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import pytest
import copy
import grpc
import json
@@ -8,7 +7,6 @@
from control.cephutils import CephUtils
from control.proto import gateway_pb2 as pb2
from control.proto import gateway_pb2_grpc as pb2_grpc
import spdk.rpc.bdev as rpc_bdev

image = "mytestdevimage"
pool = "rbd"
7 changes: 4 additions & 3 deletions tests/test_omap_lock.py
Original file line number Diff line number Diff line change
@@ -16,7 +16,7 @@
host_nqn_prefix = "nqn.2014-08.org.nvmexpress:uuid:22207d09-d8af-4ed2-84ec-a6d80b"
created_resource_count = 10

def setup_config(config, gw1_name, gw2_name, gw_group, update_notify ,update_interval_sec, disable_unlock, lock_duration,
def setup_config(config, gw1_name, gw2_name, gw_group, update_notify, update_interval_sec, disable_unlock, lock_duration,
sock1_name, sock2_name, port_inc):
"""Sets up the config objects for gateways A and B """

@@ -118,7 +118,8 @@ def conn_concurrent(config, request):
ceph_utils = CephUtils(config)

# Setup GatewayA and GatewayB configs
configA, configB = setup_config(config, "GatewayAAA", "GatewayBBB", "Group3", True, 5, False, 60,
configA, configB = setup_config(config, "GatewayAAA", "GatewayBBB", "Group3", update_notify, update_interval_sec,
disable_unlock, lock_duration,
"spdk_GatewayAAA.sock", "spdk_GatewayBBB.sock", 4)

addr = configA.get("gateway", "addr")
@@ -254,7 +255,7 @@ def test_trying_to_lock_twice(config, image, conn_lock_twice, caplog):
caplog.clear()
stubA, stubB = conn_lock_twice

with pytest.raises(Exception) as ex:
with pytest.raises(Exception):
create_resource_by_index(stubA, 100000, None)
create_resource_by_index(stubB, 100001, None)
assert "OMAP file unlock was disabled, will not unlock file" in caplog.text
Loading

0 comments on commit db7bb71

Please sign in to comment.