2021-01-08 13:41:50 +01:00
|
|
|
From c9268ec731371cdd7b2fc129ad111d9f73800752 Mon Sep 17 00:00:00 2001
|
2020-10-14 17:29:00 +02:00
|
|
|
From: =?UTF-8?q?Pablo=20Su=C3=A1rez=20Hern=C3=A1ndez?=
|
|
|
|
<psuarezhernandez@suse.com>
|
|
|
|
Date: Tue, 22 Sep 2020 15:15:51 +0100
|
|
|
|
Subject: [PATCH] Invalidate file list cache when cache file modified
|
|
|
|
time is in the future (bsc#1176397)
|
|
|
|
|
|
|
|
Add test_future_file_list_cache_file_ignored unit test
|
|
|
|
---
|
|
|
|
salt/fileserver/__init__.py | 2 +-
|
2021-01-08 13:41:50 +01:00
|
|
|
tests/unit/test_fileserver.py | 53 +++++++++++++++++++++++------------
|
|
|
|
2 files changed, 36 insertions(+), 19 deletions(-)
|
2020-10-14 17:29:00 +02:00
|
|
|
|
|
|
|
diff --git a/salt/fileserver/__init__.py b/salt/fileserver/__init__.py
|
2021-01-08 13:41:50 +01:00
|
|
|
index c8c417168f..b9e345d8c3 100644
|
2020-10-14 17:29:00 +02:00
|
|
|
--- a/salt/fileserver/__init__.py
|
|
|
|
+++ b/salt/fileserver/__init__.py
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -132,7 +132,7 @@ def check_file_list_cache(opts, form, list_cache, w_lock):
|
|
|
|
current_time,
|
|
|
|
file_mtime,
|
2020-10-14 17:29:00 +02:00
|
|
|
)
|
|
|
|
- age = 0
|
|
|
|
+ age = -1
|
|
|
|
else:
|
|
|
|
age = current_time - file_mtime
|
|
|
|
else:
|
|
|
|
diff --git a/tests/unit/test_fileserver.py b/tests/unit/test_fileserver.py
|
2021-01-08 13:41:50 +01:00
|
|
|
index 0bf30ee5cc..a1087bf4b0 100644
|
2020-10-14 17:29:00 +02:00
|
|
|
--- a/tests/unit/test_fileserver.py
|
|
|
|
+++ b/tests/unit/test_fileserver.py
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -1,14 +1,15 @@
|
|
|
|
-# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
|
|
:codeauthor: Joao Mesquita <jmesquita@sangoma.com>
|
|
|
|
"""
|
2020-10-14 17:29:00 +02:00
|
|
|
|
2021-01-08 13:41:50 +01:00
|
|
|
-# Import Python libs
|
|
|
|
-from __future__ import absolute_import, print_function, unicode_literals
|
|
|
|
|
|
|
|
-from salt import fileserver
|
2020-10-14 17:29:00 +02:00
|
|
|
+import datetime
|
|
|
|
+import os
|
|
|
|
+import time
|
|
|
|
|
2021-01-08 13:41:50 +01:00
|
|
|
-# Import Salt Testing libs
|
2020-10-14 17:29:00 +02:00
|
|
|
+import salt.utils.files
|
2021-01-08 13:41:50 +01:00
|
|
|
+from salt import fileserver
|
2020-10-14 17:29:00 +02:00
|
|
|
+from tests.support.helpers import with_tempdir
|
2021-01-08 13:41:50 +01:00
|
|
|
from tests.support.mixins import LoaderModuleMockMixin
|
|
|
|
from tests.support.unit import TestCase
|
2020-10-14 17:29:00 +02:00
|
|
|
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -31,22 +32,38 @@ class MapDiffTestCase(TestCase):
|
2020-10-14 17:29:00 +02:00
|
|
|
assert fileserver.diff_mtime_map(map1, map2) is True
|
2021-01-08 13:41:50 +01:00
|
|
|
|
|
|
|
|
|
|
|
-class VCSBackendWhitelistCase(TestCase, LoaderModuleMockMixin):
|
2020-10-14 17:29:00 +02:00
|
|
|
+class VCSBackendWhitelistCase(TestCase):
|
2021-01-08 13:41:50 +01:00
|
|
|
def setup_loader_modules(self):
|
|
|
|
return {fileserver: {}}
|
|
|
|
|
|
|
|
- def test_whitelist(self):
|
2020-10-14 17:29:00 +02:00
|
|
|
+ @with_tempdir()
|
|
|
|
+ def test_future_file_list_cache_file_ignored(self, cachedir):
|
2021-01-08 13:41:50 +01:00
|
|
|
opts = {
|
|
|
|
- "fileserver_backend": ["roots", "git", "hgfs", "svn"],
|
2020-10-14 17:29:00 +02:00
|
|
|
+ "fileserver_backend": ["roots"],
|
|
|
|
+ "cachedir": cachedir,
|
2021-01-08 13:41:50 +01:00
|
|
|
"extension_modules": "",
|
|
|
|
}
|
|
|
|
- fs = fileserver.Fileserver(opts)
|
|
|
|
- assert fs.servers.whitelist == [
|
|
|
|
- "git",
|
|
|
|
- "gitfs",
|
|
|
|
- "hg",
|
|
|
|
- "hgfs",
|
|
|
|
- "svn",
|
|
|
|
- "svnfs",
|
|
|
|
- "roots",
|
|
|
|
- ], fs.servers.whitelist
|
2020-10-14 17:29:00 +02:00
|
|
|
+
|
|
|
|
+ back_cachedir = os.path.join(cachedir, "file_lists/roots")
|
|
|
|
+ os.makedirs(os.path.join(back_cachedir))
|
|
|
|
+
|
|
|
|
+ # Touch a couple files
|
|
|
|
+ for filename in ("base.p", "foo.txt"):
|
|
|
|
+ with salt.utils.files.fopen(
|
|
|
|
+ os.path.join(back_cachedir, filename), "wb"
|
|
|
|
+ ) as _f:
|
|
|
|
+ if filename == "base.p":
|
|
|
|
+ _f.write(b"\x80")
|
|
|
|
+
|
|
|
|
+ # Set modification time to file list cache file to 1 year in the future
|
|
|
|
+ now = datetime.datetime.utcnow()
|
|
|
|
+ future = now + datetime.timedelta(days=365)
|
|
|
|
+ mod_time = time.mktime(future.timetuple())
|
|
|
|
+ os.utime(os.path.join(back_cachedir, "base.p"), (mod_time, mod_time))
|
|
|
|
+
|
|
|
|
+ list_cache = os.path.join(back_cachedir, "base.p")
|
|
|
|
+ w_lock = os.path.join(back_cachedir, ".base.w")
|
|
|
|
+ ret = fileserver.check_file_list_cache(opts, "files", list_cache, w_lock)
|
|
|
|
+ assert (
|
|
|
|
+ ret[1] is True
|
|
|
|
+ ), "Cache file list cache file is not refreshed when future modification time"
|
|
|
|
--
|
2021-01-08 13:41:50 +01:00
|
|
|
2.29.2
|
2020-10-14 17:29:00 +02:00
|
|
|
|
|
|
|
|