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
|
local InstallContext = require "mason-core.installer.context"
local InstallHandle = require "mason-core.installer.InstallHandle"
local InstallLocation = require "mason-core.installer.InstallLocation"
local Result = require "mason-core.result"
local a = require "mason-core.async"
local registry = require "mason-registry"
local spy = require "luassert.spy"
local M = {}
---@param opts? { install_opts?: PackageInstallOpts, package?: string }
function M.create_context(opts)
local pkg = registry.get_package(opts and opts.package or "dummy")
local handle = InstallHandle:new(pkg, InstallLocation.global())
local context = InstallContext:new(handle, opts and opts.install_opts or {})
context.spawn = setmetatable({}, {
__index = function(s, cmd)
s[cmd] = spy.new(function()
return Result.success { stdout = nil, stderr = nil }
end)
return s[cmd]
end,
})
context.cwd:initialize():get_or_throw()
return context
end
---@param pkg AbstractPackage
---@param opts? PackageInstallOpts
function M.sync_install(pkg, opts)
return a.run_blocking(function()
return a.wait(function(resolve, reject)
pkg:install(opts, function(success, result)
(success and resolve or reject)(result)
end)
end)
end)
end
---@param pkg AbstractPackage
---@param opts? PackageUninstallOpts
function M.sync_uninstall(pkg, opts)
return a.run_blocking(function()
return a.wait(function(resolve, reject)
pkg:uninstall(opts, function(success, result)
(success and resolve or reject)(result)
end)
end)
end)
end
---@param runner InstallRunner
---@param opts PackageInstallOpts
function M.sync_runner_execute(runner, opts)
local callback = spy.new()
runner:execute(opts, callback)
assert.wait(function()
assert.spy(callback).was_called()
end)
return callback
end
return M
|