Skip to content

Commit

Permalink
Add Valkey support
Browse files Browse the repository at this point in the history
This is a copy of redis with names changed for Valkey.
  • Loading branch information
zzzeek committed Aug 7, 2024
1 parent d37bae2 commit e7251a1
Show file tree
Hide file tree
Showing 4 changed files with 144 additions and 2 deletions.
2 changes: 2 additions & 0 deletions README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ Pifpaf currently supports:
* `InfluxDB`_
* `Etcd`_ (with clustering)
* `Redis`_ (with sentinel mode)
* `Valkey`_
* `Elasticsearch`_
* `ZooKeeper`_
* `Gnocchi`_
Expand All @@ -47,6 +48,7 @@ Pifpaf currently supports:
.. _InfluxDB: http://influxdb.org
.. _Etcd: https://coreos.com/etcd/
.. _Redis: http://redis.io/
.. _Valkey: https://valkey.io/
.. _Elasticsearch: https://www.elastic.co/
.. _ZooKeeper: https://zookeeper.apache.org/
.. _Gnocchi: http://gnocchi.xyz
Expand Down
90 changes: 90 additions & 0 deletions pifpaf/drivers/valkey.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
# implied.
# See the License for the specific language governing permissions and
# limitations under the License.

import os

from pifpaf import drivers


class ValkeyDriver(drivers.Driver):

DEFAULT_PORT = 6379
DEFAULT_PORT_SENTINEL = 6380
DEFAULT_PASSWORD = ''

def __init__(self, port=DEFAULT_PORT,
sentinel=False, sentinel_port=DEFAULT_PORT_SENTINEL,
password=DEFAULT_PASSWORD, **kwargs):
"""Create a new Valkey server."""
super(ValkeyDriver, self).__init__(**kwargs)
self.port = port
self.sentinel = sentinel
self.sentinel_port = sentinel_port
self.password = password

@classmethod
def get_options(cls):
return [
{"param_decls": ["--port"],
"type": int,
"default": cls.DEFAULT_PORT,
"help": "port to use for Valkey"},
{"param_decls": ["--sentinel"],
"is_flag": True,
"help": "activate Valkey sentinel"},
{"param_decls": ["--sentinel-port"],
"type": int,
"default": cls.DEFAULT_PORT_SENTINEL,
"help": "port to use for Valkey sentinel"},
{"param_decls": ["--password"],
"default": cls.DEFAULT_PASSWORD,
"help": "Valkey and Valkey sentinel password"},
]

def _setUp(self):
super(ValkeyDriver, self)._setUp()
valkey_conf = """dir %s
port %d
""" % (self.tempdir, self.port)
if self.password:
valkey_conf += "requirepass %s\n" % self.password
c, _ = self._exec(
["valkey-server", "-"],
stdin=(valkey_conf).encode('ascii'),
wait_for_line="eady to accept connections")

if self.sentinel:
cfg = os.path.join(self.tempdir, "valkey-sentinel.conf")
sentinel_conf = """dir %s
port %d
sentinel monitor pifpaf localhost %d 1
""" % (self.tempdir, self.sentinel_port, self.port)
if self.password:
sentinel_conf += (
"sentinel auth-pass pifpaf %s\n" % self.password)
sentinel_conf += "requirepass %s\n" % self.password
with open(cfg, "w") as f:
f.write(sentinel_conf)

c, _ = self._exec(
["valkey-sentinel", cfg],
wait_for_line=r"# Sentinel (runid|ID) is")

self.addCleanup(self._kill, c)

self.putenv("VALKEY_SENTINEL_PORT",
str(self.sentinel_port))

self.putenv("VALKEY_PORT", str(self.port))
self.url = "valkey://localhost:%d" % self.port
self.putenv("URL", self.url)
47 changes: 47 additions & 0 deletions pifpaf/tests/test_drivers.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@
from pifpaf.drivers import redis
from pifpaf.drivers import s3rver
from pifpaf.drivers import swift
from pifpaf.drivers import valkey
from pifpaf.drivers import vault
from pifpaf.drivers import zookeeper

Expand Down Expand Up @@ -309,6 +310,52 @@ def test_redis_sentinel_with_password(self):
f.sentinel_port)
self._run("redis-cli -p %d -a secrete llen pifpaf" % f.port)

@testtools.skipUnless(spawn.find_executable("valkey-server"),
"valkey-server not found")
def test_valkey(self):
port = 6384
f = self.useFixture(valkey.ValkeyDriver(port=port))
self.assertEqual("valkey://localhost:%d" % port,
os.getenv("PIFPAF_URL"))
self.assertEqual(str(port), os.getenv("PIFPAF_VALKEY_PORT"))
self._run("valkey-cli -p %d llen pifpaf" % f.port)

@testtools.skipUnless(spawn.find_executable("valkey-server"),
"valkey-server not found")
def test_valkey_with_password(self):
port = 6384
f = self.useFixture(valkey.ValkeyDriver(port=port, password='secrete'))
self.assertEqual("valkey://localhost:%d" % port,
os.getenv("PIFPAF_URL"))
self.assertEqual(str(port), os.getenv("PIFPAF_VALKEY_PORT"))
self._run("valkey-cli -p %d -a secrete llen pifpaf" % f.port)

@testtools.skipUnless(spawn.find_executable("valkey-sentinel"),
"valkey-sentinel not found")
def test_valkey_sentinel(self):
port = 6385
f = self.useFixture(valkey.ValkeyDriver(sentinel=True, port=port))
self.assertEqual("valkey://localhost:%d" % port,
os.getenv("PIFPAF_URL"))
self.assertEqual(str(port), os.getenv("PIFPAF_VALKEY_PORT"))
self.assertEqual("6380", os.getenv("PIFPAF_VALKEY_SENTINEL_PORT"))
self._run("valkey-cli -p %d sentinel master pifpaf" % f.sentinel_port)
self._run("valkey-cli -p %d llen pifpaf" % f.port)

@testtools.skipUnless(spawn.find_executable("valkey-sentinel"),
"valkey-sentinel not found")
def test_valkey_sentinel_with_password(self):
port = 6385
f = self.useFixture(valkey.ValkeyDriver(sentinel=True, port=port,
password='secrete'))
self.assertEqual("valkey://localhost:%d" % port,
os.getenv("PIFPAF_URL"))
self.assertEqual(str(port), os.getenv("PIFPAF_VALKEY_PORT"))
self.assertEqual("6380", os.getenv("PIFPAF_VALKEY_SENTINEL_PORT"))
self._run("valkey-cli -p %d -a secrete sentinel master pifpaf" %
f.sentinel_port)
self._run("valkey-cli -p %d -a secrete llen pifpaf" % f.port)

@testtools.skipUnless(spawn.find_executable(
"zkServer.sh", path=":".join(zookeeper.ZooKeeperDriver.PATH)),
"ZooKeeper not found")
Expand Down
7 changes: 5 additions & 2 deletions setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,9 @@ classifier =
Topic :: Software Development :: Testing

[options]
packages =
pifpaf
packages = find_namespace:
include_package_data = true
zip_safe = false

install_requires =
daiquiri
Expand All @@ -29,6 +30,7 @@ install_requires =
fixtures
packaging
psutil
setuptools
xattr ; sys_platform != 'win32'

[options.extras_require]
Expand Down Expand Up @@ -63,6 +65,7 @@ pifpaf.daemons =
qdrouterd = pifpaf.drivers.qdrouterd:QdrouterdDriver
rabbitmq = pifpaf.drivers.rabbitmq:RabbitMQDriver
redis = pifpaf.drivers.redis:RedisDriver
valkey = pifpaf.drivers.valkey:ValkeyDriver
s3rver = pifpaf.drivers.s3rver:S3rverDriver
zookeeper = pifpaf.drivers.zookeeper:ZooKeeperDriver
vault = pifpaf.drivers.vault:VaultDriver
Expand Down

0 comments on commit e7251a1

Please sign in to comment.