summaryrefslogtreecommitdiff
path: root/test/tclient/tests/multi-workspace.lua
diff options
context:
space:
mode:
Diffstat (limited to 'test/tclient/tests/multi-workspace.lua')
-rw-r--r--test/tclient/tests/multi-workspace.lua80
1 files changed, 80 insertions, 0 deletions
diff --git a/test/tclient/tests/multi-workspace.lua b/test/tclient/tests/multi-workspace.lua
new file mode 100644
index 00000000..99b7f122
--- /dev/null
+++ b/test/tclient/tests/multi-workspace.lua
@@ -0,0 +1,80 @@
+local lclient = require 'tclient.lclient'
+local fs = require 'bee.filesystem'
+local util = require 'utility'
+local furi = require 'file-uri'
+local ws = require 'workspace'
+local files = require 'files'
+
+local rootPath = LOGPATH .. '/multi-workspace'
+local rootUri = furi.encode(rootPath)
+
+for _, name in ipairs { 'ws1', 'ws2', 'share', 'lb1', 'lb2' } do
+ fs.create_directories(fs.path(rootPath .. '/' .. name))
+ util.saveFile(rootPath .. '/' .. name .. '/test.lua', '')
+end
+
+---@async
+lclient():start(function (client)
+ client:registerFakers()
+
+ client:register('workspace/configuration', function (params)
+ local uri = params.items[1].scopeUri
+ if uri == rootUri .. '/ws1' then
+ return {
+ {
+ ['workspace.library'] = {
+ rootPath .. '/share',
+ rootPath .. '/lb1',
+ }
+ }
+ }
+ end
+ if uri == rootUri .. '/ws2' then
+ return {
+ {
+ ['workspace.library'] = {
+ rootPath .. '/share',
+ rootPath .. '/lb2',
+ }
+ }
+ }
+ end
+ return {}
+ end)
+
+ client:initialize {
+ rootPath = rootPath,
+ rootUri = rootUri,
+ workspaceFolders = {
+ {
+ name = 'ws1',
+ uri = rootUri .. '/ws1',
+ },
+ {
+ name = 'ws2',
+ uri = rootUri .. '/ws2',
+ },
+ }
+ }
+
+ ws.awaitReady(rootUri .. '/ws1')
+ ws.awaitReady(rootUri .. '/ws2')
+
+ assert(files.getState(rootUri .. '/ws1/test.lua') ~= nil)
+ assert(files.getState(rootUri .. '/ws2/test.lua') ~= nil)
+ assert(files.getState(rootUri .. '/share/test.lua') ~= nil)
+ assert(files.getState(rootUri .. '/lb1/test.lua') ~= nil)
+ assert(files.getState(rootUri .. '/lb2/test.lua') ~= nil)
+
+ assert(ws.getScope(rootUri .. '/ws1/test.lua').uri == rootUri .. '/ws1')
+ assert(ws.getScope(rootUri .. '/ws2/test.lua').uri == rootUri .. '/ws2')
+ assert(ws.getScope(rootUri .. '/share/test.lua').uri == rootUri .. '/ws1')
+ assert(ws.getScope(rootUri .. '/lb1/test.lua').uri == rootUri .. '/ws1')
+ assert(ws.getScope(rootUri .. '/lb2/test.lua').uri == rootUri .. '/ws2')
+
+ assert(files.isLibrary(rootUri .. '/ws1/test.lua') == false)
+ assert(files.isLibrary(rootUri .. '/ws2/test.lua') == false)
+ assert(files.isLibrary(rootUri .. '/share/test.lua') == true)
+ assert(files.isLibrary(rootUri .. '/lb1/test.lua') == true)
+ assert(files.isLibrary(rootUri .. '/lb2/test.lua') == true)
+end)