summaryrefslogtreecommitdiffhomepage
path: root/test/test_variables.py
diff options
context:
space:
mode:
authorAndrei Belov <defan@nginx.com>2020-10-08 19:19:31 +0300
committerAndrei Belov <defan@nginx.com>2020-10-08 19:19:31 +0300
commitd586ac9fdc4a86c142b06a75dde4cdacad5b52f6 (patch)
tree9817282396f9d2cf5333050e4b5bf807d3617e40 /test/test_variables.py
parent9be35d9b7418c041e5177f273c20f0fd2d3f00ad (diff)
parentad516735a65fe109773b60e26214a071411f1734 (diff)
downloadunit-d586ac9fdc4a86c142b06a75dde4cdacad5b52f6.tar.gz
unit-d586ac9fdc4a86c142b06a75dde4cdacad5b52f6.tar.bz2
Merged with the default branch.1.20.0-1
Diffstat (limited to 'test/test_variables.py')
-rw-r--r--test/test_variables.py125
1 files changed, 78 insertions, 47 deletions
diff --git a/test/test_variables.py b/test/test_variables.py
index 805c5144..c458b636 100644
--- a/test/test_variables.py
+++ b/test/test_variables.py
@@ -4,83 +4,117 @@ from unit.applications.proto import TestApplicationProto
class TestVariables(TestApplicationProto):
prerequisites = {}
- def setUp(self):
- super().setUp()
-
- self.assertIn(
- 'success',
- self.conf(
- {
- "listeners": {"*:7080": {"pass": "routes/$method"}},
- "routes": {
- "GET": [{"action": {"return": 201}}],
- "POST": [{"action": {"return": 202}}],
- "3": [{"action": {"return": 203}}],
- "4": [{"action": {"return": 204}}],
- "blahGET}": [{"action": {"return": 205}}],
- "5GET": [{"action": {"return": 206}}],
- "GETGET": [{"action": {"return": 207}}],
- },
+ def setup_method(self):
+ super().setup_method()
+
+ assert 'success' in self.conf(
+ {
+ "listeners": {"*:7080": {"pass": "routes/$method"}},
+ "routes": {
+ "GET": [{"action": {"return": 201}}],
+ "POST": [{"action": {"return": 202}}],
+ "3": [{"action": {"return": 203}}],
+ "4*": [{"action": {"return": 204}}],
+ "blahGET}": [{"action": {"return": 205}}],
+ "5GET": [{"action": {"return": 206}}],
+ "GETGET": [{"action": {"return": 207}}],
+ "localhost": [{"action": {"return": 208}}],
},
- ),
- 'configure routes',
- )
+ },
+ ), 'configure routes'
def conf_routes(self, routes):
- self.assertIn(
- 'success',
- self.conf(routes, 'listeners/*:7080/pass')
- )
+ assert 'success' in self.conf(routes, 'listeners/*:7080/pass')
def test_variables_method(self):
- self.assertEqual(self.get()['status'], 201, 'method GET')
- self.assertEqual(self.post()['status'], 202, 'method POST')
+ assert self.get()['status'] == 201, 'method GET'
+ assert self.post()['status'] == 202, 'method POST'
def test_variables_uri(self):
self.conf_routes("\"routes$uri\"")
- self.assertEqual(self.get(url='/3')['status'], 203, 'uri')
- self.assertEqual(self.get(url='/4')['status'], 204, 'uri 2')
+ assert self.get(url='/3')['status'] == 203, 'uri'
+ assert self.get(url='/4*')['status'] == 204, 'uri 2'
+ assert self.get(url='/4%2A')['status'] == 204, 'uri 3'
+
+ def test_variables_host(self):
+ self.conf_routes("\"routes/$host\"")
+
+ def check_host(host, status=208):
+ assert (
+ self.get(headers={'Host': host, 'Connection': 'close'})[
+ 'status'
+ ]
+ == status
+ )
+
+ check_host('localhost')
+ check_host('localhost.')
+ check_host('localhost:7080')
+ check_host('.localhost', 404)
+ check_host('www.localhost', 404)
+ check_host('localhost1', 404)
def test_variables_many(self):
self.conf_routes("\"routes$uri$method\"")
- self.assertEqual(self.get(url='/5')['status'], 206, 'many')
+ assert self.get(url='/5')['status'] == 206, 'many'
self.conf_routes("\"routes${uri}${method}\"")
- self.assertEqual(self.get(url='/5')['status'], 206, 'many 2')
+ assert self.get(url='/5')['status'] == 206, 'many 2'
self.conf_routes("\"routes${uri}$method\"")
- self.assertEqual(self.get(url='/5')['status'], 206, 'many 3')
+ assert self.get(url='/5')['status'] == 206, 'many 3'
self.conf_routes("\"routes/$method$method\"")
- self.assertEqual(self.get()['status'], 207, 'many 4')
+ assert self.get()['status'] == 207, 'many 4'
self.conf_routes("\"routes/$method$uri\"")
- self.assertEqual(self.get()['status'], 404, 'no route')
- self.assertEqual(self.get(url='/blah')['status'], 404, 'no route 2')
+ assert self.get()['status'] == 404, 'no route'
+ assert self.get(url='/blah')['status'] == 404, 'no route 2'
def test_variables_replace(self):
- self.assertEqual(self.get()['status'], 201)
+ assert self.get()['status'] == 201
self.conf_routes("\"routes$uri\"")
- self.assertEqual(self.get(url='/3')['status'], 203)
+ assert self.get(url='/3')['status'] == 203
self.conf_routes("\"routes/${method}\"")
- self.assertEqual(self.post()['status'], 202)
+ assert self.post()['status'] == 202
self.conf_routes("\"routes${uri}\"")
- self.assertEqual(self.get(url='/4')['status'], 204)
+ assert self.get(url='/4*')['status'] == 204
self.conf_routes("\"routes/blah$method}\"")
- self.assertEqual(self.get()['status'], 205)
+ assert self.get()['status'] == 205
+
+ def test_variables_upstream(self):
+ assert 'success' in self.conf(
+ {
+ "listeners": {
+ "*:7080": {"pass": "upstreams$uri"},
+ "*:7081": {"pass": "routes/one"},
+ },
+ "upstreams": {
+ "1": {
+ "servers": {
+ "127.0.0.1:7081": {},
+ },
+ },
+ },
+ "routes": {
+ "one": [{"action": {"return": 200}}],
+ },
+ },
+ ), 'upstreams initial configuration'
+
+ assert self.get(url='/1')['status'] == 200
+ assert self.get(url='/2')['status'] == 404
def test_variables_invalid(self):
def check_variables(routes):
- self.assertIn(
- 'error',
- self.conf(routes, 'listeners/*:7080/pass'),
- 'invalid variables',
- )
+ assert 'error' in self.conf(
+ routes, 'listeners/*:7080/pass'
+ ), 'invalid variables'
check_variables("\"routes$\"")
check_variables("\"routes${\"")
@@ -89,6 +123,3 @@ class TestVariables(TestApplicationProto):
check_variables("\"routes$uriblah\"")
check_variables("\"routes${uri\"")
check_variables("\"routes${{uri}\"")
-
-if __name__ == '__main__':
- TestVariables.main()