Skip to content

Commit

Permalink
Avoid code duplication when connecting to Rados.
Browse files Browse the repository at this point in the history
Fixes #289

Signed-off-by: Gil Bregman <[email protected]>
  • Loading branch information
gbregman committed Oct 25, 2023
1 parent 122d39a commit c7eb44f
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 20 deletions.
8 changes: 1 addition & 7 deletions control/discovery.py
Original file line number Diff line number Diff line change
Expand Up @@ -319,13 +319,7 @@ def __init__(self, config):
if gateway_group else "nvmeof.state"
self.logger.info(f"log pages info from omap: {self.omap_name}")

ceph_pool = self.config.get("ceph", "pool")
ceph_conf = self.config.get("ceph", "config_file")
rados_id = self.config.get_with_default("ceph", "id", "")
conn = rados.Rados(conffile=ceph_conf, rados_id=rados_id)
conn.connect()
self.ioctx = conn.open_ioctx(ceph_pool)

self.ioctx = self.omap_state.open_rados_connection(config)
self.discovery_addr = self.config.get_with_default("discovery", "addr", "0.0.0.0")
self.discovery_port = self.config.get_with_default("discovery", "port", "8009")
if not self.discovery_addr or not self.discovery_port:
Expand Down
16 changes: 10 additions & 6 deletions control/state.py
Original file line number Diff line number Diff line change
Expand Up @@ -170,14 +170,9 @@ def __init__(self, config):
self.watch = None
gateway_group = self.config.get("gateway", "group")
self.omap_name = f"nvmeof.{gateway_group}.state" if gateway_group else "nvmeof.state"
ceph_pool = self.config.get("ceph", "pool")
ceph_conf = self.config.get("ceph", "config_file")
rados_id = self.config.get_with_default("ceph", "id", "")

try:
conn = rados.Rados(conffile=ceph_conf, rados_id=rados_id)
conn.connect()
self.ioctx = conn.open_ioctx(ceph_pool)
self.ioctx = self.open_rados_connection(self.config)
# Create a new gateway persistence OMAP object
with rados.WriteOpCtx() as write_op:
# Set exclusive parameter to fail write_op if object exists
Expand All @@ -198,6 +193,15 @@ def __exit__(self, exc_type, exc_value, traceback):
self.watch.close()
self.ioctx.close()

def open_rados_connection(self, config):
ceph_pool = config.get("ceph", "pool")
ceph_conf = config.get("ceph", "config_file")
rados_id = config.get_with_default("ceph", "id", "")
conn = rados.Rados(conffile=ceph_conf, rados_id=rados_id)
conn.connect()
ioctx = conn.open_ioctx(ceph_pool)
return ioctx

def get_local_version(self) -> int:
"""Returns local version."""
return self.version
Expand Down
10 changes: 3 additions & 7 deletions tests/test_state.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,10 @@
from control.state import LocalGatewayState, OmapGatewayState, GatewayStateHandler


@pytest.fixture(scope="module")
def ioctx(config):
@pytest.fixture
def ioctx(omap_state, config):
"""Opens IO context to ceph pool."""
ceph_pool = config.get("ceph", "pool")
ceph_conf = config.get("ceph", "config_file")
conn = rados.Rados(conffile=ceph_conf)
conn.connect()
ioctx = conn.open_ioctx(ceph_pool)
ioctx = omap_state.open_rados_connection(config)
yield ioctx
ioctx.close()

Expand Down

0 comments on commit c7eb44f

Please sign in to comment.