Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

Adding tests for timeout against rules

  • Loading branch information...
commit 541f26c26dc1fb646aa59d7f7db71e79eafba93a 1 parent 13012f9
David Beitey davidjb authored
Showing with 95 additions and 0 deletions.
  1. +95 −0 qa/298-Timeout.py
95 qa/298-Timeout.py
View
@@ -0,0 +1,95 @@
+from base import *
+
+DIR = "298-Timeout"
+DIR_RULE = "%s-rule" % DIR
+CONTENT = "Tests to check whether timeout is applied."
+
+SERVER_TIMEOUT = 5
+RULE_TIMEOUT = 3
+
+CONF = """
+server!timeout = %(SERVER_TIMEOUT)i
+vserver!1!rule!2890!match = directory
+vserver!1!rule!2890!match!directory = /%(DIR)s
+vserver!1!rule!2890!handler = cgi
+
+vserver!1!rule!2891!match = directory
+vserver!1!rule!2891!match!directory = /%(DIR_RULE)s
+vserver!1!rule!2891!handler = cgi
+vserver!1!rule!2891!timeout = %(RULE_TIMEOUT)i
+
+""" %(globals())
+
+CGI_CODE = """#!/bin/sh
+
+echo "Content-Type: text/plain"
+echo
+sleep %(runtime)i
+echo "%(content)s"
+"""
+
+
+class TestEntry (TestBase):
+ """Test for timeout being applied.
+
+ If timeout expires, no content after `sleep` in the CGI will
+ be delivered.
+ """
+
+ def __init__ (self, dir, filename, runtime, content, expected_timeout):
+ TestBase.__init__ (self, __file__)
+ self.request = "GET /%s/%s HTTP/1.0\r\n" % (dir, filename) +\
+ "Connection: close\r\n"
+ self.expected_error = 200
+
+ if runtime < expected_timeout:
+ self.expected_content = content
+ else:
+ self.forbidden_content = content
+
+
+class Test (TestCollection):
+
+ def __init__ (self):
+ TestCollection.__init__ (self, __file__)
+
+ self.name = "Connection Timeouts Applied"
+ self.conf = CONF
+ self.proxy_suitable = True
+ self.filenames = {DIR: [],
+ DIR_RULE: []}
+
+ def Prepare (self, www):
+ self.local_dirs = {DIR: self.Mkdir (www, DIR),
+ DIR_RULE: self.Mkdir (www, DIR_RULE)}
+
+ def JustBefore (self, www):
+ # Create sub-request objects
+ self.Empty ()
+
+ # Create all tests with different runtime lengths
+ # Instant return and 1 second less than timeout should work,
+ # but past the timeout should return no content.
+ for dir, timeout in ((DIR, SERVER_TIMEOUT), (DIR_RULE, RULE_TIMEOUT)):
+ for script_runtime in (0, timeout-1, timeout+1):
+ # Write the new script files
+ filename = 'test-%i-seconds.cgi' % script_runtime
+ code = CGI_CODE % dict(runtime=script_runtime, content=CONTENT)
+ self.WriteFile (self.local_dirs[dir], filename, 0755, code)
+ self.filenames[dir].append(filename)
+
+ obj = self.Add (TestEntry (dir,
+ filename,
+ runtime=script_runtime,
+ content=CONTENT,
+ expected_timeout=timeout))
+
+
+ def JustAfter (self, www):
+ # Clean up the local files
+ for dir in self.local_dirs:
+ for filename in self.filenames[dir]:
+ fp = os.path.join (self.local_dirs[dir], filename)
+ os.unlink (fp)
+ self.filenames = {}
+
Please sign in to comment.
Something went wrong with that request. Please try again.