summaryrefslogtreecommitdiffhomepage
path: root/test/test_static.py
diff options
context:
space:
mode:
Diffstat (limited to 'test/test_static.py')
-rw-r--r--test/test_static.py45
1 files changed, 45 insertions, 0 deletions
diff --git a/test/test_static.py b/test/test_static.py
index 94f790da..80f4c610 100644
--- a/test/test_static.py
+++ b/test/test_static.py
@@ -1,7 +1,9 @@
import os
+import shutil
import socket
import pytest
+from conftest import unit_run, unit_stop
from unit.applications.proto import TestApplicationProto
from unit.option import option
from unit.utils import waitforfiles
@@ -40,6 +42,49 @@ class TestStatic(TestApplicationProto):
}
)
+ def test_static_migration(self, skip_fds_check, temp_dir):
+ skip_fds_check(True, True, True)
+
+ def set_conf_version(path, version):
+ with open(path, 'w+') as f:
+ f.write(str(version))
+
+ with open(temp_dir + '/state/version', 'r') as f:
+ assert int(f.read().rstrip()) > 12500, 'current version'
+
+ assert 'success' in self.conf(
+ {"share": temp_dir + "/assets"}, 'routes/0/action'
+ ), 'configure migration 12500'
+
+ shutil.copytree(temp_dir + '/state', temp_dir + '/state_copy_12500')
+ set_conf_version(temp_dir + '/state_copy_12500/version', 12500)
+
+ assert 'success' in self.conf(
+ {"share": temp_dir + "/assets$uri"}, 'routes/0/action'
+ ), 'configure migration 12600'
+ shutil.copytree(temp_dir + '/state', temp_dir + '/state_copy_12600')
+ set_conf_version(temp_dir + '/state_copy_12600/version', 12600)
+
+ assert 'success' in self.conf(
+ {"share": temp_dir + "/assets"}, 'routes/0/action'
+ ), 'configure migration no version'
+ shutil.copytree(
+ temp_dir + '/state', temp_dir + '/state_copy_no_version'
+ )
+ os.remove(temp_dir + '/state_copy_no_version/version')
+
+ unit_stop()
+ unit_run(temp_dir + '/state_copy_12500')
+ assert self.get(url='/')['body'] == '0123456789', 'before 1.26.0'
+
+ unit_stop()
+ unit_run(temp_dir + '/state_copy_12600')
+ assert self.get(url='/')['body'] == '0123456789', 'after 1.26.0'
+
+ unit_stop()
+ unit_run(temp_dir + '/state_copy_no_version')
+ assert self.get(url='/')['body'] == '0123456789', 'before 1.26.0 2'
+
def test_static_index(self):
assert self.get(url='/index.html')['body'] == '0123456789', 'index'
assert self.get(url='/')['body'] == '0123456789', 'index 2'