Merge pull request #45 from 4O4/observer-tests-improvements
Observer tests improvements
This commit is contained in:
commit
13a983787b
@ -1,91 +1,168 @@
|
|||||||
describe('Observer', function()
|
describe('Observer', function()
|
||||||
|
|
||||||
describe('create', function()
|
describe('create', function()
|
||||||
it('returns an Observer', function()
|
local function expectObserverToBeInCleanStateAndValid(observer)
|
||||||
expect(Rx.Observer.create()).to.be.an(Rx.Observer)
|
expect(observer).to.be.an(Rx.Observer)
|
||||||
|
expect(observer.stopped).to.equal(false)
|
||||||
|
end
|
||||||
|
|
||||||
|
it('works when no parameters is passed', function()
|
||||||
|
local observer = Rx.Observer.create()
|
||||||
|
expectObserverToBeInCleanStateAndValid(observer)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('assigns onNext, onError, and onCompleted', function()
|
it('works when onNext callback parameter is passed', function()
|
||||||
local function onNext() end
|
local observer = Rx.Observer.create(function () end)
|
||||||
local function onError() end
|
expectObserverToBeInCleanStateAndValid(observer)
|
||||||
local function onCompleted() end
|
|
||||||
|
|
||||||
local observer = Rx.Observer.create(onNext, onError, onCompleted)
|
|
||||||
|
|
||||||
expect(observer._onNext).to.equal(onNext)
|
|
||||||
expect(observer._onError).to.equal(onError)
|
|
||||||
expect(observer._onCompleted).to.equal(onCompleted)
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('initializes stopped to false', function()
|
it('works when onError callback parameter is passed', function()
|
||||||
expect(Rx.Observer.create().stopped).to.equal(false)
|
local observer = Rx.Observer.create(nil, function () end)
|
||||||
|
expectObserverToBeInCleanStateAndValid(observer)
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('works when onComplete callback parameter is passed', function()
|
||||||
|
local observer = Rx.Observer.create(nil, nil, function () end)
|
||||||
|
expectObserverToBeInCleanStateAndValid(observer)
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('works when all callback parameters are passed', function()
|
||||||
|
local observer = Rx.Observer.create(function () end, function () end, function () end)
|
||||||
|
expectObserverToBeInCleanStateAndValid(observer)
|
||||||
end)
|
end)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
describe('onNext', function()
|
describe('onNext', function()
|
||||||
it('calls _onNext', function()
|
it('calls custom onNext callback if it was provided', function()
|
||||||
local observer = Rx.Observer.create()
|
local onNext = spy()
|
||||||
local function run() observer:onNext() end
|
local observer = Rx.Observer.create(onNext, nil, nil)
|
||||||
expect(#spy(observer, '_onNext', run)).to.equal(1)
|
observer:onNext()
|
||||||
|
expect(#onNext).to.equal(1)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('passes all arguments to _onNext', function()
|
it('passes all arguments to custom onNext callback if it was provided', function()
|
||||||
local observer = Rx.Observer.create()
|
local onNext = spy()
|
||||||
local function run() observer:onNext(1, '2', 3, nil, 5) end
|
local observer = Rx.Observer.create(onNext, nil, nil)
|
||||||
expect(spy(observer, '_onNext', run)).to.equal({{1, '2', 3, nil, 5}})
|
observer:onNext(1, '2', 3, nil, 5, { key = 6 })
|
||||||
|
expect(onNext).to.equal({{1, '2', 3, nil, 5, { key = 6 }}})
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('does not call _onNext if stopped is true', function()
|
it('works and does not error when custom onNext callback was not provided', function()
|
||||||
local observer = Rx.Observer.create()
|
local observer = Rx.Observer.create()
|
||||||
observer.stopped = true
|
local errors = {}
|
||||||
local function run() observer:onNext() end
|
|
||||||
expect(#spy(observer, '_onNext', run)).to.equal(0)
|
-- would gladly use something like to_not.fail() here but it's
|
||||||
|
-- not quite good with producing useful error messages
|
||||||
|
local success = tryCall(function () observer:onNext() end, errors)
|
||||||
|
tryCall(function () expect(success).to.equal(true) end, errors)
|
||||||
|
throwErrorsIfAny(errors)
|
||||||
|
end)
|
||||||
|
|
||||||
|
describe('does not call custom onError callback', function ()
|
||||||
|
it('if observer already received completion notification', function()
|
||||||
|
local onNext = spy()
|
||||||
|
local observer = Rx.Observer.create(onNext, nil, nil)
|
||||||
|
observer:onCompleted()
|
||||||
|
observer:onNext()
|
||||||
|
expect(#onNext).to.equal(0)
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('if observer already received error notification', function()
|
||||||
|
local onNext = spy()
|
||||||
|
local observer = Rx.Observer.create(onNext, nil, nil)
|
||||||
|
observer:onCompleted()
|
||||||
|
observer:onNext()
|
||||||
|
expect(#onNext).to.equal(0)
|
||||||
|
end)
|
||||||
end)
|
end)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
describe('onError', function()
|
describe('onError', function()
|
||||||
it('calls _onError with the first argument it was passed', function()
|
it('causes an error by default if custom onError callback was not provided', function()
|
||||||
local observer = Rx.Observer.create(_, function() end, _)
|
local observer = Rx.Observer.create()
|
||||||
local function run() observer:onError('sheeit', 1) end
|
expect(function () observer:onError() end).to.fail()
|
||||||
expect(spy(observer, '_onError', run)).to.equal({{'sheeit'}})
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('sets stopped to true', function()
|
it('calls custom onError callback if it was provided', function()
|
||||||
local observer = Rx.Observer.create(_, function() end, _)
|
local onError = spy()
|
||||||
|
local observer = Rx.Observer.create(nil, onError, nil)
|
||||||
|
observer:onError()
|
||||||
|
expect(#onError).to.equal(1)
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('passes first value from error notification to custom onError callback', function()
|
||||||
|
local onError = spy()
|
||||||
|
local observer = Rx.Observer.create(nil, onError, nil)
|
||||||
|
observer:onError("err msg", "excessive arg", 1)
|
||||||
|
expect(onError).to.equal({{"err msg"}})
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('marks observer as stopped', function()
|
||||||
|
local observer = Rx.Observer.create(nil, function() end, nil)
|
||||||
observer:onError()
|
observer:onError()
|
||||||
expect(observer.stopped).to.equal(true)
|
expect(observer.stopped).to.equal(true)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('does not call _onError if stopped is already true', function()
|
describe('does not call custom onError callback', function ()
|
||||||
local observer = Rx.Observer.create(_, function() end, _)
|
it('if observer already received completion notification', function()
|
||||||
observer.stopped = true
|
local onError = spy()
|
||||||
local function run() observer:onError() end
|
local observer = Rx.Observer.create(nil, onError, nil)
|
||||||
expect(#spy(observer, '_onError', run)).to.equal(0)
|
observer:onCompleted()
|
||||||
end)
|
observer:onError()
|
||||||
|
expect(#onError).to.equal(0)
|
||||||
|
end)
|
||||||
|
|
||||||
it('causes an error by default', function()
|
it('if observer already received error notification', function()
|
||||||
local observer = Rx.Observer.create()
|
local spyEnabled = false
|
||||||
expect(observer.onError).to.fail()
|
local onError = spy()
|
||||||
|
local observer = Rx.Observer.create(nil, function () if spyEnabled then onError() end end, nil)
|
||||||
|
observer:onError()
|
||||||
|
spyEnabled = true
|
||||||
|
observer:onError()
|
||||||
|
expect(#onError).to.equal(0)
|
||||||
|
end)
|
||||||
end)
|
end)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
describe('onCompleted', function()
|
describe('onCompleted', function()
|
||||||
it('calls _onCompleted with no arguments', function()
|
it('calls custom onCompleted callback if it was provided', function()
|
||||||
local observer = Rx.Observer.create()
|
local onCompleted = spy()
|
||||||
local function run() observer:onCompleted(1, 2, 3) end
|
local observer = Rx.Observer.create(nil, nil, onCompleted)
|
||||||
expect(spy(observer, '_onCompleted', run)).to.equal({{}})
|
observer:onCompleted()
|
||||||
|
expect(#onCompleted).to.equal(1)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('sets stopped to true', function()
|
it('calls custom onCompleted callback with no parameters', function()
|
||||||
local observer = Rx.Observer.create()
|
local onCompleted = spy()
|
||||||
|
local observer = Rx.Observer.create(nil, nil, onCompleted)
|
||||||
|
observer:onCompleted("excessive arg", 1)
|
||||||
|
expect(onCompleted).to.equal({{}})
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('marks observer as stopped', function()
|
||||||
|
local observer = Rx.Observer.create(nil, function() end, nil)
|
||||||
observer:onCompleted()
|
observer:onCompleted()
|
||||||
expect(observer.stopped).to.equal(true)
|
expect(observer.stopped).to.equal(true)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('does not call _onCompleted if stopped is already true', function()
|
describe('does not call custom onCompleted callback', function ()
|
||||||
local observer = Rx.Observer.create()
|
it('if observer already received completion notification', function()
|
||||||
observer.stopped = true
|
local spyEnabled = false
|
||||||
local function run() observer:onCompleted() end
|
local onCompleted = spy()
|
||||||
expect(#spy(observer, '_onCompleted', run)).to.equal(0)
|
local observer = Rx.Observer.create(nil, function () if spyEnabled then onCompleted() end end, nil)
|
||||||
|
observer:onCompleted()
|
||||||
|
spyEnabled = true
|
||||||
|
observer:onCompleted()
|
||||||
|
expect(#onCompleted).to.equal(0)
|
||||||
|
end)
|
||||||
|
|
||||||
|
it('if observer already received error notification', function()
|
||||||
|
local onCompleted = spy()
|
||||||
|
local observer = Rx.Observer.create(nil, function () end, onCompleted)
|
||||||
|
observer:onError()
|
||||||
|
observer:onCompleted()
|
||||||
|
expect(#onCompleted).to.equal(0)
|
||||||
|
end)
|
||||||
end)
|
end)
|
||||||
end)
|
end)
|
||||||
end)
|
end)
|
||||||
|
@ -5,6 +5,23 @@ for _, fn in pairs({'describe', 'it', 'test', 'expect', 'spy', 'before', 'after'
|
|||||||
_G[fn] = lust[fn]
|
_G[fn] = lust[fn]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- helper function to safely accumulate errors which will be displayed when done testing
|
||||||
|
function tryCall(fn, errorsAccumulator)
|
||||||
|
local errNum = #errorsAccumulator
|
||||||
|
|
||||||
|
xpcall(fn, function (err)
|
||||||
|
table.insert(errorsAccumulator, err)
|
||||||
|
end)
|
||||||
|
|
||||||
|
return #errorsAccumulator == errNum
|
||||||
|
end
|
||||||
|
|
||||||
|
function throwErrorsIfAny(errorsAccumulator)
|
||||||
|
if #errorsAccumulator > 0 then
|
||||||
|
error(table.concat(errorsAccumulator, '\n\t' .. string.rep('\t', lust.level)))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
observableSpy = function(observable)
|
observableSpy = function(observable)
|
||||||
local onNextSpy = spy()
|
local onNextSpy = spy()
|
||||||
local onErrorSpy = spy()
|
local onErrorSpy = spy()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user