aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorWilliam Boman <william@redwill.se>2022-09-03 01:26:03 +0200
committerGitHub <noreply@github.com>2022-09-03 01:26:03 +0200
commit73fb0ea926cf27f2107dfa1138f74a1f7999694d (patch)
treeddf324bfbabab1b06d3a9d6c0c6522057810022a /tests
parentfix(fantomas): link correct fantomas binany name (#370) (diff)
downloadmason-73fb0ea926cf27f2107dfa1138f74a1f7999694d.tar
mason-73fb0ea926cf27f2107dfa1138f74a1f7999694d.tar.gz
mason-73fb0ea926cf27f2107dfa1138f74a1f7999694d.tar.bz2
mason-73fb0ea926cf27f2107dfa1138f74a1f7999694d.tar.lz
mason-73fb0ea926cf27f2107dfa1138f74a1f7999694d.tar.xz
mason-73fb0ea926cf27f2107dfa1138f74a1f7999694d.tar.zst
mason-73fb0ea926cf27f2107dfa1138f74a1f7999694d.zip
fix(EventEmitter): properly deregister handlers, print errors that occur in handler (#373)
Diffstat (limited to 'tests')
-rw-r--r--tests/mason-core/EventEmitter_spec.lua72
-rw-r--r--tests/mason-core/installer/handle_spec.lua16
2 files changed, 84 insertions, 4 deletions
diff --git a/tests/mason-core/EventEmitter_spec.lua b/tests/mason-core/EventEmitter_spec.lua
new file mode 100644
index 00000000..4b9e3a6e
--- /dev/null
+++ b/tests/mason-core/EventEmitter_spec.lua
@@ -0,0 +1,72 @@
+local spy = require "luassert.spy"
+local match = require "luassert.match"
+
+local a = require "mason-core.async"
+local EventEmitter = require "mason-core.EventEmitter"
+
+describe("EventEmitter", function()
+ it("should call registered event handlers", function()
+ local emitter = EventEmitter.init(setmetatable({}, { __index = EventEmitter }))
+ local my_event_handler = spy.new()
+ emitter:on(
+ "my:event",
+ my_event_handler --[[@as fun()]]
+ )
+
+ emitter:emit("my:event", { table = "value" })
+ emitter:emit("my:event", 1337, 42)
+
+ assert.spy(my_event_handler).was_called(2)
+ assert.spy(my_event_handler).was_called_with(match.same { table = "value" })
+ assert.spy(my_event_handler).was_called_with(1337, 42)
+ end)
+
+ it("should call registered event handlers only once", function()
+ local emitter = EventEmitter.init(setmetatable({}, { __index = EventEmitter }))
+ local my_event_handler = spy.new()
+ emitter:once(
+ "my:event",
+ my_event_handler --[[@as fun()]]
+ )
+
+ emitter:emit("my:event", { table = "value" })
+ emitter:emit("my:event", 1337, 42)
+
+ assert.spy(my_event_handler).was_called(1)
+ assert.spy(my_event_handler).was_called_with(match.same { table = "value" })
+ end)
+
+ it("should remove registered event handlers", function()
+ local emitter = EventEmitter.init(setmetatable({}, { __index = EventEmitter }))
+ local my_event_handler = spy.new()
+ emitter:on(
+ "my:event",
+ my_event_handler --[[@as fun()]]
+ )
+ emitter:once(
+ "my:event",
+ my_event_handler --[[@as fun()]]
+ )
+
+ emitter:off(
+ "my:event",
+ my_event_handler --[[@as fun()]]
+ )
+
+ emitter:emit("my:event", { table = "value" })
+ assert.spy(my_event_handler).was_called(0)
+ end)
+
+ it(
+ "should print errors in handlers",
+ async_test(function()
+ spy.on(vim.api, "nvim_err_writeln")
+ local emitter = EventEmitter.init(setmetatable({}, { __index = EventEmitter }))
+ emitter:on("event", mockx.throws "My error.")
+ emitter:emit "event"
+ a.scheduler()
+ assert.spy(vim.api.nvim_err_writeln).was_called(1)
+ assert.spy(vim.api.nvim_err_writeln).was_called_with "My error."
+ end)
+ )
+end)
diff --git a/tests/mason-core/installer/handle_spec.lua b/tests/mason-core/installer/handle_spec.lua
index b1c75763..fb7b434e 100644
--- a/tests/mason-core/installer/handle_spec.lua
+++ b/tests/mason-core/installer/handle_spec.lua
@@ -7,9 +7,11 @@ describe("installer handle", function()
it("should register spawn handle", function()
local handle = InstallHandle.new(mock.new {})
local spawn_handle_change_handler = spy.new()
- handle:once("spawn_handles:change", spawn_handle_change_handler)
local luv_handle = mock.new {}
+
+ handle:once("spawn_handles:change", spawn_handle_change_handler)
handle:register_spawn_handle(luv_handle, 1337, "tar", { "-xvf", "file" })
+
assert.same({
uv_handle = luv_handle,
pid = 1337,
@@ -22,11 +24,13 @@ describe("installer handle", function()
it("should deregister spawn handle", function()
local handle = InstallHandle.new(mock.new {})
local spawn_handle_change_handler = spy.new()
- handle:once("spawn_handles:change", spawn_handle_change_handler)
local luv_handle1 = mock.new {}
local luv_handle2 = mock.new {}
+
+ handle:on("spawn_handles:change", spawn_handle_change_handler)
handle:register_spawn_handle(luv_handle1, 42, "curl", { "someurl" })
handle:register_spawn_handle(luv_handle2, 1337, "tar", { "-xvf", "file" })
+
assert.is_true(handle:deregister_spawn_handle(luv_handle1))
assert.equals(1, #handle.spawn_handles)
assert.same({
@@ -41,8 +45,10 @@ describe("installer handle", function()
it("should change state", function()
local handle = InstallHandle.new(mock.new {})
local state_change_handler = spy.new()
+
handle:once("state:change", state_change_handler)
handle:set_state "QUEUED"
+
assert.equals("QUEUED", handle.state)
assert.spy(state_change_handler).was_called(1)
assert.spy(state_change_handler).was_called_with("QUEUED", "IDLE")
@@ -54,11 +60,12 @@ describe("installer handle", function()
local uv_handle = {}
local handle = InstallHandle.new(mock.new {})
local kill_handler = spy.new()
+
handle:once("kill", kill_handler)
handle.state = "ACTIVE"
handle.spawn_handles = { { uv_handle = uv_handle } }
-
handle:kill(9)
+
assert.spy(process.kill).was_called(1)
assert.spy(process.kill).was_called_with(uv_handle, 9)
assert.spy(kill_handler).was_called(1)
@@ -76,13 +83,14 @@ describe("installer handle", function()
local kill_handler = spy.new()
local terminate_handler = spy.new()
local closed_handler = spy.new()
+
handle:once("kill", kill_handler)
handle:once("terminate", terminate_handler)
handle:once("closed", closed_handler)
handle.state = "ACTIVE"
handle.spawn_handles = { { uv_handle = uv_handle2 }, { uv_handle = uv_handle2 } }
-
handle:terminate()
+
assert.spy(process.kill).was_called(2)
assert.spy(process.kill).was_called_with(uv_handle1, 15)
assert.spy(process.kill).was_called_with(uv_handle2, 15)