aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorWilliam Boman <william@redwill.se>2022-10-09 23:14:15 +0200
committerGitHub <noreply@github.com>2022-10-09 23:14:15 +0200
commitf336a8fac9090b4f8f5b3b430b5870efbd4b9113 (patch)
tree5f2199e61ac2b0f3814df7dabe7c7eb7cf07cc80 /tests
parentfeat(registry): add iferr tool for Go (#528) (diff)
downloadmason-f336a8fac9090b4f8f5b3b430b5870efbd4b9113.tar
mason-f336a8fac9090b4f8f5b3b430b5870efbd4b9113.tar.gz
mason-f336a8fac9090b4f8f5b3b430b5870efbd4b9113.tar.bz2
mason-f336a8fac9090b4f8f5b3b430b5870efbd4b9113.tar.lz
mason-f336a8fac9090b4f8f5b3b430b5870efbd4b9113.tar.xz
mason-f336a8fac9090b4f8f5b3b430b5870efbd4b9113.tar.zst
mason-f336a8fac9090b4f8f5b3b430b5870efbd4b9113.zip
feat(npm): speed up checking for new versions (#530)
Diffstat (limited to 'tests')
-rw-r--r--tests/mason-core/managers/npm_spec.lua58
-rw-r--r--tests/mason-core/result_spec.lua21
2 files changed, 54 insertions, 25 deletions
diff --git a/tests/mason-core/managers/npm_spec.lua b/tests/mason-core/managers/npm_spec.lua
index 78845ff1..71d93301 100644
--- a/tests/mason-core/managers/npm_spec.lua
+++ b/tests/mason-core/managers/npm_spec.lua
@@ -1,3 +1,4 @@
+local stub = require "luassert.stub"
local spy = require "luassert.spy"
local match = require "luassert.match"
local mock = require "luassert.mock"
@@ -6,6 +7,7 @@ local npm = require "mason-core.managers.npm"
local Result = require "mason-core.result"
local spawn = require "mason-core.spawn"
local path = require "mason-core.path"
+local api = require "mason-registry.api"
describe("npm manager", function()
it(
@@ -83,7 +85,7 @@ describe("npm version check", function()
it(
"should return current version",
async_test(function()
- spawn.npm = spy.new(function()
+ stub(spawn, "npm", function()
return Result.success {
stdout = [[
{
@@ -113,26 +115,27 @@ describe("npm version check", function()
assert.spy(spawn.npm).was_called_with { "ls", "--json", cwd = path.package_prefix "dummy" }
assert.is_true(result:is_success())
assert.equals("2.0.0", result:get_or_nil())
-
- spawn.npm = nil
end)
)
it(
"should return outdated primary package",
async_test(function()
- spawn.npm = spy.new(function()
- -- npm outdated returns with exit code 1 if outdated packages are found!
- return Result.failure {
- exit_code = 1,
+ stub(api, "get")
+ api.get.on_call_with("/api/npm/bash-language-server/latest-version").returns(Result.success {
+ name = "bash-language-server",
+ version = "2.0.0",
+ })
+ stub(spawn, "npm", function()
+ return Result.success {
stdout = [[
{
- "bash-language-server": {
- "current": "1.17.0",
- "wanted": "1.17.0",
- "latest": "2.0.0",
- "dependent": "bash",
- "location": "/tmp/install/dir"
+ "name": "bash",
+ "dependencies": {
+ "bash-language-server": {
+ "version": "1.17.0",
+ "resolved": "https://registry.npmjs.org/bash-language-server/-/bash-language-server-1.17.0.tgz"
+ }
}
}
]],
@@ -149,32 +152,38 @@ describe("npm version check", function()
path.package_prefix "dummy"
)
- assert.spy(spawn.npm).was_called(1)
- assert.spy(spawn.npm).was_called_with {
- "outdated",
- "--json",
- "bash-language-server",
- cwd = path.package_prefix "dummy",
- }
assert.is_true(result:is_success())
assert.same({
name = "bash-language-server",
current_version = "1.17.0",
latest_version = "2.0.0",
}, result:get_or_nil())
-
- spawn.npm = nil
end)
)
it(
"should return failure if primary package is not outdated",
async_test(function()
- spawn.npm = spy.new(function()
+ stub(spawn, "npm", function()
return Result.success {
- stdout = "{}",
+ stdout = [[
+ {
+ "name": "bash",
+ "dependencies": {
+ "bash-language-server": {
+ "version": "1.17.0",
+ "resolved": "https://registry.npmjs.org/bash-language-server/-/bash-language-server-1.17.0.tgz"
+ }
+ }
+ }
+ ]],
}
end)
+ stub(api, "get")
+ api.get.on_call_with("/api/npm/bash-language-server/latest-version").returns(Result.success {
+ name = "bash-language-server",
+ version = "1.17.0",
+ })
local result = npm.check_outdated_primary_package(
mock.new {
@@ -188,7 +197,6 @@ describe("npm version check", function()
assert.is_true(result:is_failure())
assert.equals("Primary package is not outdated.", result:err_or_nil())
- spawn.npm = nil
end)
)
end)
diff --git a/tests/mason-core/result_spec.lua b/tests/mason-core/result_spec.lua
index 737d8c56..ee722281 100644
--- a/tests/mason-core/result_spec.lua
+++ b/tests/mason-core/result_spec.lua
@@ -153,4 +153,25 @@ describe("result", function()
assert.is_true(getmetatable(opt) == Optional)
assert.is_false(opt:is_present())
end)
+
+ it("should chain results", function()
+ local success = Result.success("First"):and_then(function(value)
+ return Result.success(value .. " Second")
+ end)
+ local failure = Result.success("Error"):and_then(Result.failure)
+
+ assert.is_true(success:is_success())
+ assert.equals("First Second", success:get_or_nil())
+ assert.is_true(failure:is_failure())
+ assert.equals("Error", failure:err_or_nil())
+ end)
+
+ it("should not chain results upon failure", function()
+ local chain = spy.new()
+ local failure = Result.failure("Error"):and_then(chain)
+
+ assert.is_true(failure:is_failure())
+ assert.equals("Error", failure:err_or_nil())
+ assert.spy(chain).was_not_called()
+ end)
end)