diff options
| author | William Boman <william@redwill.se> | 2022-10-09 23:14:15 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-10-09 23:14:15 +0200 |
| commit | f336a8fac9090b4f8f5b3b430b5870efbd4b9113 (patch) | |
| tree | 5f2199e61ac2b0f3814df7dabe7c7eb7cf07cc80 /tests | |
| parent | feat(registry): add iferr tool for Go (#528) (diff) | |
| download | mason-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.lua | 58 | ||||
| -rw-r--r-- | tests/mason-core/result_spec.lua | 21 |
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) |
