test/event_buffer-tests.lua

Sat, 15 Jan 2011 20:21:54 -0500

author
Thomas Harning Jr <harningt@gmail.com>
date
Sat, 15 Jan 2011 20:21:54 -0500
changeset 100
41a6f9a64b9e
parent 37
b7351b503b4b
permissions
-rw-r--r--

base: noted in CHANGELOG pending 0.3.0 release

require("luaevent.core")
local buffer = luaevent.core.buffer

require("lunit")

lunit.import("all")

bufferTests = TestCase("bufferTests")

function bufferTests:setup()
	self.buffer = buffer.new()
	self.buffer2 = buffer.new()
end

function bufferTests:teardown()
	self.buffer:close()
	self.buffer2:close()
end

local function testDataEqual(expected, actual, msg)
	msg = msg or ''
	assert_equal(expected, actual:get_data(), "Buffer not the same: " .. msg)
	assert_equal(#expected, actual:length(), "Buffer length not the same: " .. msg)
	assert_equal(expected, tostring(actual), "Buffer (from tostring) not the same: " .. msg)
	assert_equal(#expected, #actual, "Buffer length (from #) not zero: " .. msg)
end

function bufferTests:test_empty()
	testDataEqual("", self.buffer, "Buffer not empty")
	testDataEqual("", self.buffer2, "Buffer2 not empty")
end

function bufferTests:test_addSimpleString()
	self.buffer:add("Hello")
	testDataEqual("Hello", self.buffer)
	self.buffer:add("Hello")
	testDataEqual("HelloHello", self.buffer)
end

function bufferTests:test_addMultipleStrings()
	self.buffer:add("Hello", "Hello")
	testDataEqual("HelloHello", self.buffer)
end

function bufferTests:test_addDigits()
	self.buffer:add(1,2,3,4)
	testDataEqual("1234", self.buffer)
	self.buffer:add(100)
	testDataEqual("1234100", self.buffer)
	self.buffer:add(1.1)
	testDataEqual("12341001.1", self.buffer)
end

function bufferTests:test_addBuffer()
	self.buffer:add(self.buffer2)
	testDataEqual("", self.buffer)
	testDataEqual("", self.buffer2)
	self.buffer2:add("Hello")
	testDataEqual("Hello", self.buffer2)
	self.buffer:add(self.buffer2)
	testDataEqual("Hello", self.buffer)
	testDataEqual("", self.buffer2)
	assert_error("Cannot self-add buffers", function()
		self.buffer:add(self.buffer)
	end)
	assert_error("Cannot self-add buffers", function()
		self.buffer2:add(self.buffer2)
	end)
	testDataEqual("Hello", self.buffer, "Failures should not affect data content")
	testDataEqual("", self.buffer2, "Failures should not affect data content")
end

function bufferTests:test_addBadValues_fail()
	assert_error("Should not be able to add no values", function()
		self.buffer:add()
	end)
	assert_error("Should not be able to add boolean true", function()
		self.buffer:add(true)
	end)
	assert_error("Should not be able to add boolean false", function()
		self.buffer:add(false)
	end)
	assert_error("Should not be able to add functions", function()
		self.buffer:add(function() end)
	end)
	assert_error("Should not be able to add threads", function()
		self.buffer:add(coroutine.create(function() end))
	end)
	assert_error("Should not be able to add non-buffer userdata", function()
		self.buffer:add(newproxy())
	end)
	assert_error("Should not be able to add nil values", function()
		self.buffer:add(nil)
	end)
	assert_error("Multiples including valid values should not affect failure results", function()
		self.buffer:add("Hello", 1, bufferb, true, false, function() end, newproxy(), nil)
	end)
	testDataEqual("", self.buffer, "Buffer not empty after failing additions")
end

function bufferTests:test_drain()
	self.buffer:add("123456789")
	testDataEqual("123456789", self.buffer)
	assert_error("Cannot call drain w/ no args", function()
		self.buffer:drain()
	end)
	self.buffer:drain(1)
	testDataEqual("23456789", self.buffer)
	self.buffer:drain(4)
	testDataEqual("6789", self.buffer)
	assert_pass("Should be able to apply draining beyond actual buffer length", function()
		self.buffer:drain(5)
	end)
	testDataEqual("", self.buffer)
	self.buffer:add("123456789")
	testDataEqual("123456789", self.buffer)
	assert_pass([[Should be able to apply negative draining to cause draining `all data`
	(see source comments for why)]], function()
		self.buffer:drain(-1)
	end)
	testDataEqual("", self.buffer)
end

function bufferTests:test_getPartial()
	self.buffer:add("123456789")
	assert_equal("1234", self.buffer:get_data(4))
	assert_equal("1234", self.buffer:get_data(1,4))
	assert_equal("5678", self.buffer:get_data(5,4))
	assert_equal("5", self.buffer:get_data(5,1))
	assert_equal("56789", self.buffer:get_data(5,100000000), "Data length is capped at max obtainable")
	assert_equal("56789", self.buffer:get_data(5,-100), "Negative sizes capture entire remaining string")
	assert_equal("9", self.buffer:get_data(-1, 1, "Negative position causes wraparound"))
	assert_equal("89", self.buffer:get_data(-2,2, "Negative wraparound does not cause length inversion"))
end

local lineData = [[1
2
3]]
local splitLineData = {
	"1","2",nil
}
local mixedLineData = "1\r2\n3\r\n4\n\r5\r\r6\n\n7\r\n\r8\r\n\r9"
local splitMixedLineData = {
	"1","2","3","4","5","","6","","7","","8","", nil
}
function bufferTests:test_readline()
	self.buffer:add(lineData)
	testDataEqual(lineData, self.buffer)
	for _, data in ipairs(splitLineData) do
		assert_equal(data, self.buffer:readline())
	end
	testDataEqual("3", self.buffer, "Failed readline doesn't affect buffer contents")
	self.buffer:drain(-1)
	testDataEqual("", self.buffer)
	self.buffer:add(mixedLineData)
	testDataEqual(mixedLineData, self.buffer)
	for _, data in ipairs(splitMixedLineData) do
		assert_equal(data, self.buffer:readline())
	end
	testDataEqual("9", self.buffer)
end

lunit.run()

mercurial