diff options
| author | William Boman <william@redwill.se> | 2022-07-08 18:34:38 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-07-08 18:34:38 +0200 |
| commit | 976aa4fbee8a070f362cab6f6ec84e9251a90cf9 (patch) | |
| tree | 5e8d9c9c59444a25c7801b8f39763c4ba6e1f76d /tests/mason-core/platform_spec.lua | |
| parent | feat: add gotests, gomodifytags, impl (#28) (diff) | |
| download | mason-976aa4fbee8a070f362cab6f6ec84e9251a90cf9.tar mason-976aa4fbee8a070f362cab6f6ec84e9251a90cf9.tar.gz mason-976aa4fbee8a070f362cab6f6ec84e9251a90cf9.tar.bz2 mason-976aa4fbee8a070f362cab6f6ec84e9251a90cf9.tar.lz mason-976aa4fbee8a070f362cab6f6ec84e9251a90cf9.tar.xz mason-976aa4fbee8a070f362cab6f6ec84e9251a90cf9.tar.zst mason-976aa4fbee8a070f362cab6f6ec84e9251a90cf9.zip | |
refactor: add mason-schemas and mason-core modules (#29)
* refactor: add mason-schemas and move generated filetype map to mason-lspconfig
* refactor: add mason-core module
Diffstat (limited to 'tests/mason-core/platform_spec.lua')
| -rw-r--r-- | tests/mason-core/platform_spec.lua | 159 |
1 files changed, 159 insertions, 0 deletions
diff --git a/tests/mason-core/platform_spec.lua b/tests/mason-core/platform_spec.lua new file mode 100644 index 00000000..2c9d2035 --- /dev/null +++ b/tests/mason-core/platform_spec.lua @@ -0,0 +1,159 @@ +local stub = require "luassert.stub" +local spy = require "luassert.spy" +local match = require "luassert.match" + +describe("platform", function() + local function platform() + package.loaded["mason-core.platform"] = nil + return require "mason-core.platform" + end + + local function stub_mac(arch) + arch = arch or "x86_64" + stub(vim.fn, "has") + stub(vim.loop, "os_uname") + vim.loop.os_uname.returns { machine = arch } + vim.fn.has.on_call_with("mac").returns(1) + vim.fn.has.on_call_with("unix").returns(1) + vim.fn.has.on_call_with(match._).returns(0) + end + + local function stub_linux() + stub(vim.fn, "has") + vim.fn.has.on_call_with("mac").returns(0) + vim.fn.has.on_call_with("unix").returns(1) + vim.fn.has.on_call_with(match._).returns(0) + end + + local function stub_windows() + stub(vim.fn, "has") + vim.fn.has.on_call_with("win32").returns(1) + vim.fn.has.on_call_with(match._).returns(0) + end + + it("should be able to detect platform and arch", function() + stub_mac "arm64" + assert.is_true(platform().is.mac_arm64) + assert.is_false(platform().is.mac_x64) + assert.is_false(platform().is.nothing) + end) + + it("should be able to detect macos", function() + stub_mac() + assert.is_true(platform().is_mac) + assert.is_true(platform().is.mac) + assert.is_true(platform().is_unix) + assert.is_true(platform().is.unix) + assert.is_false(platform().is_linux) + assert.is_false(platform().is.linux) + assert.is_false(platform().is_win) + assert.is_false(platform().is.win) + end) + + it("should be able to detect linux", function() + stub_linux() + assert.is_false(platform().is_mac) + assert.is_false(platform().is.mac) + assert.is_true(platform().is_unix) + assert.is_true(platform().is.unix) + assert.is_true(platform().is_linux) + assert.is_true(platform().is.linux) + assert.is_false(platform().is_win) + assert.is_false(platform().is.win) + end) + + it("should be able to detect windows", function() + stub_windows() + assert.is_false(platform().is_mac) + assert.is_false(platform().is.mac) + assert.is_false(platform().is_unix) + assert.is_false(platform().is.unix) + assert.is_false(platform().is_linux) + assert.is_false(platform().is.linux) + assert.is_true(platform().is_win) + assert.is_true(platform().is.win) + end) + + it("should run correct case on linux", function() + local unix = spy.new() + local win = spy.new() + local mac = spy.new() + local linux = spy.new() + + stub_linux() + platform().when { + unix = unix, + win = win, + linux = linux, + mac = mac, + } + assert.spy(unix).was_not_called() + assert.spy(mac).was_not_called() + assert.spy(win).was_not_called() + assert.spy(linux).was_called(1) + end) + + it("should run correct case on mac", function() + local unix = spy.new() + local win = spy.new() + local mac = spy.new() + local linux = spy.new() + + stub_mac() + platform().when { + unix = unix, + win = win, + linux = linux, + mac = mac, + } + assert.spy(unix).was_not_called() + assert.spy(mac).was_called(1) + assert.spy(win).was_not_called() + assert.spy(linux).was_not_called() + end) + + it("should run correct case on windows", function() + local unix = spy.new() + local win = spy.new() + local mac = spy.new() + local linux = spy.new() + + stub_windows() + platform().when { + unix = unix, + win = win, + linux = linux, + mac = mac, + } + assert.spy(unix).was_not_called() + assert.spy(mac).was_not_called() + assert.spy(win).was_called(1) + assert.spy(linux).was_not_called() + end) + + it("should run correct case on mac (unix)", function() + local unix = spy.new() + local win = spy.new() + + stub_mac() + platform().when { + unix = unix, + win = win, + } + assert.spy(unix).was_called(1) + assert.spy(win).was_not_called() + end) + + it("should run correct case on linux (unix)", function() + local unix = spy.new() + local win = spy.new() + + stub_linux() + platform().when { + unix = unix, + win = win, + } + assert.spy(unix).was_called(1) + assert.spy(win).was_not_called() + end) +end) |
