asyar-sdk 1.16.2 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +95 -42
- package/dist/ExtensionBridge.d.ts +1 -1
- package/dist/ExtensionBridge.d.ts.map +1 -1
- package/dist/ExtensionBridge.js +17 -13
- package/dist/ExtensionBridge.js.map +1 -1
- package/dist/ExtensionBridge.test.js +76 -101
- package/dist/ExtensionBridge.test.js.map +1 -1
- package/dist/ExtensionContext.d.ts +22 -57
- package/dist/ExtensionContext.d.ts.map +1 -1
- package/dist/ExtensionContext.js +84 -207
- package/dist/ExtensionContext.js.map +1 -1
- package/dist/ExtensionContext.test.js +91 -66
- package/dist/ExtensionContext.test.js.map +1 -1
- package/dist/ExtensionContextCore.d.ts +46 -0
- package/dist/ExtensionContextCore.d.ts.map +1 -0
- package/dist/ExtensionContextCore.js +149 -0
- package/dist/ExtensionContextCore.js.map +1 -0
- package/dist/PreferencesFacade.js +4 -9
- package/dist/PreferencesFacade.js.map +1 -1
- package/dist/PreferencesFacade.test.js +53 -55
- package/dist/PreferencesFacade.test.js.map +1 -1
- package/dist/cli/commands/attach.js +1 -1
- package/dist/cli/commands/attach.js.map +1 -1
- package/dist/cli/commands/build.d.ts +5 -1
- package/dist/cli/commands/build.d.ts.map +1 -1
- package/dist/cli/commands/build.js +43 -5
- package/dist/cli/commands/build.js.map +1 -1
- package/dist/cli/lib/manifest.d.ts +17 -5
- package/dist/cli/lib/manifest.d.ts.map +1 -1
- package/dist/cli/lib/manifest.js +125 -66
- package/dist/cli/lib/manifest.js.map +1 -1
- package/dist/{index.d.ts → contracts.d.ts} +23 -1
- package/dist/contracts.d.ts.map +1 -0
- package/dist/contracts.js +36 -0
- package/dist/contracts.js.map +1 -0
- package/dist/contracts.purity.test.d.ts +2 -0
- package/dist/contracts.purity.test.d.ts.map +1 -0
- package/dist/contracts.purity.test.js +42 -0
- package/dist/contracts.purity.test.js.map +1 -0
- package/dist/icons/AsyarIconElement.js +4 -9
- package/dist/icons/AsyarIconElement.js.map +1 -1
- package/dist/icons/AsyarIconElement.test.js +14 -16
- package/dist/icons/AsyarIconElement.test.js.map +1 -1
- package/dist/icons/IconRenderer.js +9 -15
- package/dist/icons/IconRenderer.js.map +1 -1
- package/dist/icons/IconRenderer.test.js +63 -65
- package/dist/icons/IconRenderer.test.js.map +1 -1
- package/dist/icons/iconData.js +2 -5
- package/dist/icons/iconData.js.map +1 -1
- package/dist/icons/index.js +3 -14
- package/dist/icons/index.js.map +1 -1
- package/dist/ipc/MessageBroker.d.ts.map +1 -1
- package/dist/ipc/MessageBroker.js +33 -6
- package/dist/ipc/MessageBroker.js.map +1 -1
- package/dist/ipc/MessageBroker.test.js +26 -28
- package/dist/ipc/MessageBroker.test.js.map +1 -1
- package/dist/ipc/devInspectorBridge.d.ts +57 -0
- package/dist/ipc/devInspectorBridge.d.ts.map +1 -0
- package/dist/ipc/devInspectorBridge.js +70 -0
- package/dist/ipc/devInspectorBridge.js.map +1 -0
- package/dist/ipc/devInspectorBridge.test.d.ts +2 -0
- package/dist/ipc/devInspectorBridge.test.d.ts.map +1 -0
- package/dist/ipc/devInspectorBridge.test.js +128 -0
- package/dist/ipc/devInspectorBridge.test.js.map +1 -0
- package/dist/ipc/namespaces.d.ts +1 -1
- package/dist/ipc/namespaces.d.ts.map +1 -1
- package/dist/ipc/namespaces.js +4 -7
- package/dist/ipc/namespaces.js.map +1 -1
- package/dist/ipc/namespaces.test.js +11 -13
- package/dist/ipc/namespaces.test.js.map +1 -1
- package/dist/lib/focusTracker.js +1 -4
- package/dist/lib/focusTracker.js.map +1 -1
- package/dist/lib/focusTracker.test.js +32 -57
- package/dist/lib/focusTracker.test.js.map +1 -1
- package/dist/lib/syncProviderBridge.js +1 -4
- package/dist/lib/syncProviderBridge.js.map +1 -1
- package/dist/lib/syncProviderBridge.test.js +60 -85
- package/dist/lib/syncProviderBridge.test.js.map +1 -1
- package/dist/lib/themeInjector.js +3 -8
- package/dist/lib/themeInjector.js.map +1 -1
- package/dist/lib/themeInjector.test.js +42 -44
- package/dist/lib/themeInjector.test.js.map +1 -1
- package/dist/search/SearchEngine.js +3 -10
- package/dist/search/SearchEngine.js.map +1 -1
- package/dist/search/SearchEngine.test.js +53 -55
- package/dist/search/SearchEngine.test.js.map +1 -1
- package/dist/search/index.js +2 -8
- package/dist/search/index.js.map +1 -1
- package/dist/search/textUtils.js +2 -6
- package/dist/search/textUtils.js.map +1 -1
- package/dist/search/textUtils.test.js +73 -75
- package/dist/search/textUtils.test.js.map +1 -1
- package/dist/search/types.js +1 -2
- package/dist/services/AIServiceProxy.js +2 -6
- package/dist/services/AIServiceProxy.js.map +1 -1
- package/dist/services/AIServiceProxy.test.js +69 -71
- package/dist/services/AIServiceProxy.test.js.map +1 -1
- package/dist/services/ActionServiceProxy.d.ts.map +1 -1
- package/dist/services/ActionServiceProxy.js +14 -13
- package/dist/services/ActionServiceProxy.js.map +1 -1
- package/dist/services/ActionServiceProxy.test.js +28 -23
- package/dist/services/ActionServiceProxy.test.js.map +1 -1
- package/dist/services/ApplicationService.js +2 -6
- package/dist/services/ApplicationService.js.map +1 -1
- package/dist/services/ApplicationService.test.js +108 -110
- package/dist/services/ApplicationService.test.js.map +1 -1
- package/dist/services/BaseServiceProxy.js +3 -7
- package/dist/services/BaseServiceProxy.js.map +1 -1
- package/dist/services/CacheServiceProxy.js +2 -6
- package/dist/services/CacheServiceProxy.js.map +1 -1
- package/dist/services/CacheServiceProxy.test.js +21 -23
- package/dist/services/CacheServiceProxy.test.js.map +1 -1
- package/dist/services/ClipboardHistoryServiceProxy.js +6 -10
- package/dist/services/ClipboardHistoryServiceProxy.js.map +1 -1
- package/dist/services/ClipboardHistoryServiceProxy.test.js +106 -108
- package/dist/services/ClipboardHistoryServiceProxy.test.js.map +1 -1
- package/dist/services/CommandServiceProxy.js +7 -11
- package/dist/services/CommandServiceProxy.js.map +1 -1
- package/dist/services/CommandServiceProxy.test.js +37 -39
- package/dist/services/CommandServiceProxy.test.js.map +1 -1
- package/dist/services/EntitlementServiceProxy.js +2 -6
- package/dist/services/EntitlementServiceProxy.js.map +1 -1
- package/dist/services/EntitlementServiceProxy.test.js +16 -18
- package/dist/services/EntitlementServiceProxy.test.js.map +1 -1
- package/dist/services/ExtensionManagerProxy.js +2 -6
- package/dist/services/ExtensionManagerProxy.js.map +1 -1
- package/dist/services/ExtensionManagerProxy.test.js +42 -44
- package/dist/services/ExtensionManagerProxy.test.js.map +1 -1
- package/dist/services/ExtensionRpc.d.ts +90 -0
- package/dist/services/ExtensionRpc.d.ts.map +1 -0
- package/dist/services/ExtensionRpc.js +277 -0
- package/dist/services/ExtensionRpc.js.map +1 -0
- package/dist/services/ExtensionRpc.test.d.ts +2 -0
- package/dist/services/ExtensionRpc.test.d.ts.map +1 -0
- package/dist/services/ExtensionRpc.test.js +259 -0
- package/dist/services/ExtensionRpc.test.js.map +1 -0
- package/dist/services/ExtensionStateProxy.d.ts +44 -0
- package/dist/services/ExtensionStateProxy.d.ts.map +1 -0
- package/dist/services/ExtensionStateProxy.js +115 -0
- package/dist/services/ExtensionStateProxy.js.map +1 -0
- package/dist/services/ExtensionStateProxy.test.d.ts +2 -0
- package/dist/services/ExtensionStateProxy.test.d.ts.map +1 -0
- package/dist/services/ExtensionStateProxy.test.js +158 -0
- package/dist/services/ExtensionStateProxy.test.js.map +1 -0
- package/dist/services/FeedbackServiceProxy.js +2 -6
- package/dist/services/FeedbackServiceProxy.js.map +1 -1
- package/dist/services/FeedbackServiceProxy.test.js +31 -33
- package/dist/services/FeedbackServiceProxy.test.js.map +1 -1
- package/dist/services/FileManagerServiceProxy.js +2 -6
- package/dist/services/FileManagerServiceProxy.js.map +1 -1
- package/dist/services/FileManagerServiceProxy.test.js +21 -23
- package/dist/services/FileManagerServiceProxy.test.js.map +1 -1
- package/dist/services/FileSystemWatcherService.js +2 -6
- package/dist/services/FileSystemWatcherService.js.map +1 -1
- package/dist/services/FileSystemWatcherService.test.js +45 -47
- package/dist/services/FileSystemWatcherService.test.js.map +1 -1
- package/dist/services/IAIService.js +1 -2
- package/dist/services/ICacheService.js +1 -2
- package/dist/services/IClipboardHistoryService.js +1 -2
- package/dist/services/ICommandService.js +1 -2
- package/dist/services/IEntitlementService.js +1 -2
- package/dist/services/IExtensionManager.js +1 -2
- package/dist/services/IFeedbackService.js +1 -2
- package/dist/services/IFileManagerService.js +1 -2
- package/dist/services/IInteropService.js +1 -5
- package/dist/services/IInteropService.js.map +1 -1
- package/dist/services/INotificationService.js +1 -2
- package/dist/services/IOAuthService.js +1 -2
- package/dist/services/IPowerService.js +1 -2
- package/dist/services/IPreferencesService.js +1 -2
- package/dist/services/ISelectionService.js +1 -2
- package/dist/services/ISettingsService.js +1 -2
- package/dist/services/IShellService.js +1 -2
- package/dist/services/IStatusBarService.js +1 -2
- package/dist/services/IStorageService.js +1 -2
- package/dist/services/ISystemEventsService.js +1 -2
- package/dist/services/ISystemEventsService.js.map +1 -1
- package/dist/services/ITimerService.js +1 -2
- package/dist/services/InteropServiceProxy.js +2 -6
- package/dist/services/InteropServiceProxy.js.map +1 -1
- package/dist/services/InteropServiceProxy.test.js +19 -21
- package/dist/services/InteropServiceProxy.test.js.map +1 -1
- package/dist/services/LogService.js +1 -2
- package/dist/services/LogServiceProxy.js +2 -6
- package/dist/services/LogServiceProxy.js.map +1 -1
- package/dist/services/LogServiceProxy.test.js +43 -45
- package/dist/services/LogServiceProxy.test.js.map +1 -1
- package/dist/services/NetworkServiceProxy.js +2 -6
- package/dist/services/NetworkServiceProxy.js.map +1 -1
- package/dist/services/NetworkServiceProxy.test.js +20 -22
- package/dist/services/NetworkServiceProxy.test.js.map +1 -1
- package/dist/services/NotificationServiceProxy.js +2 -6
- package/dist/services/NotificationServiceProxy.js.map +1 -1
- package/dist/services/NotificationServiceProxy.test.js +39 -41
- package/dist/services/NotificationServiceProxy.test.js.map +1 -1
- package/dist/services/OAuthServiceProxy.js +2 -6
- package/dist/services/OAuthServiceProxy.js.map +1 -1
- package/dist/services/OAuthServiceProxy.test.js +42 -44
- package/dist/services/OAuthServiceProxy.test.js.map +1 -1
- package/dist/services/PowerServiceProxy.js +2 -6
- package/dist/services/PowerServiceProxy.js.map +1 -1
- package/dist/services/PowerServiceProxy.test.js +24 -26
- package/dist/services/PowerServiceProxy.test.js.map +1 -1
- package/dist/services/PreferencesServiceProxy.js +2 -6
- package/dist/services/PreferencesServiceProxy.js.map +1 -1
- package/dist/services/PreferencesServiceProxy.test.js +22 -24
- package/dist/services/PreferencesServiceProxy.test.js.map +1 -1
- package/dist/services/SelectionServiceProxy.js +2 -6
- package/dist/services/SelectionServiceProxy.js.map +1 -1
- package/dist/services/SelectionServiceProxy.test.js +20 -22
- package/dist/services/SelectionServiceProxy.test.js.map +1 -1
- package/dist/services/SettingsServiceProxy.js +2 -6
- package/dist/services/SettingsServiceProxy.js.map +1 -1
- package/dist/services/SettingsServiceProxy.test.js +18 -20
- package/dist/services/SettingsServiceProxy.test.js.map +1 -1
- package/dist/services/ShellServiceProxy.js +2 -6
- package/dist/services/ShellServiceProxy.js.map +1 -1
- package/dist/services/ShellServiceProxy.test.js +92 -94
- package/dist/services/ShellServiceProxy.test.js.map +1 -1
- package/dist/services/StatusBarServiceProxy.js +9 -13
- package/dist/services/StatusBarServiceProxy.js.map +1 -1
- package/dist/services/StatusBarServiceProxy.test.js +68 -70
- package/dist/services/StatusBarServiceProxy.test.js.map +1 -1
- package/dist/services/StorageServiceProxy.js +2 -6
- package/dist/services/StorageServiceProxy.js.map +1 -1
- package/dist/services/StorageServiceProxy.test.js +31 -33
- package/dist/services/StorageServiceProxy.test.js.map +1 -1
- package/dist/services/SystemEventsServiceProxy.js +2 -6
- package/dist/services/SystemEventsServiceProxy.js.map +1 -1
- package/dist/services/SystemEventsServiceProxy.test.js +50 -52
- package/dist/services/SystemEventsServiceProxy.test.js.map +1 -1
- package/dist/services/TimerServiceProxy.js +2 -6
- package/dist/services/TimerServiceProxy.js.map +1 -1
- package/dist/services/TimerServiceProxy.test.js +33 -35
- package/dist/services/TimerServiceProxy.test.js.map +1 -1
- package/dist/services/WindowManagementService.js +2 -6
- package/dist/services/WindowManagementService.js.map +1 -1
- package/dist/services/WindowManagementService.test.js +23 -25
- package/dist/services/WindowManagementService.test.js.map +1 -1
- package/dist/services/index.js +36 -76
- package/dist/services/index.js.map +1 -1
- package/dist/services/statusBarValidation.js +7 -14
- package/dist/services/statusBarValidation.js.map +1 -1
- package/dist/types/ActionType.js +3 -6
- package/dist/types/ActionType.js.map +1 -1
- package/dist/types/ApplicationType.js +1 -2
- package/dist/types/ClipboardType.js +2 -5
- package/dist/types/ClipboardType.js.map +1 -1
- package/dist/types/CommandType.js +1 -2
- package/dist/types/ExtensionType.d.ts +40 -5
- package/dist/types/ExtensionType.d.ts.map +1 -1
- package/dist/types/ExtensionType.js +1 -2
- package/dist/types/NetworkType.js +1 -2
- package/dist/types/NotificationType.js +1 -2
- package/dist/types/SyncType.js +1 -2
- package/dist/types/index.js +2 -18
- package/dist/types/index.js.map +1 -1
- package/dist/view.d.ts +12 -0
- package/dist/view.d.ts.map +1 -0
- package/dist/view.js +19 -0
- package/dist/view.js.map +1 -0
- package/dist/view.test.d.ts +2 -0
- package/dist/view.test.d.ts.map +1 -0
- package/dist/view.test.js +114 -0
- package/dist/view.test.js.map +1 -0
- package/dist/worker.bundle-size.test.d.ts +2 -0
- package/dist/worker.bundle-size.test.d.ts.map +1 -0
- package/dist/worker.bundle-size.test.js +96 -0
- package/dist/worker.bundle-size.test.js.map +1 -0
- package/dist/worker.d.ts +37 -0
- package/dist/worker.d.ts.map +1 -0
- package/dist/worker.js +122 -0
- package/dist/worker.js.map +1 -0
- package/dist/worker.test.d.ts +2 -0
- package/dist/worker.test.d.ts.map +1 -0
- package/dist/worker.test.js +136 -0
- package/dist/worker.test.js.map +1 -0
- package/package.json +12 -4
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -47
- package/dist/index.js.map +0 -1
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
2
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
3
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -8,26 +7,25 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
7
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
8
|
});
|
|
10
9
|
};
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
vitest_1.vi.mock('../ipc/MessageBroker', () => ({
|
|
10
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
11
|
+
import { OAuthServiceProxy } from './OAuthServiceProxy';
|
|
12
|
+
import { messageBroker } from '../ipc/MessageBroker';
|
|
13
|
+
vi.mock('../ipc/MessageBroker', () => ({
|
|
16
14
|
messageBroker: {
|
|
17
|
-
invoke:
|
|
18
|
-
on:
|
|
19
|
-
off:
|
|
15
|
+
invoke: vi.fn(),
|
|
16
|
+
on: vi.fn(),
|
|
17
|
+
off: vi.fn(),
|
|
20
18
|
},
|
|
21
19
|
}));
|
|
22
20
|
// ── Helpers ───────────────────────────────────────────────────────────────────
|
|
23
21
|
function makeProxy() {
|
|
24
|
-
const mockInvoke =
|
|
25
|
-
Object.assign(
|
|
22
|
+
const mockInvoke = vi.fn();
|
|
23
|
+
Object.assign(messageBroker, {
|
|
26
24
|
invoke: mockInvoke,
|
|
27
|
-
on:
|
|
28
|
-
off:
|
|
25
|
+
on: vi.fn(),
|
|
26
|
+
off: vi.fn(),
|
|
29
27
|
});
|
|
30
|
-
const proxy = new
|
|
28
|
+
const proxy = new OAuthServiceProxy();
|
|
31
29
|
proxy.setExtensionId('ext.test');
|
|
32
30
|
return { proxy, mockInvoke };
|
|
33
31
|
}
|
|
@@ -54,22 +52,22 @@ function fireOAuthResult(flowId, payload) {
|
|
|
54
52
|
}));
|
|
55
53
|
}
|
|
56
54
|
// ── Tests ─────────────────────────────────────────────────────────────────────
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
55
|
+
describe('OAuthServiceProxy', () => {
|
|
56
|
+
beforeEach(() => {
|
|
57
|
+
vi.clearAllMocks();
|
|
60
58
|
});
|
|
61
|
-
|
|
62
|
-
|
|
59
|
+
describe('authorize()', () => {
|
|
60
|
+
it('resolves immediately when IPC response contains a cached token', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
63
61
|
const { proxy, mockInvoke } = makeProxy();
|
|
64
62
|
const token = validToken();
|
|
65
63
|
// Host returned cached token directly in IPC response
|
|
66
64
|
mockInvoke.mockResolvedValue(token);
|
|
67
65
|
const result = yield proxy.authorize(validConfig());
|
|
68
|
-
|
|
66
|
+
expect(result).toEqual(token);
|
|
69
67
|
// setExtensionId patches invoke → originalInvoke(cmd, payload, extensionId, timeoutMs)
|
|
70
68
|
const [cmd, payload] = mockInvoke.mock.calls[0];
|
|
71
|
-
|
|
72
|
-
|
|
69
|
+
expect(cmd).toBe('oauth:authorize');
|
|
70
|
+
expect(payload).toMatchObject({
|
|
73
71
|
providerId: 'github',
|
|
74
72
|
clientId: 'my-client-id',
|
|
75
73
|
authorizationUrl: 'https://github.com/login/oauth/authorize',
|
|
@@ -77,16 +75,16 @@ function fireOAuthResult(flowId, payload) {
|
|
|
77
75
|
scopes: ['repo'],
|
|
78
76
|
});
|
|
79
77
|
}));
|
|
80
|
-
|
|
78
|
+
it('payload key order matches host service parameter order', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
81
79
|
const { proxy, mockInvoke } = makeProxy();
|
|
82
80
|
mockInvoke.mockResolvedValue(validToken());
|
|
83
81
|
yield proxy.authorize(validConfig());
|
|
84
82
|
const payload = mockInvoke.mock.calls[0][1];
|
|
85
83
|
const keys = Object.keys(payload);
|
|
86
84
|
// Must match: providerId, clientId, authorizationUrl, tokenUrl, scopes, flowId
|
|
87
|
-
|
|
85
|
+
expect(keys).toEqual(['providerId', 'clientId', 'authorizationUrl', 'tokenUrl', 'scopes', 'flowId']);
|
|
88
86
|
}));
|
|
89
|
-
|
|
87
|
+
it('resolves via asyar:oauth:result postMessage when host returns pending:true', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
90
88
|
const { proxy, mockInvoke } = makeProxy();
|
|
91
89
|
const token = validToken();
|
|
92
90
|
let capturedFlowId;
|
|
@@ -96,13 +94,13 @@ function fireOAuthResult(flowId, payload) {
|
|
|
96
94
|
});
|
|
97
95
|
const promise = proxy.authorize(validConfig());
|
|
98
96
|
// Wait for invoke to fire and capture flowId
|
|
99
|
-
yield
|
|
97
|
+
yield vi.waitFor(() => capturedFlowId !== undefined);
|
|
100
98
|
// Simulate host posting the result
|
|
101
99
|
fireOAuthResult(capturedFlowId, { token });
|
|
102
100
|
const result = yield promise;
|
|
103
|
-
|
|
101
|
+
expect(result).toEqual(token);
|
|
104
102
|
}));
|
|
105
|
-
|
|
103
|
+
it('rejects when asyar:oauth:result carries an error', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
106
104
|
const { proxy, mockInvoke } = makeProxy();
|
|
107
105
|
let capturedFlowId;
|
|
108
106
|
mockInvoke.mockImplementation((_cmd, payload) => {
|
|
@@ -110,18 +108,18 @@ function fireOAuthResult(flowId, payload) {
|
|
|
110
108
|
return Promise.resolve({ pending: true });
|
|
111
109
|
});
|
|
112
110
|
const promise = proxy.authorize(validConfig());
|
|
113
|
-
yield
|
|
111
|
+
yield vi.waitFor(() => capturedFlowId !== undefined);
|
|
114
112
|
fireOAuthResult(capturedFlowId, {
|
|
115
113
|
error: { code: 'access_denied', message: 'User denied access' },
|
|
116
114
|
});
|
|
117
|
-
yield
|
|
115
|
+
yield expect(promise).rejects.toThrow('access_denied');
|
|
118
116
|
}));
|
|
119
|
-
|
|
117
|
+
it('rejects when invoke itself fails', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
120
118
|
const { proxy, mockInvoke } = makeProxy();
|
|
121
119
|
mockInvoke.mockRejectedValue(new Error('Permission denied: oauth:use'));
|
|
122
|
-
yield
|
|
120
|
+
yield expect(proxy.authorize(validConfig())).rejects.toThrow('Permission denied');
|
|
123
121
|
}));
|
|
124
|
-
|
|
122
|
+
it('ignores asyar:oauth:result messages with a different flowId', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
125
123
|
const { proxy, mockInvoke } = makeProxy();
|
|
126
124
|
const token = validToken();
|
|
127
125
|
let capturedFlowId;
|
|
@@ -130,33 +128,33 @@ function fireOAuthResult(flowId, payload) {
|
|
|
130
128
|
return Promise.resolve({ pending: true });
|
|
131
129
|
});
|
|
132
130
|
const promise = proxy.authorize(validConfig());
|
|
133
|
-
yield
|
|
131
|
+
yield vi.waitFor(() => capturedFlowId !== undefined);
|
|
134
132
|
// Fire a message with a wrong flowId — should be ignored
|
|
135
133
|
fireOAuthResult('wrong-flow-id', { token });
|
|
136
134
|
// Fire the correct one
|
|
137
135
|
fireOAuthResult(capturedFlowId, { token });
|
|
138
136
|
const result = yield promise;
|
|
139
|
-
|
|
137
|
+
expect(result).toEqual(token);
|
|
140
138
|
}));
|
|
141
|
-
|
|
139
|
+
it('cleans up listener after cached token resolve', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
142
140
|
const { proxy, mockInvoke } = makeProxy();
|
|
143
141
|
const token = validToken();
|
|
144
|
-
const addSpy =
|
|
145
|
-
const removeSpy =
|
|
142
|
+
const addSpy = vi.spyOn(window, 'addEventListener');
|
|
143
|
+
const removeSpy = vi.spyOn(window, 'removeEventListener');
|
|
146
144
|
mockInvoke.mockResolvedValue(token);
|
|
147
145
|
yield proxy.authorize(validConfig());
|
|
148
|
-
|
|
149
|
-
|
|
146
|
+
expect(addSpy).toHaveBeenCalledWith('message', expect.any(Function));
|
|
147
|
+
expect(removeSpy).toHaveBeenCalledWith('message', expect.any(Function));
|
|
150
148
|
}));
|
|
151
149
|
});
|
|
152
|
-
|
|
153
|
-
|
|
150
|
+
describe('revokeToken()', () => {
|
|
151
|
+
it('invokes revokeToken with correct providerId', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
154
152
|
const { proxy, mockInvoke } = makeProxy();
|
|
155
153
|
mockInvoke.mockResolvedValue(undefined);
|
|
156
154
|
yield proxy.revokeToken('github');
|
|
157
155
|
const [cmd, payload] = mockInvoke.mock.calls[0];
|
|
158
|
-
|
|
159
|
-
|
|
156
|
+
expect(cmd).toBe('oauth:revokeToken');
|
|
157
|
+
expect(payload).toEqual({ providerId: 'github' });
|
|
160
158
|
}));
|
|
161
159
|
});
|
|
162
160
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OAuthServiceProxy.test.js","sourceRoot":"","sources":["../../src/services/OAuthServiceProxy.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"OAuthServiceProxy.test.js","sourceRoot":"","sources":["../../src/services/OAuthServiceProxy.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
2
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
3
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -8,16 +7,14 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
7
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
8
|
});
|
|
10
9
|
};
|
|
11
|
-
|
|
12
|
-
exports.PowerServiceProxy = void 0;
|
|
13
|
-
const BaseServiceProxy_1 = require("./BaseServiceProxy");
|
|
10
|
+
import { BaseServiceProxy } from './BaseServiceProxy';
|
|
14
11
|
/**
|
|
15
12
|
* SDK proxy for the power inhibitor service.
|
|
16
13
|
*
|
|
17
14
|
* The host's IPC router automatically injects the calling extension's ID
|
|
18
15
|
* into every call, so extensions can only see and release their own tokens.
|
|
19
16
|
*/
|
|
20
|
-
class PowerServiceProxy extends
|
|
17
|
+
export class PowerServiceProxy extends BaseServiceProxy {
|
|
21
18
|
keepAwake(options) {
|
|
22
19
|
return __awaiter(this, void 0, void 0, function* () {
|
|
23
20
|
return this.broker.invoke('power:keepAwake', { options });
|
|
@@ -34,5 +31,4 @@ class PowerServiceProxy extends BaseServiceProxy_1.BaseServiceProxy {
|
|
|
34
31
|
});
|
|
35
32
|
}
|
|
36
33
|
}
|
|
37
|
-
exports.PowerServiceProxy = PowerServiceProxy;
|
|
38
34
|
//# sourceMappingURL=PowerServiceProxy.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PowerServiceProxy.js","sourceRoot":"","sources":["../../src/services/PowerServiceProxy.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PowerServiceProxy.js","sourceRoot":"","sources":["../../src/services/PowerServiceProxy.ts"],"names":[],"mappings":";;;;;;;;;AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEtD;;;;;GAKG;AACH,MAAM,OAAO,iBAAkB,SAAQ,gBAAgB;IAC/C,SAAS,CAAC,OAAyB;;YACvC,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAS,iBAAiB,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;QACpE,CAAC;KAAA;IAEK,OAAO,CAAC,KAAa;;YACzB,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAO,eAAe,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;QAC9D,CAAC;KAAA;IAEK,IAAI;;YACR,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAoB,YAAY,EAAE,EAAE,CAAC,CAAC;QACjE,CAAC;KAAA;CACF"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
2
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
3
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -8,33 +7,32 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
7
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
8
|
});
|
|
10
9
|
};
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
vitest_1.vi.mock('../ipc/MessageBroker', () => ({
|
|
10
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
11
|
+
vi.mock('../ipc/MessageBroker', () => ({
|
|
14
12
|
messageBroker: {
|
|
15
|
-
invoke:
|
|
13
|
+
invoke: vi.fn(),
|
|
16
14
|
},
|
|
17
15
|
}));
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
16
|
+
import { PowerServiceProxy } from './PowerServiceProxy';
|
|
17
|
+
import { messageBroker } from '../ipc/MessageBroker';
|
|
18
|
+
describe('PowerServiceProxy', () => {
|
|
21
19
|
let proxy;
|
|
22
20
|
let mockBroker;
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
mockBroker =
|
|
26
|
-
proxy = new
|
|
21
|
+
beforeEach(() => {
|
|
22
|
+
vi.clearAllMocks();
|
|
23
|
+
mockBroker = messageBroker;
|
|
24
|
+
proxy = new PowerServiceProxy();
|
|
27
25
|
});
|
|
28
|
-
|
|
29
|
-
|
|
26
|
+
it('keepAwake invokes power:keepAwake with the full payload and returns the token', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
27
|
+
vi.mocked(mockBroker.invoke).mockResolvedValueOnce('token-123');
|
|
30
28
|
const token = yield proxy.keepAwake({
|
|
31
29
|
system: true,
|
|
32
30
|
display: true,
|
|
33
31
|
disk: false,
|
|
34
32
|
reason: 'Transcribing audio',
|
|
35
33
|
});
|
|
36
|
-
|
|
37
|
-
|
|
34
|
+
expect(token).toBe('token-123');
|
|
35
|
+
expect(mockBroker.invoke).toHaveBeenCalledWith('power:keepAwake', {
|
|
38
36
|
options: {
|
|
39
37
|
system: true,
|
|
40
38
|
display: true,
|
|
@@ -43,19 +41,19 @@ const MessageBroker_1 = require("../ipc/MessageBroker");
|
|
|
43
41
|
},
|
|
44
42
|
});
|
|
45
43
|
}));
|
|
46
|
-
|
|
47
|
-
|
|
44
|
+
it('keepAwake with only reason still serializes that field', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
45
|
+
vi.mocked(mockBroker.invoke).mockResolvedValueOnce('token-42');
|
|
48
46
|
yield proxy.keepAwake({ reason: 'default' });
|
|
49
|
-
|
|
47
|
+
expect(mockBroker.invoke).toHaveBeenCalledWith('power:keepAwake', {
|
|
50
48
|
options: { reason: 'default' },
|
|
51
49
|
});
|
|
52
50
|
}));
|
|
53
|
-
|
|
54
|
-
|
|
51
|
+
it('release invokes power:release with the token', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
52
|
+
vi.mocked(mockBroker.invoke).mockResolvedValueOnce(undefined);
|
|
55
53
|
yield proxy.release('tok');
|
|
56
|
-
|
|
54
|
+
expect(mockBroker.invoke).toHaveBeenCalledWith('power:release', { token: 'tok' });
|
|
57
55
|
}));
|
|
58
|
-
|
|
56
|
+
it('list invokes power:list and returns the array', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
59
57
|
const sample = [
|
|
60
58
|
{
|
|
61
59
|
token: 't1',
|
|
@@ -64,10 +62,10 @@ const MessageBroker_1 = require("../ipc/MessageBroker");
|
|
|
64
62
|
createdAt: 1,
|
|
65
63
|
},
|
|
66
64
|
];
|
|
67
|
-
|
|
65
|
+
vi.mocked(mockBroker.invoke).mockResolvedValueOnce(sample);
|
|
68
66
|
const list = yield proxy.list();
|
|
69
|
-
|
|
70
|
-
|
|
67
|
+
expect(mockBroker.invoke).toHaveBeenCalledWith('power:list', {});
|
|
68
|
+
expect(list).toEqual(sample);
|
|
71
69
|
}));
|
|
72
70
|
});
|
|
73
71
|
//# sourceMappingURL=PowerServiceProxy.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PowerServiceProxy.test.js","sourceRoot":"","sources":["../../src/services/PowerServiceProxy.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PowerServiceProxy.test.js","sourceRoot":"","sources":["../../src/services/PowerServiceProxy.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
exports.PreferencesServiceProxy = void 0;
|
|
4
|
-
const BaseServiceProxy_1 = require("./BaseServiceProxy");
|
|
5
|
-
class PreferencesServiceProxy extends BaseServiceProxy_1.BaseServiceProxy {
|
|
1
|
+
import { BaseServiceProxy } from './BaseServiceProxy';
|
|
2
|
+
export class PreferencesServiceProxy extends BaseServiceProxy {
|
|
6
3
|
getAll() {
|
|
7
4
|
return this.broker.invoke('preferences:getAll');
|
|
8
5
|
}
|
|
@@ -13,5 +10,4 @@ class PreferencesServiceProxy extends BaseServiceProxy_1.BaseServiceProxy {
|
|
|
13
10
|
return this.broker.invoke('preferences:reset', { scope });
|
|
14
11
|
}
|
|
15
12
|
}
|
|
16
|
-
exports.PreferencesServiceProxy = PreferencesServiceProxy;
|
|
17
13
|
//# sourceMappingURL=PreferencesServiceProxy.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PreferencesServiceProxy.js","sourceRoot":"","sources":["../../src/services/PreferencesServiceProxy.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PreferencesServiceProxy.js","sourceRoot":"","sources":["../../src/services/PreferencesServiceProxy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEtD,MAAM,OAAO,uBAAwB,SAAQ,gBAAgB;IAC3D,MAAM;QACJ,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAkB,oBAAoB,CAAC,CAAC;IACnE,CAAC;IAED,GAAG,CAAC,KAAa,EAAE,GAAW,EAAE,KAAc;QAC5C,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAO,iBAAiB,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;IAC5E,CAAC;IAED,KAAK,CAAC,KAAa;QACjB,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAO,mBAAmB,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;IAClE,CAAC;CACF"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
2
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
3
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -8,49 +7,48 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
7
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
8
|
});
|
|
10
9
|
};
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
vitest_1.vi.mock('../ipc/MessageBroker', () => ({
|
|
10
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
11
|
+
import { PreferencesServiceProxy } from './PreferencesServiceProxy';
|
|
12
|
+
import { messageBroker } from '../ipc/MessageBroker';
|
|
13
|
+
vi.mock('../ipc/MessageBroker', () => ({
|
|
16
14
|
messageBroker: {
|
|
17
|
-
invoke:
|
|
18
|
-
on:
|
|
19
|
-
off:
|
|
15
|
+
invoke: vi.fn().mockResolvedValue(undefined),
|
|
16
|
+
on: vi.fn(),
|
|
17
|
+
off: vi.fn(),
|
|
20
18
|
},
|
|
21
19
|
}));
|
|
22
20
|
function makeProxy() {
|
|
23
|
-
const mockInvoke =
|
|
24
|
-
Object.assign(
|
|
21
|
+
const mockInvoke = vi.fn().mockResolvedValue(undefined);
|
|
22
|
+
Object.assign(messageBroker, {
|
|
25
23
|
invoke: mockInvoke,
|
|
26
|
-
on:
|
|
27
|
-
off:
|
|
24
|
+
on: vi.fn(),
|
|
25
|
+
off: vi.fn(),
|
|
28
26
|
});
|
|
29
|
-
const proxy = new
|
|
27
|
+
const proxy = new PreferencesServiceProxy();
|
|
30
28
|
proxy.setExtensionId('ext.test');
|
|
31
29
|
return { proxy, mockInvoke };
|
|
32
30
|
}
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
31
|
+
describe('PreferencesServiceProxy', () => {
|
|
32
|
+
beforeEach(() => vi.clearAllMocks());
|
|
33
|
+
it('getAll → "preferences:getAll"', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
36
34
|
const { proxy, mockInvoke } = makeProxy();
|
|
37
35
|
yield proxy.getAll();
|
|
38
36
|
const call = mockInvoke.mock.calls.find((c) => c[0] === 'preferences:getAll');
|
|
39
|
-
|
|
37
|
+
expect(call).toBeDefined();
|
|
40
38
|
}));
|
|
41
|
-
|
|
39
|
+
it('set → "preferences:set" with payload', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
42
40
|
const { proxy, mockInvoke } = makeProxy();
|
|
43
41
|
yield proxy.set('extension', 'theme', 'dark');
|
|
44
42
|
const call = mockInvoke.mock.calls.find((c) => c[0] === 'preferences:set');
|
|
45
|
-
|
|
46
|
-
|
|
43
|
+
expect(call).toBeDefined();
|
|
44
|
+
expect(call[1]).toMatchObject({ scope: 'extension', key: 'theme', value: 'dark' });
|
|
47
45
|
}));
|
|
48
|
-
|
|
46
|
+
it('reset → "preferences:reset" with scope', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
49
47
|
const { proxy, mockInvoke } = makeProxy();
|
|
50
48
|
yield proxy.reset('extension');
|
|
51
49
|
const call = mockInvoke.mock.calls.find((c) => c[0] === 'preferences:reset');
|
|
52
|
-
|
|
53
|
-
|
|
50
|
+
expect(call).toBeDefined();
|
|
51
|
+
expect(call[1]).toMatchObject({ scope: 'extension' });
|
|
54
52
|
}));
|
|
55
53
|
});
|
|
56
54
|
//# sourceMappingURL=PreferencesServiceProxy.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PreferencesServiceProxy.test.js","sourceRoot":"","sources":["../../src/services/PreferencesServiceProxy.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PreferencesServiceProxy.test.js","sourceRoot":"","sources":["../../src/services/PreferencesServiceProxy.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SelectionServiceProxy = void 0;
|
|
4
|
-
const BaseServiceProxy_1 = require("./BaseServiceProxy");
|
|
1
|
+
import { BaseServiceProxy } from './BaseServiceProxy';
|
|
5
2
|
/**
|
|
6
3
|
* Proxy for the Selection service, mapping SDK calls to IPC commands.
|
|
7
4
|
*/
|
|
8
|
-
class SelectionServiceProxy extends
|
|
5
|
+
export class SelectionServiceProxy extends BaseServiceProxy {
|
|
9
6
|
getSelectedText() {
|
|
10
7
|
return this.broker.invoke('selection:getSelectedText', {}, undefined, 5000);
|
|
11
8
|
}
|
|
@@ -13,5 +10,4 @@ class SelectionServiceProxy extends BaseServiceProxy_1.BaseServiceProxy {
|
|
|
13
10
|
return this.broker.invoke('selection:getSelectedFinderItems', {}, undefined, 5000);
|
|
14
11
|
}
|
|
15
12
|
}
|
|
16
|
-
exports.SelectionServiceProxy = SelectionServiceProxy;
|
|
17
13
|
//# sourceMappingURL=SelectionServiceProxy.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectionServiceProxy.js","sourceRoot":"","sources":["../../src/services/SelectionServiceProxy.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"SelectionServiceProxy.js","sourceRoot":"","sources":["../../src/services/SelectionServiceProxy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAGrD;;GAEG;AACH,MAAM,OAAO,qBAAsB,SAAQ,gBAAgB;IACzD,eAAe;QACb,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CACvB,2BAA2B,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;IACtD,CAAC;IAED,sBAAsB;QACpB,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CACvB,kCAAkC,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;IAC7D,CAAC;CACF"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
2
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
3
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -8,45 +7,44 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
7
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
8
|
});
|
|
10
9
|
};
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
vitest_1.vi.mock('../ipc/MessageBroker', () => ({
|
|
10
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
11
|
+
import { SelectionServiceProxy } from './SelectionServiceProxy';
|
|
12
|
+
import { messageBroker } from '../ipc/MessageBroker';
|
|
13
|
+
vi.mock('../ipc/MessageBroker', () => ({
|
|
16
14
|
messageBroker: {
|
|
17
|
-
invoke:
|
|
18
|
-
on:
|
|
19
|
-
off:
|
|
15
|
+
invoke: vi.fn(),
|
|
16
|
+
on: vi.fn(),
|
|
17
|
+
off: vi.fn(),
|
|
20
18
|
},
|
|
21
19
|
}));
|
|
22
20
|
function makeProxy() {
|
|
23
|
-
const mockInvoke =
|
|
24
|
-
Object.assign(
|
|
21
|
+
const mockInvoke = vi.fn().mockResolvedValue(undefined);
|
|
22
|
+
Object.assign(messageBroker, {
|
|
25
23
|
invoke: mockInvoke,
|
|
26
|
-
on:
|
|
27
|
-
off:
|
|
24
|
+
on: vi.fn(),
|
|
25
|
+
off: vi.fn(),
|
|
28
26
|
});
|
|
29
|
-
const proxy = new
|
|
27
|
+
const proxy = new SelectionServiceProxy();
|
|
30
28
|
proxy.setExtensionId('ext.test');
|
|
31
29
|
return { proxy, mockInvoke };
|
|
32
30
|
}
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
31
|
+
describe('SelectionServiceProxy', () => {
|
|
32
|
+
beforeEach(() => vi.clearAllMocks());
|
|
33
|
+
it('getSelectedText → "selection:getSelectedText"', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
36
34
|
const { proxy, mockInvoke } = makeProxy();
|
|
37
35
|
mockInvoke.mockResolvedValue('hello world');
|
|
38
36
|
const result = yield proxy.getSelectedText();
|
|
39
37
|
const call = mockInvoke.mock.calls.find((c) => c[0] === 'selection:getSelectedText');
|
|
40
|
-
|
|
41
|
-
|
|
38
|
+
expect(call).toBeDefined();
|
|
39
|
+
expect(result).toBe('hello world');
|
|
42
40
|
}));
|
|
43
|
-
|
|
41
|
+
it('getSelectedFinderItems → "selection:getSelectedFinderItems"', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
44
42
|
const { proxy, mockInvoke } = makeProxy();
|
|
45
43
|
mockInvoke.mockResolvedValue(['/path/a', '/path/b']);
|
|
46
44
|
const result = yield proxy.getSelectedFinderItems();
|
|
47
45
|
const call = mockInvoke.mock.calls.find((c) => c[0] === 'selection:getSelectedFinderItems');
|
|
48
|
-
|
|
49
|
-
|
|
46
|
+
expect(call).toBeDefined();
|
|
47
|
+
expect(result).toEqual(['/path/a', '/path/b']);
|
|
50
48
|
}));
|
|
51
49
|
});
|
|
52
50
|
//# sourceMappingURL=SelectionServiceProxy.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectionServiceProxy.test.js","sourceRoot":"","sources":["../../src/services/SelectionServiceProxy.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"SelectionServiceProxy.test.js","sourceRoot":"","sources":["../../src/services/SelectionServiceProxy.test.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAC9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,EAAE,CAAC,IAAI,CAAC,sBAAsB,EAAE,GAAG,EAAE,CAAC,CAAC;IACrC,aAAa,EAAE;QACX,MAAM,EAAE,EAAE,CAAC,EAAE,EAAE;QACf,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE;QACX,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE;KACb;CACJ,CAAC,CAAC,CAAC;AAEJ,SAAS,SAAS;IAChB,MAAM,UAAU,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;IACxD,MAAM,CAAC,MAAM,CAAC,aAAa,EAAE;QAC3B,MAAM,EAAE,UAAU;QAClB,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE;QACX,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE;KACb,CAAC,CAAC;IACH,MAAM,KAAK,GAAG,IAAI,qBAAqB,EAAE,CAAC;IAC1C,KAAK,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;IACjC,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC;AAC/B,CAAC;AAED,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,UAAU,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC,CAAC;IAErC,EAAE,CAAC,+CAA+C,EAAE,GAAS,EAAE;QAC7D,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,SAAS,EAAE,CAAC;QAC1C,UAAU,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;QAC5C,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,eAAe,EAAE,CAAC;QAC7C,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CACrC,CAAC,CAAY,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,2BAA2B,CACvD,CAAC;QACF,MAAM,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;QAC3B,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACrC,CAAC,CAAA,CAAC,CAAC;IAEH,EAAE,CAAC,6DAA6D,EAAE,GAAS,EAAE;QAC3E,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,SAAS,EAAE,CAAC;QAC1C,UAAU,CAAC,iBAAiB,CAAC,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC;QACrD,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,sBAAsB,EAAE,CAAC;QACpD,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CACrC,CAAC,CAAY,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,kCAAkC,CAC9D,CAAC;QACF,MAAM,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;QAC3B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC;IACjD,CAAC,CAAA,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
1
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
2
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
3
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -8,10 +7,8 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
7
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
8
|
});
|
|
10
9
|
};
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
const BaseServiceProxy_1 = require("./BaseServiceProxy");
|
|
14
|
-
class SettingsServiceProxy extends BaseServiceProxy_1.BaseServiceProxy {
|
|
10
|
+
import { BaseServiceProxy } from './BaseServiceProxy';
|
|
11
|
+
export class SettingsServiceProxy extends BaseServiceProxy {
|
|
15
12
|
get(section, key) {
|
|
16
13
|
return __awaiter(this, void 0, void 0, function* () {
|
|
17
14
|
return this.broker.invoke('settings:get', { section, key });
|
|
@@ -35,5 +32,4 @@ class SettingsServiceProxy extends BaseServiceProxy_1.BaseServiceProxy {
|
|
|
35
32
|
};
|
|
36
33
|
}
|
|
37
34
|
}
|
|
38
|
-
exports.SettingsServiceProxy = SettingsServiceProxy;
|
|
39
35
|
//# sourceMappingURL=SettingsServiceProxy.js.map
|