summaryrefslogtreecommitdiffhomepage
path: root/test/test_static_variables.py
diff options
context:
space:
mode:
authorAndrei Belov <defan@nginx.com>2021-11-18 17:04:04 +0300
committerAndrei Belov <defan@nginx.com>2021-11-18 17:04:04 +0300
commitb400ccd1aa8eeb6a5de1707e0bb8c3d417fe69b7 (patch)
tree60ff49ffc16ef7cb3aad1beb2d78f051a8794cdf /test/test_static_variables.py
parentfafd44166d9e835e91a4c5668048308ce99a62bd (diff)
parentb77895d1c7d6cd4826ac7427c91baa95b998a912 (diff)
downloadunit-b400ccd1aa8eeb6a5de1707e0bb8c3d417fe69b7.tar.gz
unit-b400ccd1aa8eeb6a5de1707e0bb8c3d417fe69b7.tar.bz2
Merged with the default branch.1.26.0-1
Diffstat (limited to 'test/test_static_variables.py')
-rw-r--r--test/test_static_variables.py79
1 files changed, 79 insertions, 0 deletions
diff --git a/test/test_static_variables.py b/test/test_static_variables.py
new file mode 100644
index 00000000..e7e1629c
--- /dev/null
+++ b/test/test_static_variables.py
@@ -0,0 +1,79 @@
+import os
+from pathlib import Path
+
+import pytest
+from unit.applications.proto import TestApplicationProto
+
+
+class TestStaticVariables(TestApplicationProto):
+ prerequisites = {}
+
+ @pytest.fixture(autouse=True)
+ def setup_method_fixture(self, temp_dir):
+ os.makedirs(temp_dir + '/assets/dir')
+ os.makedirs(temp_dir + '/assets/d$r')
+ Path(temp_dir + '/assets/index.html').write_text('0123456789')
+ Path(temp_dir + '/assets/dir/file').write_text('file')
+ Path(temp_dir + '/assets/d$r/file').write_text('d$r')
+
+ self._load_conf(
+ {
+ "listeners": {"*:7080": {"pass": "routes"}},
+ "routes": [{"action": {"share": temp_dir + "/assets$uri"}}],
+ }
+ )
+
+ def update_share(self, share):
+ if isinstance(share, list):
+ return self.conf(share, 'routes/0/action/share')
+
+ return self.conf('"' + share + '"', 'routes/0/action/share')
+
+ def test_static_variables(self, temp_dir):
+ assert self.get(url='/index.html')['status'] == 200
+ assert self.get(url='/d$r/file')['status'] == 200
+
+ assert 'success' in self.update_share('$uri')
+ assert self.get(url=temp_dir + '/assets/index.html')['status'] == 200
+
+ assert 'success' in self.update_share(temp_dir + '/assets${uri}')
+ assert self.get(url='/index.html')['status'] == 200
+
+ def test_static_variables_array(self, temp_dir):
+ assert 'success' in self.update_share(
+ [temp_dir + '/assets$uri', '$uri']
+ )
+
+ assert self.get(url='/dir/file')['status'] == 200
+ assert self.get(url=temp_dir + '/assets/index.html')['status'] == 200
+ assert self.get(url='/blah')['status'] == 404
+
+ assert 'success' in self.conf(
+ {
+ "share": [temp_dir + '/assets$uri', '$uri'],
+ "fallback": {"return": 201},
+ },
+ 'routes/0/action',
+ )
+
+ assert self.get(url='/dir/file')['status'] == 200
+ assert self.get(url=temp_dir + '/assets/index.html')['status'] == 200
+ assert self.get(url='/dir/blah')['status'] == 201
+
+ def test_static_variables_buildin_start(self, temp_dir):
+ assert 'success' in self.update_share('$uri/assets/index.html')
+ assert self.get(url=temp_dir)['status'] == 200
+
+ def test_static_variables_buildin_mid(self, temp_dir):
+ assert 'success' in self.update_share(temp_dir + '$uri/index.html')
+ assert self.get(url='/assets')['status'] == 200
+
+ def test_static_variables_buildin_end(self):
+ assert self.get(url='/index.html')['status'] == 200
+
+ def test_static_variables_invalid(self, temp_dir):
+ assert 'error' in self.update_share(temp_dir + '/assets/d$r$uri')
+ assert 'error' in self.update_share(temp_dir + '/assets/$$uri')
+ assert 'error' in self.update_share(
+ [temp_dir + '/assets$uri', temp_dir + '/assets/dir', '$$uri']
+ )