mirror of
https://github.com/emikulic/darkhttpd.git
synced 2023-08-10 21:13:08 +03:00
Add test for --timeout.
This commit is contained in:
@ -97,6 +97,15 @@ runtests() {
|
||||
kill $PID
|
||||
wait $PID
|
||||
|
||||
echo "===> run --timeout tests"
|
||||
./a.out $DIR --port $PORT --timeout 1 \
|
||||
>>test.out.stdout 2>>test.out.stderr &
|
||||
PID=$!
|
||||
kill -0 $PID || exit 1
|
||||
python test_timeout.py
|
||||
kill $PID
|
||||
wait $PID
|
||||
|
||||
if [[ -s test.out.stderr ]]; then
|
||||
echo "FAIL: stderr should have been empty."
|
||||
exit 1
|
||||
|
22
devel/test_timeout.py
Executable file
22
devel/test_timeout.py
Executable file
@ -0,0 +1,22 @@
|
||||
#!/usr/bin/env python
|
||||
# This is run by the "run-tests" script.
|
||||
import unittest
|
||||
import signal
|
||||
import socket
|
||||
|
||||
class TestTimeout(unittest.TestCase):
|
||||
def test_timeout(self):
|
||||
port = 12346
|
||||
s = socket.socket()
|
||||
s.connect(("0.0.0.0", port))
|
||||
# Assumes the server has --timeout 1
|
||||
signal.alarm(3)
|
||||
# Expect to get EOF before the alarm fires.
|
||||
ret = s.recv(1024)
|
||||
signal.alarm(0)
|
||||
self.assertEquals(ret, '')
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.main()
|
||||
|
||||
# vim:set ts=4 sw=4 et:
|
Reference in New Issue
Block a user