summaryrefslogtreecommitdiffstats
path: root/test/stest.lua
blob: f54a4159fa10b9a7bd258aa6e9dd770bb1250c1b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#!bin/lem
--
-- This file is part of LEM, a Lua Event Machine.
-- Copyright 2011-2012 Emil Renner Berthing
--
-- LEM is free software: you can redistribute it and/or
-- modify it under the terms of the GNU General Public License as
-- published by the Free Software Foundation, either version 3 of
-- the License, or (at your option) any later version.
--
-- LEM is distributed in the hope that it will be useful,
-- but WITHOUT ANY WARRANTY; without even the implied warranty of
-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-- GNU General Public License for more details.
--
-- You should have received a copy of the GNU General Public License
-- along with LEM.  If not, see <http://www.gnu.org/licenses/>.
--

print('Entered ' .. arg[0])

local utils   = require 'lem.utils'
local streams = require 'lem.streams'

local server = assert(streams.tcp4_listen('*', arg[1] or 8080))

--timer(10, function() exit(0) end)
utils.timer(10, function()
	print 'Closing server'
	server:close()
end)

local ok, err = server:autospawn(function(i, o)
	print 'Accepted a connection'
	local sleeper = utils.sleeper()

	while true do
		local line, err = i:read('*l')
		if not line then
			if err == 'closed' then
				print("Client closed connection")
				return
			end

			error(err)
		end

		print("Client sent: '" .. line .. "'")
		if line ~= 'ping' then break end

		sleeper:sleep(0.4)
		assert(o:write('pong\n'))
	end

	print "Ok, I'm out"
	assert(i:close())
	assert(o:close())
end)

if not ok and err ~= 'interrupted' then error(err) end

print('Exiting ' .. arg[0])

-- vim: syntax=lua ts=2 sw=2 noet: