summaryrefslogtreecommitdiffstats
path: root/src/pybind/mgr/snap_schedule/tests
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-23 16:45:13 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-23 16:45:13 +0000
commit389020e14594e4894e28d1eb9103c210b142509e (patch)
tree2ba734cdd7a243f46dda7c3d0cc88c2293d9699f /src/pybind/mgr/snap_schedule/tests
parentAdding upstream version 18.2.2. (diff)
downloadceph-389020e14594e4894e28d1eb9103c210b142509e.tar.xz
ceph-389020e14594e4894e28d1eb9103c210b142509e.zip
Adding upstream version 18.2.3.upstream/18.2.3upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/pybind/mgr/snap_schedule/tests')
-rw-r--r--src/pybind/mgr/snap_schedule/tests/conftest.py37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/pybind/mgr/snap_schedule/tests/conftest.py b/src/pybind/mgr/snap_schedule/tests/conftest.py
index 35255b8d4..92d4c9bc1 100644
--- a/src/pybind/mgr/snap_schedule/tests/conftest.py
+++ b/src/pybind/mgr/snap_schedule/tests/conftest.py
@@ -31,4 +31,41 @@ def db():
db.row_factory = sqlite3.Row
db.execute("PRAGMA FOREIGN_KEYS = 1")
db.executescript(Schedule.CREATE_TABLES)
+ _create_snap_schedule_kv_db(db)
+ _upgrade_snap_schedule_db_schema(db)
return db
+
+def _create_snap_schedule_kv_db(db):
+ SQL = """
+ CREATE TABLE IF NOT EXISTS SnapScheduleModuleKV (
+ key TEXT PRIMARY KEY,
+ value NOT NULL
+ ) WITHOUT ROWID;
+ INSERT OR IGNORE INTO SnapScheduleModuleKV (key, value) VALUES ('__snap_schedule_db_version', 1);
+ """
+ db.executescript(SQL)
+
+def _get_snap_schedule_db_version(db):
+ SQL = """
+ SELECT value
+ FROM SnapScheduleModuleKV
+ WHERE key = '__snap_schedule_db_version';
+ """
+ cur = db.execute(SQL)
+ row = cur.fetchone()
+ assert row is not None
+ return int(row[0])
+
+# add all upgrades here
+def _upgrade_snap_schedule_db_schema(db):
+ # add a column to hold the subvolume group name
+ if _get_snap_schedule_db_version(db) < 2:
+ SQL = """
+ ALTER TABLE schedules
+ ADD COLUMN group_name TEXT;
+ """
+ db.executescript(SQL)
+
+ # bump up the snap-schedule db version to 2
+ SQL = "UPDATE OR ROLLBACK SnapScheduleModuleKV SET value = ? WHERE key = '__snap_schedule_db_version';"
+ db.execute(SQL, (2,))