@backstage/backend-test-utils 1.7.1-next.0 → 1.8.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/CHANGELOG.md +26 -0
- package/dist/alpha/services/ActionsRegistryServiceMock.cjs.js.map +1 -1
- package/dist/alpha/services/ActionsServiceMock.cjs.js.map +1 -1
- package/dist/alpha/services/MockActionsRegistry.cjs.js.map +1 -1
- package/dist/alpha/services/simpleMock.cjs.js.map +1 -1
- package/dist/backend-app-api/src/lib/DependencyGraph.cjs.js.map +1 -1
- package/dist/backend-app-api/src/wiring/ServiceRegistry.cjs.js.map +1 -1
- package/dist/cache/TestCaches.cjs.js.map +1 -1
- package/dist/cache/memcache.cjs.js.map +1 -1
- package/dist/cache/redis.cjs.js.map +1 -1
- package/dist/cache/types.cjs.js.map +1 -1
- package/dist/cache/valkey.cjs.js.map +1 -1
- package/dist/database/TestDatabases.cjs.js.map +1 -1
- package/dist/database/mysql.cjs.js.map +1 -1
- package/dist/database/postgres.cjs.js.map +1 -1
- package/dist/database/sqlite.cjs.js.map +1 -1
- package/dist/database/types.cjs.js.map +1 -1
- package/dist/filesystem/MockDirectory.cjs.js.map +1 -1
- package/dist/index.d.ts +15 -4
- package/dist/msw/registerMswTestHooks.cjs.js.map +1 -1
- package/dist/services/MockAuthService.cjs.js.map +1 -1
- package/dist/services/MockEventsService.cjs.js.map +1 -1
- package/dist/services/MockHttpAuthService.cjs.js.map +1 -1
- package/dist/services/MockPermissionsService.cjs.js.map +1 -1
- package/dist/services/MockRootLoggerService.cjs.js.map +1 -1
- package/dist/services/MockSchedulerService.cjs.js +123 -0
- package/dist/services/MockSchedulerService.cjs.js.map +1 -0
- package/dist/services/MockUserInfoService.cjs.js.map +1 -1
- package/dist/services/mockCredentials.cjs.js.map +1 -1
- package/dist/services/mockServices.cjs.js +7 -3
- package/dist/services/mockServices.cjs.js.map +1 -1
- package/dist/services/simpleMock.cjs.js.map +1 -1
- package/dist/util/errorHandler.cjs.js +1 -1
- package/dist/util/errorHandler.cjs.js.map +1 -1
- package/dist/util/getDockerImageForName.cjs.js.map +1 -1
- package/dist/util/isDockerDisabledForTests.cjs.js.map +1 -1
- package/dist/wiring/ServiceFactoryTester.cjs.js.map +1 -1
- package/dist/wiring/TestBackend.cjs.js.map +1 -1
- package/package.json +11 -11
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var backendPluginApi = require('@backstage/backend-plugin-api');
|
|
4
|
+
var types = require('@backstage/types');
|
|
5
|
+
|
|
6
|
+
class MockSchedulerService {
|
|
7
|
+
#tasks = /* @__PURE__ */ new Map();
|
|
8
|
+
#runningTasks = /* @__PURE__ */ new Set();
|
|
9
|
+
#deferredTaskCompletions = /* @__PURE__ */ new Map();
|
|
10
|
+
/**
|
|
11
|
+
* Creates a service factory for this mock scheduler instance, which can be installed in a test backend
|
|
12
|
+
*/
|
|
13
|
+
factory(options) {
|
|
14
|
+
return backendPluginApi.createServiceFactory({
|
|
15
|
+
service: backendPluginApi.coreServices.scheduler,
|
|
16
|
+
deps: { lifecycle: backendPluginApi.coreServices.lifecycle },
|
|
17
|
+
factory: async ({ lifecycle }) => {
|
|
18
|
+
if (!options?.skipTaskRunOnStartup) {
|
|
19
|
+
lifecycle.addStartupHook(async () => {
|
|
20
|
+
await this.#triggerAllTasks({
|
|
21
|
+
includeManualTasks: options?.includeManualTasksOnStartup,
|
|
22
|
+
includeInitialDelayedTasks: options?.includeInitialDelayedTasksOnStartup
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
lifecycle.addShutdownHook(async () => {
|
|
27
|
+
await this.#shutdownAllTasks();
|
|
28
|
+
});
|
|
29
|
+
return this;
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
createScheduledTaskRunner(schedule) {
|
|
34
|
+
return {
|
|
35
|
+
run: async (task) => {
|
|
36
|
+
await this.scheduleTask({ ...task, ...schedule });
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
async getScheduledTasks() {
|
|
41
|
+
return Array.from(this.#tasks.values()).map(({ descriptor }) => descriptor);
|
|
42
|
+
}
|
|
43
|
+
async scheduleTask(task) {
|
|
44
|
+
this.#tasks.set(task.id, {
|
|
45
|
+
...task,
|
|
46
|
+
descriptor: {
|
|
47
|
+
id: task.id,
|
|
48
|
+
scope: task.scope ?? "global",
|
|
49
|
+
settings: { version: 1 }
|
|
50
|
+
},
|
|
51
|
+
abortControllers: new AbortController()
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
async triggerTask(id) {
|
|
55
|
+
const task = this.#tasks.get(id);
|
|
56
|
+
if (!task) {
|
|
57
|
+
throw new Error(`Task ${id} not found`);
|
|
58
|
+
}
|
|
59
|
+
if (this.#runningTasks.has(id)) {
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
this.#runningTasks.add(id);
|
|
63
|
+
try {
|
|
64
|
+
await task.fn(task.abortControllers.signal);
|
|
65
|
+
this.#deferredTaskCompletions.get(id)?.resolve();
|
|
66
|
+
} catch (error) {
|
|
67
|
+
this.#deferredTaskCompletions.get(id)?.reject(error);
|
|
68
|
+
} finally {
|
|
69
|
+
this.#deferredTaskCompletions.delete(id);
|
|
70
|
+
this.#runningTasks.delete(id);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Trigger all tasks that match the given options, and wait for them to complete.
|
|
75
|
+
*
|
|
76
|
+
* @param options - The options to filter the tasks to trigger
|
|
77
|
+
*/
|
|
78
|
+
async #triggerAllTasks(options) {
|
|
79
|
+
const {
|
|
80
|
+
scope = "all",
|
|
81
|
+
includeManualTasks = false,
|
|
82
|
+
includeInitialDelayedTasks = false
|
|
83
|
+
} = options ?? {};
|
|
84
|
+
const selectedTaskIds = new Array();
|
|
85
|
+
for (const task of this.#tasks.values()) {
|
|
86
|
+
if (task.initialDelay && !includeInitialDelayedTasks) {
|
|
87
|
+
continue;
|
|
88
|
+
}
|
|
89
|
+
if ("trigger" in task.frequency && task.frequency.trigger === "manual" && !includeManualTasks) {
|
|
90
|
+
continue;
|
|
91
|
+
}
|
|
92
|
+
if (scope === "all" || scope === task.scope) {
|
|
93
|
+
selectedTaskIds.push(task.id);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
await Promise.all(selectedTaskIds.map((id) => this.triggerTask(id)));
|
|
97
|
+
}
|
|
98
|
+
async #shutdownAllTasks() {
|
|
99
|
+
for (const task of this.#tasks.values()) {
|
|
100
|
+
task.abortControllers.abort();
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Wait for the task with the given ID to complete.
|
|
105
|
+
*
|
|
106
|
+
* If the task has not yet been scheduled or started, this will wait for it to be scheduled, started, and completed
|
|
107
|
+
*
|
|
108
|
+
* @param id - The task ID to wait for
|
|
109
|
+
* @returns A promise that resolves when the task is completed
|
|
110
|
+
*/
|
|
111
|
+
async waitForTask(id) {
|
|
112
|
+
const existing = this.#deferredTaskCompletions.get(id);
|
|
113
|
+
if (existing) {
|
|
114
|
+
return existing;
|
|
115
|
+
}
|
|
116
|
+
const deferred = types.createDeferred();
|
|
117
|
+
this.#deferredTaskCompletions.set(id, deferred);
|
|
118
|
+
return deferred;
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
exports.MockSchedulerService = MockSchedulerService;
|
|
123
|
+
//# sourceMappingURL=MockSchedulerService.cjs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MockSchedulerService.cjs.js","sources":["../../src/services/MockSchedulerService.ts"],"sourcesContent":["/*\n * Copyright 2025 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n coreServices,\n createServiceFactory,\n SchedulerService,\n SchedulerServiceTaskDescriptor,\n SchedulerServiceTaskInvocationDefinition,\n SchedulerServiceTaskRunner,\n SchedulerServiceTaskScheduleDefinition,\n} from '@backstage/backend-plugin-api';\nimport { createDeferred, DeferredPromise } from '@backstage/types';\n\nexport class MockSchedulerService implements SchedulerService {\n readonly #tasks = new Map<\n string,\n SchedulerServiceTaskInvocationDefinition &\n SchedulerServiceTaskScheduleDefinition & {\n descriptor: SchedulerServiceTaskDescriptor;\n abortControllers: AbortController;\n }\n >();\n readonly #runningTasks = new Set<string>();\n readonly #deferredTaskCompletions = new Map<string, DeferredPromise<void>>();\n\n /**\n * Creates a service factory for this mock scheduler instance, which can be installed in a test backend\n */\n factory(options?: {\n skipTaskRunOnStartup?: boolean;\n includeManualTasksOnStartup?: boolean;\n includeInitialDelayedTasksOnStartup?: boolean;\n }) {\n return createServiceFactory({\n service: coreServices.scheduler,\n deps: { lifecycle: coreServices.lifecycle },\n factory: async ({ lifecycle }) => {\n if (!options?.skipTaskRunOnStartup) {\n lifecycle.addStartupHook(async () => {\n await this.#triggerAllTasks({\n includeManualTasks: options?.includeManualTasksOnStartup,\n includeInitialDelayedTasks:\n options?.includeInitialDelayedTasksOnStartup,\n });\n });\n }\n lifecycle.addShutdownHook(async () => {\n await this.#shutdownAllTasks();\n });\n return this;\n },\n });\n }\n\n createScheduledTaskRunner(\n schedule: SchedulerServiceTaskScheduleDefinition,\n ): SchedulerServiceTaskRunner {\n return {\n run: async task => {\n await this.scheduleTask({ ...task, ...schedule });\n },\n };\n }\n\n async getScheduledTasks(): Promise<SchedulerServiceTaskDescriptor[]> {\n return Array.from(this.#tasks.values()).map(({ descriptor }) => descriptor);\n }\n\n async scheduleTask(\n task: SchedulerServiceTaskScheduleDefinition &\n SchedulerServiceTaskInvocationDefinition,\n ): Promise<void> {\n this.#tasks.set(task.id, {\n ...task,\n descriptor: {\n id: task.id,\n scope: task.scope ?? 'global',\n settings: { version: 1 },\n },\n abortControllers: new AbortController(),\n });\n }\n\n async triggerTask(id: string): Promise<void> {\n const task = this.#tasks.get(id);\n if (!task) {\n throw new Error(`Task ${id} not found`);\n }\n if (this.#runningTasks.has(id)) {\n return;\n }\n this.#runningTasks.add(id);\n try {\n await task.fn(task.abortControllers.signal);\n this.#deferredTaskCompletions.get(id)?.resolve();\n } catch (error) {\n this.#deferredTaskCompletions.get(id)?.reject(error);\n } finally {\n this.#deferredTaskCompletions.delete(id);\n this.#runningTasks.delete(id);\n }\n }\n\n /**\n * Trigger all tasks that match the given options, and wait for them to complete.\n *\n * @param options - The options to filter the tasks to trigger\n */\n async #triggerAllTasks(options?: {\n scope?: 'all' | 'global' | 'local';\n includeInitialDelayedTasks?: boolean;\n includeManualTasks?: boolean;\n }): Promise<void> {\n const {\n scope = 'all',\n includeManualTasks = false,\n includeInitialDelayedTasks = false,\n } = options ?? {};\n\n const selectedTaskIds = new Array<string>();\n for (const task of this.#tasks.values()) {\n if (task.initialDelay && !includeInitialDelayedTasks) {\n continue;\n }\n if (\n 'trigger' in task.frequency &&\n task.frequency.trigger === 'manual' &&\n !includeManualTasks\n ) {\n continue;\n }\n if (scope === 'all' || scope === task.scope) {\n selectedTaskIds.push(task.id);\n }\n }\n\n await Promise.all(selectedTaskIds.map(id => this.triggerTask(id)));\n }\n\n async #shutdownAllTasks() {\n for (const task of this.#tasks.values()) {\n task.abortControllers.abort();\n }\n }\n\n /**\n * Wait for the task with the given ID to complete.\n *\n * If the task has not yet been scheduled or started, this will wait for it to be scheduled, started, and completed\n *\n * @param id - The task ID to wait for\n * @returns A promise that resolves when the task is completed\n */\n async waitForTask(id: string): Promise<void> {\n const existing = this.#deferredTaskCompletions.get(id);\n if (existing) {\n return existing;\n }\n const deferred = createDeferred<void>();\n this.#deferredTaskCompletions.set(id, deferred);\n return deferred;\n }\n}\n"],"names":["createServiceFactory","coreServices","createDeferred"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MockUserInfoService.cjs.js","sources":["../../src/services/MockUserInfoService.ts"],"sourcesContent":["/*\n * Copyright 2024 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n BackstageCredentials,\n BackstageNonePrincipal,\n BackstageServicePrincipal,\n BackstageUserInfo,\n BackstageUserPrincipal,\n UserInfoService,\n} from '@backstage/backend-plugin-api';\nimport { InputError } from '@backstage/errors';\n\n/** @internal */\nexport class MockUserInfoService implements UserInfoService {\n private readonly customInfo: Partial<BackstageUserInfo>;\n\n constructor(customInfo?: Partial<BackstageUserInfo>) {\n this.customInfo = customInfo ?? {};\n }\n\n async getUserInfo(\n credentials: BackstageCredentials,\n ): Promise<BackstageUserInfo> {\n const principal = credentials.principal as\n | BackstageUserPrincipal\n | BackstageServicePrincipal\n | BackstageNonePrincipal;\n\n if (principal.type !== 'user') {\n throw new InputError(\n `User info not available for principal type '${principal.type}'`,\n );\n }\n\n return {\n userEntityRef: principal.userEntityRef,\n ownershipEntityRefs: [principal.userEntityRef],\n ...this.customInfo,\n };\n }\n}\n"],"names":["InputError"],"mappings":";;;;AA2BO,MAAM,
|
|
1
|
+
{"version":3,"file":"MockUserInfoService.cjs.js","sources":["../../src/services/MockUserInfoService.ts"],"sourcesContent":["/*\n * Copyright 2024 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n BackstageCredentials,\n BackstageNonePrincipal,\n BackstageServicePrincipal,\n BackstageUserInfo,\n BackstageUserPrincipal,\n UserInfoService,\n} from '@backstage/backend-plugin-api';\nimport { InputError } from '@backstage/errors';\n\n/** @internal */\nexport class MockUserInfoService implements UserInfoService {\n private readonly customInfo: Partial<BackstageUserInfo>;\n\n constructor(customInfo?: Partial<BackstageUserInfo>) {\n this.customInfo = customInfo ?? {};\n }\n\n async getUserInfo(\n credentials: BackstageCredentials,\n ): Promise<BackstageUserInfo> {\n const principal = credentials.principal as\n | BackstageUserPrincipal\n | BackstageServicePrincipal\n | BackstageNonePrincipal;\n\n if (principal.type !== 'user') {\n throw new InputError(\n `User info not available for principal type '${principal.type}'`,\n );\n }\n\n return {\n userEntityRef: principal.userEntityRef,\n ownershipEntityRefs: [principal.userEntityRef],\n ...this.customInfo,\n };\n }\n}\n"],"names":["InputError"],"mappings":";;;;AA2BO,MAAM,mBAAA,CAA+C;AAAA,EACzC,UAAA;AAAA,EAEjB,YAAY,UAAA,EAAyC;AACnD,IAAA,IAAA,CAAK,UAAA,GAAa,cAAc,EAAC;AAAA,EACnC;AAAA,EAEA,MAAM,YACJ,WAAA,EAC4B;AAC5B,IAAA,MAAM,YAAY,WAAA,CAAY,SAAA;AAK9B,IAAA,IAAI,SAAA,CAAU,SAAS,MAAA,EAAQ;AAC7B,MAAA,MAAM,IAAIA,iBAAA;AAAA,QACR,CAAA,4CAAA,EAA+C,UAAU,IAAI,CAAA,CAAA;AAAA,OAC/D;AAAA,IACF;AAEA,IAAA,OAAO;AAAA,MACL,eAAe,SAAA,CAAU,aAAA;AAAA,MACzB,mBAAA,EAAqB,CAAC,SAAA,CAAU,aAAa,CAAA;AAAA,MAC7C,GAAG,IAAA,CAAK;AAAA,KACV;AAAA,EACF;AACF;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockCredentials.cjs.js","sources":["../../src/services/mockCredentials.ts"],"sourcesContent":["/*\n * Copyright 2024 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n BackstageCredentials,\n BackstageNonePrincipal,\n BackstagePrincipalAccessRestrictions,\n BackstageServicePrincipal,\n BackstageUserPrincipal,\n} from '@backstage/backend-plugin-api';\n\nexport const DEFAULT_MOCK_USER_ENTITY_REF = 'user:default/mock';\nexport const DEFAULT_MOCK_SERVICE_SUBJECT = 'external:test-service';\n\nexport const MOCK_AUTH_COOKIE = 'backstage-auth';\n\nexport const MOCK_NONE_TOKEN = 'mock-none-token';\n\nexport const MOCK_USER_TOKEN = 'mock-user-token';\nexport const MOCK_USER_TOKEN_PREFIX = 'mock-user-token:';\nexport const MOCK_INVALID_USER_TOKEN = 'mock-invalid-user-token';\n\nexport const MOCK_USER_LIMITED_TOKEN_PREFIX = 'mock-limited-user-token:';\nexport const MOCK_INVALID_USER_LIMITED_TOKEN =\n 'mock-invalid-limited-user-token';\n\nexport const MOCK_SERVICE_TOKEN = 'mock-service-token';\nexport const MOCK_SERVICE_TOKEN_PREFIX = 'mock-service-token:';\nexport const MOCK_INVALID_SERVICE_TOKEN = 'mock-invalid-service-token';\n\nfunction validateUserEntityRef(ref: string) {\n if (!ref.match(/^.+:.+\\/.+$/)) {\n throw new TypeError(\n `Invalid user entity reference '${ref}', expected <kind>:<namespace>/<name>`,\n );\n }\n}\n\n/**\n * The payload that can be encoded into a mock user token.\n * @internal\n */\nexport type UserTokenPayload = {\n sub?: string;\n actor?: { subject: string };\n};\n\n/**\n * The payload that can be encoded into a mock service token.\n * @internal\n */\nexport type ServiceTokenPayload = {\n sub?: string; // service subject\n obo?: string; // user entity reference\n target?: string; // target plugin id\n};\n\n/**\n * @public\n */\nexport namespace mockCredentials {\n /**\n * Creates a mocked credentials object for a unauthenticated principal.\n */\n export function none(): BackstageCredentials<BackstageNonePrincipal> {\n const result = {\n $$type: '@backstage/BackstageCredentials',\n principal: { type: 'none' },\n } as const;\n Object.defineProperties(result, {\n toString: {\n enumerable: false,\n configurable: true,\n writable: true,\n value: () => `mockCredentials{nonePrincipal}`,\n },\n });\n return result;\n }\n\n /**\n * Utilities related to none credentials.\n */\n export namespace none {\n /**\n * Returns an authorization header that translates to unauthenticated\n * credentials.\n *\n * This is useful when one wants to explicitly test unauthenticated requests\n * while still using the default behavior of the mock HttpAuthService where\n * it defaults to user credentials.\n */\n export function header(): string {\n // NOTE: there is no .token() version of this because only the\n // HttpAuthService should know about and consume this token\n return `Bearer ${MOCK_NONE_TOKEN}`;\n }\n }\n\n /**\n * Creates a mocked credentials object for a user principal.\n *\n * The default user entity reference is 'user:default/mock'.\n */\n export function user(\n userEntityRef: string = DEFAULT_MOCK_USER_ENTITY_REF,\n options?: { actor?: { subject: string } },\n ): BackstageCredentials<BackstageUserPrincipal> {\n validateUserEntityRef(userEntityRef);\n const result = {\n $$type: '@backstage/BackstageCredentials',\n principal: {\n type: 'user',\n userEntityRef,\n ...(options?.actor && {\n actor: { type: 'service', subject: options.actor.subject } as const,\n }),\n },\n } as const;\n Object.defineProperties(result, {\n toString: {\n enumerable: false,\n configurable: true,\n value: () =>\n `mockCredentials{userPrincipal{${userEntityRef}${\n options?.actor ? `,actor={${options.actor.subject}}` : ''\n }}}`,\n },\n token: {\n enumerable: false,\n configurable: true,\n value: user.token(),\n },\n });\n return result;\n }\n\n /**\n * Utilities related to user credentials.\n */\n export namespace user {\n /**\n * Creates a mocked user token. If a payload is provided it will be encoded\n * into the token and forwarded to the credentials object when authenticated\n * by the mock auth service.\n */\n export function token(\n userEntityRef?: string,\n options?: { actor?: { subject: string } },\n ): string {\n if (userEntityRef) {\n validateUserEntityRef(userEntityRef);\n return `${MOCK_USER_TOKEN_PREFIX}${JSON.stringify({\n sub: userEntityRef,\n ...(options?.actor && {\n actor: { subject: options.actor.subject },\n }),\n } satisfies UserTokenPayload)}`;\n }\n return MOCK_USER_TOKEN;\n }\n\n /**\n * Returns an authorization header with a mocked user token. If a payload is\n * provided it will be encoded into the token and forwarded to the\n * credentials object when authenticated by the mock auth service.\n */\n export function header(userEntityRef?: string): string {\n return `Bearer ${token(userEntityRef)}`;\n }\n\n export function invalidToken(): string {\n return MOCK_INVALID_USER_TOKEN;\n }\n\n export function invalidHeader(): string {\n return `Bearer ${invalidToken()}`;\n }\n }\n\n /**\n * Creates a mocked credentials object for a user principal with limited\n * access.\n *\n * The default user entity reference is 'user:default/mock'.\n */\n export function limitedUser(\n userEntityRef: string = DEFAULT_MOCK_USER_ENTITY_REF,\n ): BackstageCredentials<BackstageUserPrincipal> {\n return user(userEntityRef);\n }\n\n /**\n * Utilities related to limited user credentials.\n */\n export namespace limitedUser {\n /**\n * Creates a mocked limited user token. If a payload is provided it will be\n * encoded into the token and forwarded to the credentials object when\n * authenticated by the mock auth service.\n */\n export function token(\n userEntityRef: string = DEFAULT_MOCK_USER_ENTITY_REF,\n ): string {\n validateUserEntityRef(userEntityRef);\n return `${MOCK_USER_LIMITED_TOKEN_PREFIX}${JSON.stringify({\n sub: userEntityRef,\n } satisfies UserTokenPayload)}`;\n }\n\n /**\n * Returns an authorization header with a mocked limited user token. If a\n * payload is provided it will be encoded into the token and forwarded to\n * the credentials object when authenticated by the mock auth service.\n */\n export function cookie(userEntityRef?: string): string {\n return `${MOCK_AUTH_COOKIE}=${token(userEntityRef)}`;\n }\n\n export function invalidToken(): string {\n return MOCK_INVALID_USER_LIMITED_TOKEN;\n }\n\n export function invalidCookie(): string {\n return `${MOCK_AUTH_COOKIE}=${invalidToken()}`;\n }\n }\n\n /**\n * Creates a mocked credentials object for a service principal.\n *\n * The default subject is 'external:test-service', and no access restrictions.\n */\n export function service(\n subject: string = DEFAULT_MOCK_SERVICE_SUBJECT,\n accessRestrictions?: BackstagePrincipalAccessRestrictions,\n ): BackstageCredentials<BackstageServicePrincipal> {\n const result = {\n $$type: '@backstage/BackstageCredentials',\n principal: {\n type: 'service',\n subject,\n ...(accessRestrictions ? { accessRestrictions } : {}),\n },\n } as const;\n Object.defineProperties(result, {\n toString: {\n enumerable: false,\n configurable: true,\n value: () =>\n `mockCredentials{servicePrincipal{${subject}${\n accessRestrictions\n ? `,accessRestrictions=${JSON.stringify(accessRestrictions)}`\n : ''\n }}}`,\n },\n });\n return result;\n }\n\n /**\n * Utilities related to service credentials.\n */\n export namespace service {\n /**\n * Options for the creation of mock service tokens.\n */\n export type TokenOptions = {\n onBehalfOf: BackstageCredentials;\n targetPluginId: string;\n };\n\n /**\n * Creates a mocked service token. The provided options will be encoded into\n * the token and forwarded to the credentials object when authenticated by\n * the mock auth service.\n */\n export function token(options?: TokenOptions): string {\n if (options) {\n const { targetPluginId, onBehalfOf } = options; // for fixed ordering\n\n const oboPrincipal = onBehalfOf?.principal as\n | BackstageServicePrincipal\n | BackstageUserPrincipal\n | BackstageNonePrincipal;\n const obo =\n oboPrincipal.type === 'user' ? oboPrincipal.userEntityRef : undefined;\n const subject =\n oboPrincipal.type === 'service' ? oboPrincipal.subject : undefined;\n\n return `${MOCK_SERVICE_TOKEN_PREFIX}${JSON.stringify({\n sub: subject,\n obo,\n target: targetPluginId,\n } satisfies ServiceTokenPayload)}`;\n }\n return MOCK_SERVICE_TOKEN;\n }\n\n /**\n * Returns an authorization header with a mocked service token. The provided\n * options will be encoded into the token and forwarded to the credentials\n * object when authenticated by the mock auth service.\n */\n export function header(options?: TokenOptions): string {\n return `Bearer ${token(options)}`;\n }\n\n export function invalidToken(): string {\n return MOCK_INVALID_SERVICE_TOKEN;\n }\n\n export function invalidHeader(): string {\n return `Bearer ${invalidToken()}`;\n }\n }\n}\n"],"names":["mockCredentials","none","user","limitedUser","service"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"mockCredentials.cjs.js","sources":["../../src/services/mockCredentials.ts"],"sourcesContent":["/*\n * Copyright 2024 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n BackstageCredentials,\n BackstageNonePrincipal,\n BackstagePrincipalAccessRestrictions,\n BackstageServicePrincipal,\n BackstageUserPrincipal,\n} from '@backstage/backend-plugin-api';\n\nexport const DEFAULT_MOCK_USER_ENTITY_REF = 'user:default/mock';\nexport const DEFAULT_MOCK_SERVICE_SUBJECT = 'external:test-service';\n\nexport const MOCK_AUTH_COOKIE = 'backstage-auth';\n\nexport const MOCK_NONE_TOKEN = 'mock-none-token';\n\nexport const MOCK_USER_TOKEN = 'mock-user-token';\nexport const MOCK_USER_TOKEN_PREFIX = 'mock-user-token:';\nexport const MOCK_INVALID_USER_TOKEN = 'mock-invalid-user-token';\n\nexport const MOCK_USER_LIMITED_TOKEN_PREFIX = 'mock-limited-user-token:';\nexport const MOCK_INVALID_USER_LIMITED_TOKEN =\n 'mock-invalid-limited-user-token';\n\nexport const MOCK_SERVICE_TOKEN = 'mock-service-token';\nexport const MOCK_SERVICE_TOKEN_PREFIX = 'mock-service-token:';\nexport const MOCK_INVALID_SERVICE_TOKEN = 'mock-invalid-service-token';\n\nfunction validateUserEntityRef(ref: string) {\n if (!ref.match(/^.+:.+\\/.+$/)) {\n throw new TypeError(\n `Invalid user entity reference '${ref}', expected <kind>:<namespace>/<name>`,\n );\n }\n}\n\n/**\n * The payload that can be encoded into a mock user token.\n * @internal\n */\nexport type UserTokenPayload = {\n sub?: string;\n actor?: { subject: string };\n};\n\n/**\n * The payload that can be encoded into a mock service token.\n * @internal\n */\nexport type ServiceTokenPayload = {\n sub?: string; // service subject\n obo?: string; // user entity reference\n target?: string; // target plugin id\n};\n\n/**\n * @public\n */\nexport namespace mockCredentials {\n /**\n * Creates a mocked credentials object for a unauthenticated principal.\n */\n export function none(): BackstageCredentials<BackstageNonePrincipal> {\n const result = {\n $$type: '@backstage/BackstageCredentials',\n principal: { type: 'none' },\n } as const;\n Object.defineProperties(result, {\n toString: {\n enumerable: false,\n configurable: true,\n writable: true,\n value: () => `mockCredentials{nonePrincipal}`,\n },\n });\n return result;\n }\n\n /**\n * Utilities related to none credentials.\n */\n export namespace none {\n /**\n * Returns an authorization header that translates to unauthenticated\n * credentials.\n *\n * This is useful when one wants to explicitly test unauthenticated requests\n * while still using the default behavior of the mock HttpAuthService where\n * it defaults to user credentials.\n */\n export function header(): string {\n // NOTE: there is no .token() version of this because only the\n // HttpAuthService should know about and consume this token\n return `Bearer ${MOCK_NONE_TOKEN}`;\n }\n }\n\n /**\n * Creates a mocked credentials object for a user principal.\n *\n * The default user entity reference is 'user:default/mock'.\n */\n export function user(\n userEntityRef: string = DEFAULT_MOCK_USER_ENTITY_REF,\n options?: { actor?: { subject: string } },\n ): BackstageCredentials<BackstageUserPrincipal> {\n validateUserEntityRef(userEntityRef);\n const result = {\n $$type: '@backstage/BackstageCredentials',\n principal: {\n type: 'user',\n userEntityRef,\n ...(options?.actor && {\n actor: { type: 'service', subject: options.actor.subject } as const,\n }),\n },\n } as const;\n Object.defineProperties(result, {\n toString: {\n enumerable: false,\n configurable: true,\n value: () =>\n `mockCredentials{userPrincipal{${userEntityRef}${\n options?.actor ? `,actor={${options.actor.subject}}` : ''\n }}}`,\n },\n token: {\n enumerable: false,\n configurable: true,\n value: user.token(),\n },\n });\n return result;\n }\n\n /**\n * Utilities related to user credentials.\n */\n export namespace user {\n /**\n * Creates a mocked user token. If a payload is provided it will be encoded\n * into the token and forwarded to the credentials object when authenticated\n * by the mock auth service.\n */\n export function token(\n userEntityRef?: string,\n options?: { actor?: { subject: string } },\n ): string {\n if (userEntityRef) {\n validateUserEntityRef(userEntityRef);\n return `${MOCK_USER_TOKEN_PREFIX}${JSON.stringify({\n sub: userEntityRef,\n ...(options?.actor && {\n actor: { subject: options.actor.subject },\n }),\n } satisfies UserTokenPayload)}`;\n }\n return MOCK_USER_TOKEN;\n }\n\n /**\n * Returns an authorization header with a mocked user token. If a payload is\n * provided it will be encoded into the token and forwarded to the\n * credentials object when authenticated by the mock auth service.\n */\n export function header(userEntityRef?: string): string {\n return `Bearer ${token(userEntityRef)}`;\n }\n\n export function invalidToken(): string {\n return MOCK_INVALID_USER_TOKEN;\n }\n\n export function invalidHeader(): string {\n return `Bearer ${invalidToken()}`;\n }\n }\n\n /**\n * Creates a mocked credentials object for a user principal with limited\n * access.\n *\n * The default user entity reference is 'user:default/mock'.\n */\n export function limitedUser(\n userEntityRef: string = DEFAULT_MOCK_USER_ENTITY_REF,\n ): BackstageCredentials<BackstageUserPrincipal> {\n return user(userEntityRef);\n }\n\n /**\n * Utilities related to limited user credentials.\n */\n export namespace limitedUser {\n /**\n * Creates a mocked limited user token. If a payload is provided it will be\n * encoded into the token and forwarded to the credentials object when\n * authenticated by the mock auth service.\n */\n export function token(\n userEntityRef: string = DEFAULT_MOCK_USER_ENTITY_REF,\n ): string {\n validateUserEntityRef(userEntityRef);\n return `${MOCK_USER_LIMITED_TOKEN_PREFIX}${JSON.stringify({\n sub: userEntityRef,\n } satisfies UserTokenPayload)}`;\n }\n\n /**\n * Returns an authorization header with a mocked limited user token. If a\n * payload is provided it will be encoded into the token and forwarded to\n * the credentials object when authenticated by the mock auth service.\n */\n export function cookie(userEntityRef?: string): string {\n return `${MOCK_AUTH_COOKIE}=${token(userEntityRef)}`;\n }\n\n export function invalidToken(): string {\n return MOCK_INVALID_USER_LIMITED_TOKEN;\n }\n\n export function invalidCookie(): string {\n return `${MOCK_AUTH_COOKIE}=${invalidToken()}`;\n }\n }\n\n /**\n * Creates a mocked credentials object for a service principal.\n *\n * The default subject is 'external:test-service', and no access restrictions.\n */\n export function service(\n subject: string = DEFAULT_MOCK_SERVICE_SUBJECT,\n accessRestrictions?: BackstagePrincipalAccessRestrictions,\n ): BackstageCredentials<BackstageServicePrincipal> {\n const result = {\n $$type: '@backstage/BackstageCredentials',\n principal: {\n type: 'service',\n subject,\n ...(accessRestrictions ? { accessRestrictions } : {}),\n },\n } as const;\n Object.defineProperties(result, {\n toString: {\n enumerable: false,\n configurable: true,\n value: () =>\n `mockCredentials{servicePrincipal{${subject}${\n accessRestrictions\n ? `,accessRestrictions=${JSON.stringify(accessRestrictions)}`\n : ''\n }}}`,\n },\n });\n return result;\n }\n\n /**\n * Utilities related to service credentials.\n */\n export namespace service {\n /**\n * Options for the creation of mock service tokens.\n */\n export type TokenOptions = {\n onBehalfOf: BackstageCredentials;\n targetPluginId: string;\n };\n\n /**\n * Creates a mocked service token. The provided options will be encoded into\n * the token and forwarded to the credentials object when authenticated by\n * the mock auth service.\n */\n export function token(options?: TokenOptions): string {\n if (options) {\n const { targetPluginId, onBehalfOf } = options; // for fixed ordering\n\n const oboPrincipal = onBehalfOf?.principal as\n | BackstageServicePrincipal\n | BackstageUserPrincipal\n | BackstageNonePrincipal;\n const obo =\n oboPrincipal.type === 'user' ? oboPrincipal.userEntityRef : undefined;\n const subject =\n oboPrincipal.type === 'service' ? oboPrincipal.subject : undefined;\n\n return `${MOCK_SERVICE_TOKEN_PREFIX}${JSON.stringify({\n sub: subject,\n obo,\n target: targetPluginId,\n } satisfies ServiceTokenPayload)}`;\n }\n return MOCK_SERVICE_TOKEN;\n }\n\n /**\n * Returns an authorization header with a mocked service token. The provided\n * options will be encoded into the token and forwarded to the credentials\n * object when authenticated by the mock auth service.\n */\n export function header(options?: TokenOptions): string {\n return `Bearer ${token(options)}`;\n }\n\n export function invalidToken(): string {\n return MOCK_INVALID_SERVICE_TOKEN;\n }\n\n export function invalidHeader(): string {\n return `Bearer ${invalidToken()}`;\n }\n }\n}\n"],"names":["mockCredentials","none","user","limitedUser","service"],"mappings":"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"}
|
|
@@ -12,7 +12,6 @@ var permissionsRegistry = require('@backstage/backend-defaults/permissionsRegist
|
|
|
12
12
|
var rootHealth = require('@backstage/backend-defaults/rootHealth');
|
|
13
13
|
var rootHttpRouter = require('@backstage/backend-defaults/rootHttpRouter');
|
|
14
14
|
var rootLifecycle = require('@backstage/backend-defaults/rootLifecycle');
|
|
15
|
-
var scheduler = require('@backstage/backend-defaults/scheduler');
|
|
16
15
|
var urlReader = require('@backstage/backend-defaults/urlReader');
|
|
17
16
|
var backendPluginApi = require('@backstage/backend-plugin-api');
|
|
18
17
|
var config = require('@backstage/config');
|
|
@@ -25,6 +24,7 @@ var mockCredentials = require('./mockCredentials.cjs.js');
|
|
|
25
24
|
var MockEventsService = require('./MockEventsService.cjs.js');
|
|
26
25
|
var MockPermissionsService = require('./MockPermissionsService.cjs.js');
|
|
27
26
|
var simpleMock = require('./simpleMock.cjs.js');
|
|
27
|
+
var MockSchedulerService = require('./MockSchedulerService.cjs.js');
|
|
28
28
|
|
|
29
29
|
function createLoggerMock() {
|
|
30
30
|
return {
|
|
@@ -294,15 +294,19 @@ exports.mockServices = void 0;
|
|
|
294
294
|
addStartupHook: jest.fn()
|
|
295
295
|
}));
|
|
296
296
|
})(mockServices2.rootLifecycle || (mockServices2.rootLifecycle = {}));
|
|
297
|
+
function scheduler() {
|
|
298
|
+
return new MockSchedulerService.MockSchedulerService();
|
|
299
|
+
}
|
|
300
|
+
mockServices2.scheduler = scheduler;
|
|
297
301
|
((scheduler2) => {
|
|
298
|
-
scheduler2.factory = () =>
|
|
302
|
+
scheduler2.factory = (options) => new MockSchedulerService.MockSchedulerService().factory(options);
|
|
299
303
|
scheduler2.mock = simpleMock.simpleMock(backendPluginApi.coreServices.scheduler, () => ({
|
|
300
304
|
createScheduledTaskRunner: jest.fn(),
|
|
301
305
|
getScheduledTasks: jest.fn(),
|
|
302
306
|
scheduleTask: jest.fn(),
|
|
303
307
|
triggerTask: jest.fn()
|
|
304
308
|
}));
|
|
305
|
-
})(mockServices2.scheduler || (mockServices2.scheduler = {}));
|
|
309
|
+
})(scheduler = mockServices2.scheduler || (mockServices2.scheduler = {}));
|
|
306
310
|
((urlReader2) => {
|
|
307
311
|
urlReader2.factory = () => urlReader.urlReaderServiceFactory;
|
|
308
312
|
urlReader2.mock = simpleMock.simpleMock(backendPluginApi.coreServices.urlReader, () => ({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockServices.cjs.js","sources":["../../src/services/mockServices.ts"],"sourcesContent":["/*\n * Copyright 2023 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { auditorServiceFactory } from '@backstage/backend-defaults/auditor';\nimport { cacheServiceFactory } from '@backstage/backend-defaults/cache';\nimport { databaseServiceFactory } from '@backstage/backend-defaults/database';\nimport { HostDiscovery } from '@backstage/backend-defaults/discovery';\nimport { httpRouterServiceFactory } from '@backstage/backend-defaults/httpRouter';\nimport { lifecycleServiceFactory } from '@backstage/backend-defaults/lifecycle';\nimport { loggerServiceFactory } from '@backstage/backend-defaults/logger';\nimport { permissionsServiceFactory } from '@backstage/backend-defaults/permissions';\nimport { permissionsRegistryServiceFactory } from '@backstage/backend-defaults/permissionsRegistry';\nimport { rootHealthServiceFactory } from '@backstage/backend-defaults/rootHealth';\nimport { rootHttpRouterServiceFactory } from '@backstage/backend-defaults/rootHttpRouter';\nimport { rootLifecycleServiceFactory } from '@backstage/backend-defaults/rootLifecycle';\nimport { schedulerServiceFactory } from '@backstage/backend-defaults/scheduler';\nimport { urlReaderServiceFactory } from '@backstage/backend-defaults/urlReader';\nimport {\n AuthService,\n BackstageCredentials,\n BackstageUserInfo,\n DatabaseService,\n DiscoveryService,\n HttpAuthService,\n LoggerService,\n PermissionsService,\n RootConfigService,\n ServiceFactory,\n ServiceRef,\n UserInfoService,\n coreServices,\n createServiceFactory,\n} from '@backstage/backend-plugin-api';\nimport { ConfigReader } from '@backstage/config';\nimport { EventsService, eventsServiceRef } from '@backstage/plugin-events-node';\nimport { AuthorizeResult } from '@backstage/plugin-permission-common';\nimport { JsonObject } from '@backstage/types';\nimport { Knex } from 'knex';\nimport { MockAuthService } from './MockAuthService';\nimport { MockHttpAuthService } from './MockHttpAuthService';\nimport { MockRootLoggerService } from './MockRootLoggerService';\nimport { MockUserInfoService } from './MockUserInfoService';\nimport { mockCredentials } from './mockCredentials';\nimport { MockEventsService } from './MockEventsService';\nimport { MockPermissionsService } from './MockPermissionsService';\nimport { simpleMock } from './simpleMock';\n\n/** @internal */\nfunction createLoggerMock() {\n return {\n child: jest.fn().mockImplementation(createLoggerMock),\n debug: jest.fn(),\n error: jest.fn(),\n info: jest.fn(),\n warn: jest.fn(),\n };\n}\n\n/** @internal */\nfunction simpleFactoryWithOptions<\n TService,\n TScope extends 'root' | 'plugin',\n TOptions extends [options?: object] = [],\n>(\n ref: ServiceRef<TService, TScope>,\n factory: (...options: TOptions) => TService,\n): (...options: TOptions) => ServiceFactory<TService, TScope> {\n const factoryWithOptions = (...options: TOptions) =>\n createServiceFactory({\n service: ref as ServiceRef<TService, any>,\n deps: {},\n async factory() {\n return factory(...options);\n },\n });\n return Object.assign(\n factoryWithOptions,\n factoryWithOptions(...([undefined] as unknown as TOptions)),\n ) as ServiceFactory<TService, TScope> &\n ((...options: TOptions) => ServiceFactory<TService, TScope>);\n}\n\n/**\n * Mock implementations of the core services, to be used in tests.\n *\n * @public\n * @remarks\n *\n * There are some variations among the services depending on what needs tests\n * might have, but overall there are three main usage patterns:\n *\n * 1. Creating an actual fake service instance, often with a simplified version\n * of functionality, by calling the mock service itself as a function.\n *\n * ```ts\n * // The function often accepts parameters that control its behavior\n * const foo = mockServices.foo();\n * ```\n *\n * 2. Creating a mock service, where all methods are replaced with jest mocks, by\n * calling the service's `mock` function.\n *\n * ```ts\n * // You can optionally supply a subset of its methods to implement\n * const foo = mockServices.foo.mock({\n * someMethod: () => 'mocked result',\n * });\n * // After exercising your test, you can make assertions on the mock:\n * expect(foo.someMethod).toHaveBeenCalledTimes(2);\n * expect(foo.otherMethod).toHaveBeenCalledWith(testData);\n * ```\n *\n * 3. Creating a service factory that behaves similarly to the mock as per above.\n *\n * ```ts\n * await startTestBackend({\n * features: [\n * mockServices.foo.factory({\n * someMethod: () => 'mocked result',\n * })\n * ],\n * });\n * ```\n */\nexport namespace mockServices {\n export function rootConfig(options?: rootConfig.Options): RootConfigService {\n return new ConfigReader(options?.data, 'mock-config');\n }\n export namespace rootConfig {\n export type Options = { data?: JsonObject };\n\n export const factory = simpleFactoryWithOptions(\n coreServices.rootConfig,\n rootConfig,\n );\n export const mock = simpleMock(coreServices.rootConfig, () => ({\n get: jest.fn(),\n getBoolean: jest.fn(),\n getConfig: jest.fn(),\n getConfigArray: jest.fn(),\n getNumber: jest.fn(),\n getOptional: jest.fn(),\n getOptionalBoolean: jest.fn(),\n getOptionalConfig: jest.fn(),\n getOptionalConfigArray: jest.fn(),\n getOptionalNumber: jest.fn(),\n getOptionalString: jest.fn(),\n getOptionalStringArray: jest.fn(),\n getString: jest.fn(),\n getStringArray: jest.fn(),\n has: jest.fn(),\n keys: jest.fn(),\n }));\n }\n\n export function rootLogger(options?: rootLogger.Options): LoggerService {\n return MockRootLoggerService.create(options);\n }\n export namespace rootLogger {\n export type Options = {\n level?: 'none' | 'error' | 'warn' | 'info' | 'debug';\n };\n\n export const factory = simpleFactoryWithOptions(\n coreServices.rootLogger,\n rootLogger,\n );\n export const mock = simpleMock(coreServices.rootLogger, () => ({\n child: jest.fn(),\n debug: jest.fn(),\n error: jest.fn(),\n info: jest.fn(),\n warn: jest.fn(),\n }));\n }\n\n export namespace auditor {\n export const factory = () => auditorServiceFactory;\n\n export const mock = simpleMock(coreServices.auditor, () => ({\n createEvent: jest.fn(async _ => {\n return {\n success: jest.fn(),\n fail: jest.fn(),\n };\n }),\n }));\n }\n\n export function auth(options?: {\n pluginId?: string;\n disableDefaultAuthPolicy?: boolean;\n }): AuthService {\n return new MockAuthService({\n pluginId: options?.pluginId ?? 'test',\n disableDefaultAuthPolicy: Boolean(options?.disableDefaultAuthPolicy),\n });\n }\n export namespace auth {\n export const factory = () =>\n createServiceFactory({\n service: coreServices.auth,\n deps: {\n plugin: coreServices.pluginMetadata,\n config: coreServices.rootConfig,\n },\n factory({ plugin, config }) {\n const disableDefaultAuthPolicy = Boolean(\n config.getOptionalBoolean(\n 'backend.auth.dangerouslyDisableDefaultAuthPolicy',\n ),\n );\n return new MockAuthService({\n pluginId: plugin.getId(),\n disableDefaultAuthPolicy,\n });\n },\n });\n export const mock = simpleMock(coreServices.auth, () => ({\n authenticate: jest.fn(),\n getNoneCredentials: jest.fn(),\n getOwnServiceCredentials: jest.fn(),\n isPrincipal: jest.fn() as any,\n getPluginRequestToken: jest.fn(),\n getLimitedUserToken: jest.fn(),\n listPublicServiceKeys: jest.fn(),\n }));\n }\n\n export function discovery(): DiscoveryService {\n return HostDiscovery.fromConfig(\n new ConfigReader({\n backend: {\n // Invalid port to make sure that requests are always mocked\n baseUrl: 'http://localhost:0',\n listen: { port: 0 },\n },\n }),\n );\n }\n export namespace discovery {\n export const factory = () =>\n createServiceFactory({\n service: coreServices.discovery,\n deps: {},\n factory: () => discovery(),\n });\n export const mock = simpleMock(coreServices.discovery, () => ({\n getBaseUrl: jest.fn(),\n getExternalBaseUrl: jest.fn(),\n }));\n }\n\n /**\n * Creates a mock implementation of the `HttpAuthService`.\n *\n * By default all requests without credentials are treated as requests from\n * the default mock user principal. This behavior can be configured with the\n * `defaultCredentials` option.\n */\n export function httpAuth(options?: {\n pluginId?: string;\n /**\n * The default credentials to use if there are no credentials present in the\n * incoming request.\n *\n * By default all requests without credentials are treated as authenticated\n * as the default mock user as returned from `mockCredentials.user()`.\n */\n defaultCredentials?: BackstageCredentials;\n }): HttpAuthService {\n return new MockHttpAuthService(\n options?.pluginId ?? 'test',\n options?.defaultCredentials ?? mockCredentials.user(),\n );\n }\n export namespace httpAuth {\n /**\n * Creates a mock service factory for the `HttpAuthService`.\n *\n * By default all requests without credentials are treated as requests from\n * the default mock user principal. This behavior can be configured with the\n * `defaultCredentials` option.\n */\n export const factory = (options?: {\n defaultCredentials?: BackstageCredentials;\n }) =>\n createServiceFactory({\n service: coreServices.httpAuth,\n deps: { plugin: coreServices.pluginMetadata },\n factory: ({ plugin }) =>\n new MockHttpAuthService(\n plugin.getId(),\n options?.defaultCredentials ?? mockCredentials.user(),\n ),\n });\n export const mock = simpleMock(coreServices.httpAuth, () => ({\n credentials: jest.fn(),\n issueUserCookie: jest.fn(),\n }));\n }\n\n /**\n * Creates a mock implementation of the `UserInfoService`.\n *\n * By default it extracts the user's entity ref from a user principal and\n * returns that as the only ownership entity ref, but this can be overridden\n * by passing in a custom set of user info.\n */\n export function userInfo(\n customInfo?: Partial<BackstageUserInfo>,\n ): UserInfoService {\n return new MockUserInfoService(customInfo);\n }\n export namespace userInfo {\n /**\n * Creates a mock service factory for the `UserInfoService`.\n *\n * By default it extracts the user's entity ref from a user principal and\n * returns that as the only ownership entity ref.\n */\n export const factory = () =>\n createServiceFactory({\n service: coreServices.userInfo,\n deps: {},\n factory() {\n return new MockUserInfoService();\n },\n });\n export const mock = simpleMock(coreServices.userInfo, () => ({\n getUserInfo: jest.fn(),\n }));\n }\n\n // TODO(Rugvip): Not all core services have implementations available here yet.\n // some may need a bit more refactoring for it to be simpler to\n // re-implement functioning mock versions here.\n export namespace cache {\n export const factory = () => cacheServiceFactory;\n export const mock = simpleMock(coreServices.cache, () => ({\n delete: jest.fn(),\n get: jest.fn(),\n set: jest.fn(),\n withOptions: jest.fn(),\n }));\n }\n\n /**\n * Creates a mock implementation of the\n * {@link @backstage/backend-plugin-api#coreServices.database}. Just returns\n * the given `knex` instance, which is useful in combination with the\n * {@link TestDatabases} facility.\n */\n export function database(options: {\n knex: Knex;\n migrations?: { skip?: boolean };\n }): DatabaseService {\n return {\n getClient: async () => options.knex,\n migrations: options.migrations,\n };\n }\n export namespace database {\n /**\n * Creates a mock factory for the\n * {@link @backstage/backend-plugin-api#coreServices.database}. Just returns\n * the given `knex` instance if you supply one, which is useful in\n * combination with the {@link TestDatabases} facility. Otherwise, it\n * returns the regular default database factory which reads config settings.\n */\n export const factory = (options?: {\n knex: Knex;\n migrations?: { skip?: boolean };\n }) =>\n options\n ? createServiceFactory({\n service: coreServices.database,\n deps: {},\n factory: () => database(options),\n })\n : databaseServiceFactory;\n /**\n * Creates a mock of the\n * {@link @backstage/backend-plugin-api#coreServices.database}, optionally\n * with some given method implementations.\n */\n export const mock = simpleMock(coreServices.database, () => ({\n getClient: jest.fn(),\n }));\n }\n\n export namespace rootHealth {\n export const factory = () => rootHealthServiceFactory;\n export const mock = simpleMock(coreServices.rootHealth, () => ({\n getLiveness: jest.fn(),\n getReadiness: jest.fn(),\n }));\n }\n\n export namespace httpRouter {\n export const factory = () => httpRouterServiceFactory;\n export const mock = simpleMock(coreServices.httpRouter, () => ({\n use: jest.fn(),\n addAuthPolicy: jest.fn(),\n }));\n }\n\n export namespace rootHttpRouter {\n export const factory = () => rootHttpRouterServiceFactory();\n export const mock = simpleMock(coreServices.rootHttpRouter, () => ({\n use: jest.fn(),\n }));\n }\n\n export namespace lifecycle {\n export const factory = () => lifecycleServiceFactory;\n export const mock = simpleMock(coreServices.lifecycle, () => ({\n addShutdownHook: jest.fn(),\n addStartupHook: jest.fn(),\n }));\n }\n\n export namespace logger {\n export const factory = () => loggerServiceFactory;\n export const mock = simpleMock(coreServices.logger, () =>\n createLoggerMock(),\n );\n }\n\n /**\n * Creates a functional mock implementation of the\n * {@link @backstage/backend-plugin-api#PermissionsService}.\n */\n export function permissions(options?: {\n result: AuthorizeResult.ALLOW | AuthorizeResult.DENY;\n }): PermissionsService {\n return new MockPermissionsService(options);\n }\n export namespace permissions {\n /**\n * Creates a mock factory for the\n * {@link @backstage/backend-plugin-api#coreServices.permissions}. Just\n * returns the given `result` if you supply one. Otherwise, it returns the\n * regular default permissions factory.\n */\n export const factory = (options?: {\n result: AuthorizeResult.ALLOW | AuthorizeResult.DENY;\n }) =>\n options?.result\n ? createServiceFactory({\n service: coreServices.permissions,\n deps: {},\n factory: () => new MockPermissionsService(options),\n })\n : permissionsServiceFactory;\n /**\n * Creates a mock of the\n * {@link @backstage/backend-plugin-api#coreServices.permissions},\n * optionally with some given method implementations.\n */\n export const mock = simpleMock(coreServices.permissions, () => ({\n authorize: jest.fn(),\n authorizeConditional: jest.fn(),\n }));\n }\n\n export namespace permissionsRegistry {\n export const factory = () => permissionsRegistryServiceFactory;\n export const mock = simpleMock(coreServices.permissionsRegistry, () => ({\n addPermissionRules: jest.fn(),\n addPermissions: jest.fn(),\n addResourceType: jest.fn(),\n getPermissionRuleset: jest.fn(),\n }));\n }\n\n export namespace rootLifecycle {\n export const factory = () => rootLifecycleServiceFactory;\n export const mock = simpleMock(coreServices.rootLifecycle, () => ({\n addShutdownHook: jest.fn(),\n addBeforeShutdownHook: jest.fn(),\n addStartupHook: jest.fn(),\n }));\n }\n\n export namespace scheduler {\n export const factory = () => schedulerServiceFactory;\n export const mock = simpleMock(coreServices.scheduler, () => ({\n createScheduledTaskRunner: jest.fn(),\n getScheduledTasks: jest.fn(),\n scheduleTask: jest.fn(),\n triggerTask: jest.fn(),\n }));\n }\n\n export namespace urlReader {\n export const factory = () => urlReaderServiceFactory;\n export const mock = simpleMock(coreServices.urlReader, () => ({\n readTree: jest.fn(),\n readUrl: jest.fn(),\n search: jest.fn(),\n }));\n }\n\n /**\n * Creates a functional mock implementation of the\n * {@link @backstage/backend-events-node#eventsServiceRef}.\n */\n export function events(): EventsService {\n return new MockEventsService();\n }\n export namespace events {\n /**\n * Creates a functional mock factory for the\n * {@link @backstage/backend-events-node#eventsServiceRef}.\n */\n export const factory = simpleFactoryWithOptions(eventsServiceRef, events);\n /**\n * Creates a mock of the\n * {@link @backstage/backend-events-node#eventsServiceRef}, optionally\n * with some given method implementations.\n */\n export const mock = simpleMock(eventsServiceRef, () => ({\n publish: jest.fn(),\n subscribe: jest.fn(),\n }));\n }\n}\n"],"names":["createServiceFactory","mockServices","ConfigReader","rootConfig","coreServices","simpleMock","MockRootLoggerService","rootLogger","auditor","auditorServiceFactory","MockAuthService","auth","discovery","HostDiscovery","MockHttpAuthService","mockCredentials","httpAuth","MockUserInfoService","userInfo","cache","cacheServiceFactory","database","databaseServiceFactory","rootHealth","rootHealthServiceFactory","httpRouter","httpRouterServiceFactory","rootHttpRouter","rootHttpRouterServiceFactory","lifecycle","lifecycleServiceFactory","logger","loggerServiceFactory","permissions","MockPermissionsService","permissionsServiceFactory","permissionsRegistry","permissionsRegistryServiceFactory","rootLifecycle","rootLifecycleServiceFactory","scheduler","schedulerServiceFactory","urlReader","urlReaderServiceFactory","MockEventsService","events","eventsServiceRef"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6DA,SAAS,gBAAmB,GAAA;AAC1B,EAAO,OAAA;AAAA,IACL,KAAO,EAAA,IAAA,CAAK,EAAG,EAAA,CAAE,mBAAmB,gBAAgB,CAAA;AAAA,IACpD,KAAA,EAAO,KAAK,EAAG,EAAA;AAAA,IACf,KAAA,EAAO,KAAK,EAAG,EAAA;AAAA,IACf,IAAA,EAAM,KAAK,EAAG,EAAA;AAAA,IACd,IAAA,EAAM,KAAK,EAAG;AAAA,GAChB;AACF;AAGA,SAAS,wBAAA,CAKP,KACA,OAC4D,EAAA;AAC5D,EAAM,MAAA,kBAAA,GAAqB,CAAI,GAAA,OAAA,KAC7BA,qCAAqB,CAAA;AAAA,IACnB,OAAS,EAAA,GAAA;AAAA,IACT,MAAM,EAAC;AAAA,IACP,MAAM,OAAU,GAAA;AACd,MAAO,OAAA,OAAA,CAAQ,GAAG,OAAO,CAAA;AAAA;AAC3B,GACD,CAAA;AACH,EAAA,OAAO,MAAO,CAAA,MAAA;AAAA,IACZ,kBAAA;AAAA,IACA,kBAAmB,CAAA,GAAI,CAAC,KAAA,CAAS,CAAyB;AAAA,GAC5D;AAEF;AA4CiBC;AAAA,CAAV,CAAUA,aAAV,KAAA;AACE,EAAA,SAAS,WAAW,OAAiD,EAAA;AAC1E,IAAA,OAAO,IAAIC,mBAAA,CAAa,OAAS,EAAA,IAAA,EAAM,aAAa,CAAA;AAAA;AAD/C,EAAAD,aAAS,CAAA,UAAA,GAAA,UAAA;AAGT,EAAA,CAAA,CAAUE,WAAV,KAAA;AAGE,IAAMA,YAAA,OAAU,GAAA,wBAAA;AAAA,MACrBC,6BAAa,CAAA,UAAA;AAAA,MACbD;AAAA,KACF;AACO,IAAMA,WAAA,CAAA,IAAA,GAAOE,qBAAW,CAAAD,6BAAA,CAAa,YAAY,OAAO;AAAA,MAC7D,GAAA,EAAK,KAAK,EAAG,EAAA;AAAA,MACb,UAAA,EAAY,KAAK,EAAG,EAAA;AAAA,MACpB,SAAA,EAAW,KAAK,EAAG,EAAA;AAAA,MACnB,cAAA,EAAgB,KAAK,EAAG,EAAA;AAAA,MACxB,SAAA,EAAW,KAAK,EAAG,EAAA;AAAA,MACnB,WAAA,EAAa,KAAK,EAAG,EAAA;AAAA,MACrB,kBAAA,EAAoB,KAAK,EAAG,EAAA;AAAA,MAC5B,iBAAA,EAAmB,KAAK,EAAG,EAAA;AAAA,MAC3B,sBAAA,EAAwB,KAAK,EAAG,EAAA;AAAA,MAChC,iBAAA,EAAmB,KAAK,EAAG,EAAA;AAAA,MAC3B,iBAAA,EAAmB,KAAK,EAAG,EAAA;AAAA,MAC3B,sBAAA,EAAwB,KAAK,EAAG,EAAA;AAAA,MAChC,SAAA,EAAW,KAAK,EAAG,EAAA;AAAA,MACnB,cAAA,EAAgB,KAAK,EAAG,EAAA;AAAA,MACxB,GAAA,EAAK,KAAK,EAAG,EAAA;AAAA,MACb,IAAA,EAAM,KAAK,EAAG;AAAA,KACd,CAAA,CAAA;AAAA,GAxBa,EAAA,UAAA,GAAAH,aAAA,CAAA,UAAA,KAAAA,aAAA,CAAA,UAAA,GAAA,EAAA,CAAA,CAAA;AA2BV,EAAA,SAAS,WAAW,OAA6C,EAAA;AACtE,IAAO,OAAAK,2CAAA,CAAsB,OAAO,OAAO,CAAA;AAAA;AADtC,EAAAL,aAAS,CAAA,UAAA,GAAA,UAAA;AAGT,EAAA,CAAA,CAAUM,WAAV,KAAA;AAKE,IAAMA,YAAA,OAAU,GAAA,wBAAA;AAAA,MACrBH,6BAAa,CAAA,UAAA;AAAA,MACbG;AAAA,KACF;AACO,IAAMA,WAAA,CAAA,IAAA,GAAOF,qBAAW,CAAAD,6BAAA,CAAa,YAAY,OAAO;AAAA,MAC7D,KAAA,EAAO,KAAK,EAAG,EAAA;AAAA,MACf,KAAA,EAAO,KAAK,EAAG,EAAA;AAAA,MACf,KAAA,EAAO,KAAK,EAAG,EAAA;AAAA,MACf,IAAA,EAAM,KAAK,EAAG,EAAA;AAAA,MACd,IAAA,EAAM,KAAK,EAAG;AAAA,KACd,CAAA,CAAA;AAAA,GAfa,EAAA,UAAA,GAAAH,aAAA,CAAA,UAAA,KAAAA,aAAA,CAAA,UAAA,GAAA,EAAA,CAAA,CAAA;AAkBV,EAAA,CAAA,CAAUO,QAAV,KAAA;AACE,IAAMA,QAAAA,CAAA,UAAU,MAAMC,6BAAA;AAEtB,IAAMD,QAAA,CAAA,IAAA,GAAOH,qBAAW,CAAAD,6BAAA,CAAa,SAAS,OAAO;AAAA,MAC1D,WAAa,EAAA,IAAA,CAAK,EAAG,CAAA,OAAM,CAAK,KAAA;AAC9B,QAAO,OAAA;AAAA,UACL,OAAA,EAAS,KAAK,EAAG,EAAA;AAAA,UACjB,IAAA,EAAM,KAAK,EAAG;AAAA,SAChB;AAAA,OACD;AAAA,KACD,CAAA,CAAA;AAAA,GAVa,EAAAH,aAAA,CAAA,OAAA,KAAAA,aAAA,CAAA,OAAA,GAAA,EAAA,CAAA,CAAA;AAaV,EAAA,SAAS,KAAK,OAGL,EAAA;AACd,IAAA,OAAO,IAAIS,+BAAgB,CAAA;AAAA,MACzB,QAAA,EAAU,SAAS,QAAY,IAAA,MAAA;AAAA,MAC/B,wBAAA,EAA0B,OAAQ,CAAA,OAAA,EAAS,wBAAwB;AAAA,KACpE,CAAA;AAAA;AAPI,EAAAT,aAAS,CAAA,IAAA,GAAA,IAAA;AAST,EAAA,CAAA,CAAUU,KAAV,KAAA;AACE,IAAMA,KAAAA,CAAA,OAAU,GAAA,MACrBX,qCAAqB,CAAA;AAAA,MACnB,SAASI,6BAAa,CAAA,IAAA;AAAA,MACtB,IAAM,EAAA;AAAA,QACJ,QAAQA,6BAAa,CAAA,cAAA;AAAA,QACrB,QAAQA,6BAAa,CAAA;AAAA,OACvB;AAAA,MACA,OAAQ,CAAA,EAAE,MAAQ,EAAA,MAAA,EAAU,EAAA;AAC1B,QAAA,MAAM,wBAA2B,GAAA,OAAA;AAAA,UAC/B,MAAO,CAAA,kBAAA;AAAA,YACL;AAAA;AACF,SACF;AACA,QAAA,OAAO,IAAIM,+BAAgB,CAAA;AAAA,UACzB,QAAA,EAAU,OAAO,KAAM,EAAA;AAAA,UACvB;AAAA,SACD,CAAA;AAAA;AACH,KACD,CAAA;AACI,IAAMC,KAAA,CAAA,IAAA,GAAON,qBAAW,CAAAD,6BAAA,CAAa,MAAM,OAAO;AAAA,MACvD,YAAA,EAAc,KAAK,EAAG,EAAA;AAAA,MACtB,kBAAA,EAAoB,KAAK,EAAG,EAAA;AAAA,MAC5B,wBAAA,EAA0B,KAAK,EAAG,EAAA;AAAA,MAClC,WAAA,EAAa,KAAK,EAAG,EAAA;AAAA,MACrB,qBAAA,EAAuB,KAAK,EAAG,EAAA;AAAA,MAC/B,mBAAA,EAAqB,KAAK,EAAG,EAAA;AAAA,MAC7B,qBAAA,EAAuB,KAAK,EAAG;AAAA,KAC/B,CAAA,CAAA;AAAA,GA5Ba,EAAA,IAAA,GAAAH,aAAA,CAAA,IAAA,KAAAA,aAAA,CAAA,IAAA,GAAA,EAAA,CAAA,CAAA;AA+BV,EAAA,SAASW,WAA8B,GAAA;AAC5C,IAAA,OAAOC,uBAAc,CAAA,UAAA;AAAA,MACnB,IAAIX,mBAAa,CAAA;AAAA,QACf,OAAS,EAAA;AAAA;AAAA,UAEP,OAAS,EAAA,oBAAA;AAAA,UACT,MAAA,EAAQ,EAAE,IAAA,EAAM,CAAE;AAAA;AACpB,OACD;AAAA,KACH;AAAA;AATK,EAAAD,aAAS,CAAA,SAAA,GAAAW,WAAA;AAWT,EAAA,CAAA,CAAUA,UAAV,KAAA;AACE,IAAMA,UAAAA,CAAA,OAAU,GAAA,MACrBZ,qCAAqB,CAAA;AAAA,MACnB,SAASI,6BAAa,CAAA,SAAA;AAAA,MACtB,MAAM,EAAC;AAAA,MACP,OAAA,EAAS,MAAMQ,UAAU;AAAA,KAC1B,CAAA;AACI,IAAMA,UAAA,CAAA,IAAA,GAAOP,qBAAW,CAAAD,6BAAA,CAAa,WAAW,OAAO;AAAA,MAC5D,UAAA,EAAY,KAAK,EAAG,EAAA;AAAA,MACpB,kBAAA,EAAoB,KAAK,EAAG;AAAA,KAC5B,CAAA,CAAA;AAAA,GAVa,EAAAQ,WAAA,GAAAX,aAAA,CAAA,SAAA,KAAAA,aAAA,CAAA,SAAA,GAAA,EAAA,CAAA,CAAA;AAoBV,EAAA,SAAS,SAAS,OAUL,EAAA;AAClB,IAAA,OAAO,IAAIa,uCAAA;AAAA,MACT,SAAS,QAAY,IAAA,MAAA;AAAA,MACrB,OAAA,EAAS,kBAAsB,IAAAC,+BAAA,CAAgB,IAAK;AAAA,KACtD;AAAA;AAdK,EAAAd,aAAS,CAAA,QAAA,GAAA,QAAA;AAgBT,EAAA,CAAA,CAAUe,SAAV,KAAA;AAQE,IAAMA,SAAA,CAAA,OAAA,GAAU,CAAC,OAAA,KAGtBhB,qCAAqB,CAAA;AAAA,MACnB,SAASI,6BAAa,CAAA,QAAA;AAAA,MACtB,IAAM,EAAA,EAAE,MAAQ,EAAAA,6BAAA,CAAa,cAAe,EAAA;AAAA,MAC5C,OAAS,EAAA,CAAC,EAAE,MAAA,OACV,IAAIU,uCAAA;AAAA,QACF,OAAO,KAAM,EAAA;AAAA,QACb,OAAA,EAAS,kBAAsB,IAAAC,+BAAA,CAAgB,IAAK;AAAA;AACtD,KACH,CAAA;AACI,IAAMC,SAAA,CAAA,IAAA,GAAOX,qBAAW,CAAAD,6BAAA,CAAa,UAAU,OAAO;AAAA,MAC3D,WAAA,EAAa,KAAK,EAAG,EAAA;AAAA,MACrB,eAAA,EAAiB,KAAK,EAAG;AAAA,KACzB,CAAA,CAAA;AAAA,GAvBa,EAAA,QAAA,GAAAH,aAAA,CAAA,QAAA,KAAAA,aAAA,CAAA,QAAA,GAAA,EAAA,CAAA,CAAA;AAiCV,EAAA,SAAS,SACd,UACiB,EAAA;AACjB,IAAO,OAAA,IAAIgB,wCAAoB,UAAU,CAAA;AAAA;AAHpC,EAAAhB,aAAS,CAAA,QAAA,GAAA,QAAA;AAKT,EAAA,CAAA,CAAUiB,SAAV,KAAA;AAOE,IAAMA,SAAAA,CAAA,OAAU,GAAA,MACrBlB,qCAAqB,CAAA;AAAA,MACnB,SAASI,6BAAa,CAAA,QAAA;AAAA,MACtB,MAAM,EAAC;AAAA,MACP,OAAU,GAAA;AACR,QAAA,OAAO,IAAIa,uCAAoB,EAAA;AAAA;AACjC,KACD,CAAA;AACI,IAAMC,SAAA,CAAA,IAAA,GAAOb,qBAAW,CAAAD,6BAAA,CAAa,UAAU,OAAO;AAAA,MAC3D,WAAA,EAAa,KAAK,EAAG;AAAA,KACrB,CAAA,CAAA;AAAA,GAjBa,EAAA,QAAA,GAAAH,aAAA,CAAA,QAAA,KAAAA,aAAA,CAAA,QAAA,GAAA,EAAA,CAAA,CAAA;AAuBV,EAAA,CAAA,CAAUkB,MAAV,KAAA;AACE,IAAMA,MAAAA,CAAA,UAAU,MAAMC,yBAAA;AACtB,IAAMD,MAAA,CAAA,IAAA,GAAOd,qBAAW,CAAAD,6BAAA,CAAa,OAAO,OAAO;AAAA,MACxD,MAAA,EAAQ,KAAK,EAAG,EAAA;AAAA,MAChB,GAAA,EAAK,KAAK,EAAG,EAAA;AAAA,MACb,GAAA,EAAK,KAAK,EAAG,EAAA;AAAA,MACb,WAAA,EAAa,KAAK,EAAG;AAAA,KACrB,CAAA,CAAA;AAAA,GAPa,EAAAH,aAAA,CAAA,KAAA,KAAAA,aAAA,CAAA,KAAA,GAAA,EAAA,CAAA,CAAA;AAgBV,EAAA,SAASoB,WAAS,OAGL,EAAA;AAClB,IAAO,OAAA;AAAA,MACL,SAAA,EAAW,YAAY,OAAQ,CAAA,IAAA;AAAA,MAC/B,YAAY,OAAQ,CAAA;AAAA,KACtB;AAAA;AAPK,EAAApB,aAAS,CAAA,QAAA,GAAAoB,UAAA;AAST,EAAA,CAAA,CAAUA,SAAV,KAAA;AAQE,IAAMA,SAAA,CAAA,OAAA,GAAU,CAAC,OAAA,KAItB,UACIrB,qCAAqB,CAAA;AAAA,MACnB,SAASI,6BAAa,CAAA,QAAA;AAAA,MACtB,MAAM,EAAC;AAAA,MACP,OAAA,EAAS,MAAMiB,SAAAA,CAAS,OAAO;AAAA,KAChC,CACD,GAAAC,+BAAA;AAMC,IAAMD,SAAA,CAAA,IAAA,GAAOhB,qBAAW,CAAAD,6BAAA,CAAa,UAAU,OAAO;AAAA,MAC3D,SAAA,EAAW,KAAK,EAAG;AAAA,KACnB,CAAA,CAAA;AAAA,GA1Ba,EAAAiB,UAAA,GAAApB,aAAA,CAAA,QAAA,KAAAA,aAAA,CAAA,QAAA,GAAA,EAAA,CAAA,CAAA;AA6BV,EAAA,CAAA,CAAUsB,WAAV,KAAA;AACE,IAAMA,WAAAA,CAAA,UAAU,MAAMC,mCAAA;AACtB,IAAMD,WAAA,CAAA,IAAA,GAAOlB,qBAAW,CAAAD,6BAAA,CAAa,YAAY,OAAO;AAAA,MAC7D,WAAA,EAAa,KAAK,EAAG,EAAA;AAAA,MACrB,YAAA,EAAc,KAAK,EAAG;AAAA,KACtB,CAAA,CAAA;AAAA,GALa,EAAAH,aAAA,CAAA,UAAA,KAAAA,aAAA,CAAA,UAAA,GAAA,EAAA,CAAA,CAAA;AAQV,EAAA,CAAA,CAAUwB,WAAV,KAAA;AACE,IAAMA,WAAAA,CAAA,UAAU,MAAMC,mCAAA;AACtB,IAAMD,WAAA,CAAA,IAAA,GAAOpB,qBAAW,CAAAD,6BAAA,CAAa,YAAY,OAAO;AAAA,MAC7D,GAAA,EAAK,KAAK,EAAG,EAAA;AAAA,MACb,aAAA,EAAe,KAAK,EAAG;AAAA,KACvB,CAAA,CAAA;AAAA,GALa,EAAAH,aAAA,CAAA,UAAA,KAAAA,aAAA,CAAA,UAAA,GAAA,EAAA,CAAA,CAAA;AAQV,EAAA,CAAA,CAAU0B,eAAV,KAAA;AACE,IAAMA,eAAAA,CAAA,OAAU,GAAA,MAAMC,2CAA6B,EAAA;AACnD,IAAMD,eAAA,CAAA,IAAA,GAAOtB,qBAAW,CAAAD,6BAAA,CAAa,gBAAgB,OAAO;AAAA,MACjE,GAAA,EAAK,KAAK,EAAG;AAAA,KACb,CAAA,CAAA;AAAA,GAJa,EAAAH,aAAA,CAAA,cAAA,KAAAA,aAAA,CAAA,cAAA,GAAA,EAAA,CAAA,CAAA;AAOV,EAAA,CAAA,CAAU4B,UAAV,KAAA;AACE,IAAMA,UAAAA,CAAA,UAAU,MAAMC,iCAAA;AACtB,IAAMD,UAAA,CAAA,IAAA,GAAOxB,qBAAW,CAAAD,6BAAA,CAAa,WAAW,OAAO;AAAA,MAC5D,eAAA,EAAiB,KAAK,EAAG,EAAA;AAAA,MACzB,cAAA,EAAgB,KAAK,EAAG;AAAA,KACxB,CAAA,CAAA;AAAA,GALa,EAAAH,aAAA,CAAA,SAAA,KAAAA,aAAA,CAAA,SAAA,GAAA,EAAA,CAAA,CAAA;AAQV,EAAA,CAAA,CAAU8B,OAAV,KAAA;AACE,IAAMA,OAAAA,CAAA,UAAU,MAAMC,2BAAA;AACtB,IAAMD,QAAA,IAAO,GAAA1B,qBAAA;AAAA,MAAWD,6BAAa,CAAA,MAAA;AAAA,MAAQ,MAClD,gBAAiB;AAAA,KACnB;AAAA,GAJe,EAAAH,aAAA,CAAA,MAAA,KAAAA,aAAA,CAAA,MAAA,GAAA,EAAA,CAAA,CAAA;AAWV,EAAA,SAASgC,cAAY,OAEL,EAAA;AACrB,IAAO,OAAA,IAAIC,8CAAuB,OAAO,CAAA;AAAA;AAHpC,EAAAjC,aAAS,CAAA,WAAA,GAAAgC,aAAA;AAKT,EAAA,CAAA,CAAUA,YAAV,KAAA;AAOE,IAAMA,aAAA,OAAU,GAAA,CAAC,OAGtB,KAAA,OAAA,EAAS,SACLjC,qCAAqB,CAAA;AAAA,MACnB,SAASI,6BAAa,CAAA,WAAA;AAAA,MACtB,MAAM,EAAC;AAAA,MACP,OAAS,EAAA,MAAM,IAAI8B,6CAAA,CAAuB,OAAO;AAAA,KAClD,CACD,GAAAC,qCAAA;AAMC,IAAMF,YAAA,CAAA,IAAA,GAAO5B,qBAAW,CAAAD,6BAAA,CAAa,aAAa,OAAO;AAAA,MAC9D,SAAA,EAAW,KAAK,EAAG,EAAA;AAAA,MACnB,oBAAA,EAAsB,KAAK,EAAG;AAAA,KAC9B,CAAA,CAAA;AAAA,GAzBa,EAAA6B,aAAA,GAAAhC,aAAA,CAAA,WAAA,KAAAA,aAAA,CAAA,WAAA,GAAA,EAAA,CAAA,CAAA;AA4BV,EAAA,CAAA,CAAUmC,oBAAV,KAAA;AACE,IAAMA,oBAAAA,CAAA,UAAU,MAAMC,qDAAA;AACtB,IAAMD,oBAAA,CAAA,IAAA,GAAO/B,qBAAW,CAAAD,6BAAA,CAAa,qBAAqB,OAAO;AAAA,MACtE,kBAAA,EAAoB,KAAK,EAAG,EAAA;AAAA,MAC5B,cAAA,EAAgB,KAAK,EAAG,EAAA;AAAA,MACxB,eAAA,EAAiB,KAAK,EAAG,EAAA;AAAA,MACzB,oBAAA,EAAsB,KAAK,EAAG;AAAA,KAC9B,CAAA,CAAA;AAAA,GAPa,EAAAH,aAAA,CAAA,mBAAA,KAAAA,aAAA,CAAA,mBAAA,GAAA,EAAA,CAAA,CAAA;AAUV,EAAA,CAAA,CAAUqC,cAAV,KAAA;AACE,IAAMA,cAAAA,CAAA,UAAU,MAAMC,yCAAA;AACtB,IAAMD,cAAA,CAAA,IAAA,GAAOjC,qBAAW,CAAAD,6BAAA,CAAa,eAAe,OAAO;AAAA,MAChE,eAAA,EAAiB,KAAK,EAAG,EAAA;AAAA,MACzB,qBAAA,EAAuB,KAAK,EAAG,EAAA;AAAA,MAC/B,cAAA,EAAgB,KAAK,EAAG;AAAA,KACxB,CAAA,CAAA;AAAA,GANa,EAAAH,aAAA,CAAA,aAAA,KAAAA,aAAA,CAAA,aAAA,GAAA,EAAA,CAAA,CAAA;AASV,EAAA,CAAA,CAAUuC,UAAV,KAAA;AACE,IAAMA,UAAAA,CAAA,UAAU,MAAMC,iCAAA;AACtB,IAAMD,UAAA,CAAA,IAAA,GAAOnC,qBAAW,CAAAD,6BAAA,CAAa,WAAW,OAAO;AAAA,MAC5D,yBAAA,EAA2B,KAAK,EAAG,EAAA;AAAA,MACnC,iBAAA,EAAmB,KAAK,EAAG,EAAA;AAAA,MAC3B,YAAA,EAAc,KAAK,EAAG,EAAA;AAAA,MACtB,WAAA,EAAa,KAAK,EAAG;AAAA,KACrB,CAAA,CAAA;AAAA,GAPa,EAAAH,aAAA,CAAA,SAAA,KAAAA,aAAA,CAAA,SAAA,GAAA,EAAA,CAAA,CAAA;AAUV,EAAA,CAAA,CAAUyC,UAAV,KAAA;AACE,IAAMA,UAAAA,CAAA,UAAU,MAAMC,iCAAA;AACtB,IAAMD,UAAA,CAAA,IAAA,GAAOrC,qBAAW,CAAAD,6BAAA,CAAa,WAAW,OAAO;AAAA,MAC5D,QAAA,EAAU,KAAK,EAAG,EAAA;AAAA,MAClB,OAAA,EAAS,KAAK,EAAG,EAAA;AAAA,MACjB,MAAA,EAAQ,KAAK,EAAG;AAAA,KAChB,CAAA,CAAA;AAAA,GANa,EAAAH,aAAA,CAAA,SAAA,KAAAA,aAAA,CAAA,SAAA,GAAA,EAAA,CAAA,CAAA;AAaV,EAAA,SAAS,MAAwB,GAAA;AACtC,IAAA,OAAO,IAAI2C,mCAAkB,EAAA;AAAA;AADxB,EAAA3C,aAAS,CAAA,MAAA,GAAA,MAAA;AAGT,EAAA,CAAA,CAAU4C,OAAV,KAAA;AAKE,IAAMA,OAAA,CAAA,OAAA,GAAU,wBAAyB,CAAAC,iCAAA,EAAkBD,OAAM,CAAA;AAMjE,IAAMA,OAAA,CAAA,IAAA,GAAOxC,qBAAW,CAAAyC,iCAAA,EAAkB,OAAO;AAAA,MACtD,OAAA,EAAS,KAAK,EAAG,EAAA;AAAA,MACjB,SAAA,EAAW,KAAK,EAAG;AAAA,KACnB,CAAA,CAAA;AAAA,GAda,EAAA,MAAA,GAAA7C,aAAA,CAAA,MAAA,KAAAA,aAAA,CAAA,MAAA,GAAA,EAAA,CAAA,CAAA;AAAA,CAnYF,EAAAA,oBAAA,KAAAA,oBAAA,GAAA,EAAA,CAAA,CAAA;;"}
|
|
1
|
+
{"version":3,"file":"mockServices.cjs.js","sources":["../../src/services/mockServices.ts"],"sourcesContent":["/*\n * Copyright 2023 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { auditorServiceFactory } from '@backstage/backend-defaults/auditor';\nimport { cacheServiceFactory } from '@backstage/backend-defaults/cache';\nimport { databaseServiceFactory } from '@backstage/backend-defaults/database';\nimport { HostDiscovery } from '@backstage/backend-defaults/discovery';\nimport { httpRouterServiceFactory } from '@backstage/backend-defaults/httpRouter';\nimport { lifecycleServiceFactory } from '@backstage/backend-defaults/lifecycle';\nimport { loggerServiceFactory } from '@backstage/backend-defaults/logger';\nimport { permissionsServiceFactory } from '@backstage/backend-defaults/permissions';\nimport { permissionsRegistryServiceFactory } from '@backstage/backend-defaults/permissionsRegistry';\nimport { rootHealthServiceFactory } from '@backstage/backend-defaults/rootHealth';\nimport { rootHttpRouterServiceFactory } from '@backstage/backend-defaults/rootHttpRouter';\nimport { rootLifecycleServiceFactory } from '@backstage/backend-defaults/rootLifecycle';\nimport { urlReaderServiceFactory } from '@backstage/backend-defaults/urlReader';\nimport {\n AuthService,\n BackstageCredentials,\n BackstageUserInfo,\n DatabaseService,\n DiscoveryService,\n HttpAuthService,\n LoggerService,\n PermissionsService,\n RootConfigService,\n SchedulerService,\n ServiceFactory,\n ServiceRef,\n UserInfoService,\n coreServices,\n createServiceFactory,\n} from '@backstage/backend-plugin-api';\nimport { ConfigReader } from '@backstage/config';\nimport { EventsService, eventsServiceRef } from '@backstage/plugin-events-node';\nimport { AuthorizeResult } from '@backstage/plugin-permission-common';\nimport { JsonObject } from '@backstage/types';\nimport { Knex } from 'knex';\nimport { MockAuthService } from './MockAuthService';\nimport { MockHttpAuthService } from './MockHttpAuthService';\nimport { MockRootLoggerService } from './MockRootLoggerService';\nimport { MockUserInfoService } from './MockUserInfoService';\nimport { mockCredentials } from './mockCredentials';\nimport { MockEventsService } from './MockEventsService';\nimport { MockPermissionsService } from './MockPermissionsService';\nimport { simpleMock } from './simpleMock';\nimport { MockSchedulerService } from './MockSchedulerService';\n\n/** @internal */\nfunction createLoggerMock() {\n return {\n child: jest.fn().mockImplementation(createLoggerMock),\n debug: jest.fn(),\n error: jest.fn(),\n info: jest.fn(),\n warn: jest.fn(),\n };\n}\n\n/** @internal */\nfunction simpleFactoryWithOptions<\n TService,\n TScope extends 'root' | 'plugin',\n TOptions extends [options?: object] = [],\n>(\n ref: ServiceRef<TService, TScope>,\n factory: (...options: TOptions) => TService,\n): (...options: TOptions) => ServiceFactory<TService, TScope> {\n const factoryWithOptions = (...options: TOptions) =>\n createServiceFactory({\n service: ref as ServiceRef<TService, any>,\n deps: {},\n async factory() {\n return factory(...options);\n },\n });\n return Object.assign(\n factoryWithOptions,\n factoryWithOptions(...([undefined] as unknown as TOptions)),\n ) as ServiceFactory<TService, TScope> &\n ((...options: TOptions) => ServiceFactory<TService, TScope>);\n}\n\n/**\n * Mock implementations of the core services, to be used in tests.\n *\n * @public\n * @remarks\n *\n * There are some variations among the services depending on what needs tests\n * might have, but overall there are three main usage patterns:\n *\n * 1. Creating an actual fake service instance, often with a simplified version\n * of functionality, by calling the mock service itself as a function.\n *\n * ```ts\n * // The function often accepts parameters that control its behavior\n * const foo = mockServices.foo();\n * ```\n *\n * 2. Creating a mock service, where all methods are replaced with jest mocks, by\n * calling the service's `mock` function.\n *\n * ```ts\n * // You can optionally supply a subset of its methods to implement\n * const foo = mockServices.foo.mock({\n * someMethod: () => 'mocked result',\n * });\n * // After exercising your test, you can make assertions on the mock:\n * expect(foo.someMethod).toHaveBeenCalledTimes(2);\n * expect(foo.otherMethod).toHaveBeenCalledWith(testData);\n * ```\n *\n * 3. Creating a service factory that behaves similarly to the mock as per above.\n *\n * ```ts\n * await startTestBackend({\n * features: [\n * mockServices.foo.factory({\n * someMethod: () => 'mocked result',\n * })\n * ],\n * });\n * ```\n */\nexport namespace mockServices {\n export function rootConfig(options?: rootConfig.Options): RootConfigService {\n return new ConfigReader(options?.data, 'mock-config');\n }\n export namespace rootConfig {\n export type Options = { data?: JsonObject };\n\n export const factory = simpleFactoryWithOptions(\n coreServices.rootConfig,\n rootConfig,\n );\n export const mock = simpleMock(coreServices.rootConfig, () => ({\n get: jest.fn(),\n getBoolean: jest.fn(),\n getConfig: jest.fn(),\n getConfigArray: jest.fn(),\n getNumber: jest.fn(),\n getOptional: jest.fn(),\n getOptionalBoolean: jest.fn(),\n getOptionalConfig: jest.fn(),\n getOptionalConfigArray: jest.fn(),\n getOptionalNumber: jest.fn(),\n getOptionalString: jest.fn(),\n getOptionalStringArray: jest.fn(),\n getString: jest.fn(),\n getStringArray: jest.fn(),\n has: jest.fn(),\n keys: jest.fn(),\n }));\n }\n\n export function rootLogger(options?: rootLogger.Options): LoggerService {\n return MockRootLoggerService.create(options);\n }\n export namespace rootLogger {\n export type Options = {\n level?: 'none' | 'error' | 'warn' | 'info' | 'debug';\n };\n\n export const factory = simpleFactoryWithOptions(\n coreServices.rootLogger,\n rootLogger,\n );\n export const mock = simpleMock(coreServices.rootLogger, () => ({\n child: jest.fn(),\n debug: jest.fn(),\n error: jest.fn(),\n info: jest.fn(),\n warn: jest.fn(),\n }));\n }\n\n export namespace auditor {\n export const factory = () => auditorServiceFactory;\n\n export const mock = simpleMock(coreServices.auditor, () => ({\n createEvent: jest.fn(async _ => {\n return {\n success: jest.fn(),\n fail: jest.fn(),\n };\n }),\n }));\n }\n\n export function auth(options?: {\n pluginId?: string;\n disableDefaultAuthPolicy?: boolean;\n }): AuthService {\n return new MockAuthService({\n pluginId: options?.pluginId ?? 'test',\n disableDefaultAuthPolicy: Boolean(options?.disableDefaultAuthPolicy),\n });\n }\n export namespace auth {\n export const factory = () =>\n createServiceFactory({\n service: coreServices.auth,\n deps: {\n plugin: coreServices.pluginMetadata,\n config: coreServices.rootConfig,\n },\n factory({ plugin, config }) {\n const disableDefaultAuthPolicy = Boolean(\n config.getOptionalBoolean(\n 'backend.auth.dangerouslyDisableDefaultAuthPolicy',\n ),\n );\n return new MockAuthService({\n pluginId: plugin.getId(),\n disableDefaultAuthPolicy,\n });\n },\n });\n export const mock = simpleMock(coreServices.auth, () => ({\n authenticate: jest.fn(),\n getNoneCredentials: jest.fn(),\n getOwnServiceCredentials: jest.fn(),\n isPrincipal: jest.fn() as any,\n getPluginRequestToken: jest.fn(),\n getLimitedUserToken: jest.fn(),\n listPublicServiceKeys: jest.fn(),\n }));\n }\n\n export function discovery(): DiscoveryService {\n return HostDiscovery.fromConfig(\n new ConfigReader({\n backend: {\n // Invalid port to make sure that requests are always mocked\n baseUrl: 'http://localhost:0',\n listen: { port: 0 },\n },\n }),\n );\n }\n export namespace discovery {\n export const factory = () =>\n createServiceFactory({\n service: coreServices.discovery,\n deps: {},\n factory: () => discovery(),\n });\n export const mock = simpleMock(coreServices.discovery, () => ({\n getBaseUrl: jest.fn(),\n getExternalBaseUrl: jest.fn(),\n }));\n }\n\n /**\n * Creates a mock implementation of the `HttpAuthService`.\n *\n * By default all requests without credentials are treated as requests from\n * the default mock user principal. This behavior can be configured with the\n * `defaultCredentials` option.\n */\n export function httpAuth(options?: {\n pluginId?: string;\n /**\n * The default credentials to use if there are no credentials present in the\n * incoming request.\n *\n * By default all requests without credentials are treated as authenticated\n * as the default mock user as returned from `mockCredentials.user()`.\n */\n defaultCredentials?: BackstageCredentials;\n }): HttpAuthService {\n return new MockHttpAuthService(\n options?.pluginId ?? 'test',\n options?.defaultCredentials ?? mockCredentials.user(),\n );\n }\n export namespace httpAuth {\n /**\n * Creates a mock service factory for the `HttpAuthService`.\n *\n * By default all requests without credentials are treated as requests from\n * the default mock user principal. This behavior can be configured with the\n * `defaultCredentials` option.\n */\n export const factory = (options?: {\n defaultCredentials?: BackstageCredentials;\n }) =>\n createServiceFactory({\n service: coreServices.httpAuth,\n deps: { plugin: coreServices.pluginMetadata },\n factory: ({ plugin }) =>\n new MockHttpAuthService(\n plugin.getId(),\n options?.defaultCredentials ?? mockCredentials.user(),\n ),\n });\n export const mock = simpleMock(coreServices.httpAuth, () => ({\n credentials: jest.fn(),\n issueUserCookie: jest.fn(),\n }));\n }\n\n /**\n * Creates a mock implementation of the `UserInfoService`.\n *\n * By default it extracts the user's entity ref from a user principal and\n * returns that as the only ownership entity ref, but this can be overridden\n * by passing in a custom set of user info.\n */\n export function userInfo(\n customInfo?: Partial<BackstageUserInfo>,\n ): UserInfoService {\n return new MockUserInfoService(customInfo);\n }\n export namespace userInfo {\n /**\n * Creates a mock service factory for the `UserInfoService`.\n *\n * By default it extracts the user's entity ref from a user principal and\n * returns that as the only ownership entity ref.\n */\n export const factory = () =>\n createServiceFactory({\n service: coreServices.userInfo,\n deps: {},\n factory() {\n return new MockUserInfoService();\n },\n });\n export const mock = simpleMock(coreServices.userInfo, () => ({\n getUserInfo: jest.fn(),\n }));\n }\n\n // TODO(Rugvip): Not all core services have implementations available here yet.\n // some may need a bit more refactoring for it to be simpler to\n // re-implement functioning mock versions here.\n export namespace cache {\n export const factory = () => cacheServiceFactory;\n export const mock = simpleMock(coreServices.cache, () => ({\n delete: jest.fn(),\n get: jest.fn(),\n set: jest.fn(),\n withOptions: jest.fn(),\n }));\n }\n\n /**\n * Creates a mock implementation of the\n * {@link @backstage/backend-plugin-api#coreServices.database}. Just returns\n * the given `knex` instance, which is useful in combination with the\n * {@link TestDatabases} facility.\n */\n export function database(options: {\n knex: Knex;\n migrations?: { skip?: boolean };\n }): DatabaseService {\n return {\n getClient: async () => options.knex,\n migrations: options.migrations,\n };\n }\n export namespace database {\n /**\n * Creates a mock factory for the\n * {@link @backstage/backend-plugin-api#coreServices.database}. Just returns\n * the given `knex` instance if you supply one, which is useful in\n * combination with the {@link TestDatabases} facility. Otherwise, it\n * returns the regular default database factory which reads config settings.\n */\n export const factory = (options?: {\n knex: Knex;\n migrations?: { skip?: boolean };\n }) =>\n options\n ? createServiceFactory({\n service: coreServices.database,\n deps: {},\n factory: () => database(options),\n })\n : databaseServiceFactory;\n /**\n * Creates a mock of the\n * {@link @backstage/backend-plugin-api#coreServices.database}, optionally\n * with some given method implementations.\n */\n export const mock = simpleMock(coreServices.database, () => ({\n getClient: jest.fn(),\n }));\n }\n\n export namespace rootHealth {\n export const factory = () => rootHealthServiceFactory;\n export const mock = simpleMock(coreServices.rootHealth, () => ({\n getLiveness: jest.fn(),\n getReadiness: jest.fn(),\n }));\n }\n\n export namespace httpRouter {\n export const factory = () => httpRouterServiceFactory;\n export const mock = simpleMock(coreServices.httpRouter, () => ({\n use: jest.fn(),\n addAuthPolicy: jest.fn(),\n }));\n }\n\n export namespace rootHttpRouter {\n export const factory = () => rootHttpRouterServiceFactory();\n export const mock = simpleMock(coreServices.rootHttpRouter, () => ({\n use: jest.fn(),\n }));\n }\n\n export namespace lifecycle {\n export const factory = () => lifecycleServiceFactory;\n export const mock = simpleMock(coreServices.lifecycle, () => ({\n addShutdownHook: jest.fn(),\n addStartupHook: jest.fn(),\n }));\n }\n\n export namespace logger {\n export const factory = () => loggerServiceFactory;\n export const mock = simpleMock(coreServices.logger, () =>\n createLoggerMock(),\n );\n }\n\n /**\n * Creates a functional mock implementation of the\n * {@link @backstage/backend-plugin-api#PermissionsService}.\n */\n export function permissions(options?: {\n result: AuthorizeResult.ALLOW | AuthorizeResult.DENY;\n }): PermissionsService {\n return new MockPermissionsService(options);\n }\n export namespace permissions {\n /**\n * Creates a mock factory for the\n * {@link @backstage/backend-plugin-api#coreServices.permissions}. Just\n * returns the given `result` if you supply one. Otherwise, it returns the\n * regular default permissions factory.\n */\n export const factory = (options?: {\n result: AuthorizeResult.ALLOW | AuthorizeResult.DENY;\n }) =>\n options?.result\n ? createServiceFactory({\n service: coreServices.permissions,\n deps: {},\n factory: () => new MockPermissionsService(options),\n })\n : permissionsServiceFactory;\n /**\n * Creates a mock of the\n * {@link @backstage/backend-plugin-api#coreServices.permissions},\n * optionally with some given method implementations.\n */\n export const mock = simpleMock(coreServices.permissions, () => ({\n authorize: jest.fn(),\n authorizeConditional: jest.fn(),\n }));\n }\n\n export namespace permissionsRegistry {\n export const factory = () => permissionsRegistryServiceFactory;\n export const mock = simpleMock(coreServices.permissionsRegistry, () => ({\n addPermissionRules: jest.fn(),\n addPermissions: jest.fn(),\n addResourceType: jest.fn(),\n getPermissionRuleset: jest.fn(),\n }));\n }\n\n export namespace rootLifecycle {\n export const factory = () => rootLifecycleServiceFactory;\n export const mock = simpleMock(coreServices.rootLifecycle, () => ({\n addShutdownHook: jest.fn(),\n addBeforeShutdownHook: jest.fn(),\n addStartupHook: jest.fn(),\n }));\n }\n\n export function scheduler(): SchedulerService {\n return new MockSchedulerService();\n }\n export namespace scheduler {\n export const factory = (options?: {\n skipTaskRunOnStartup?: boolean;\n includeManualTasksOnStartup?: boolean;\n includeInitialDelayedTasksOnStartup?: boolean;\n }) => new MockSchedulerService().factory(options);\n export const mock = simpleMock(coreServices.scheduler, () => ({\n createScheduledTaskRunner: jest.fn(),\n getScheduledTasks: jest.fn(),\n scheduleTask: jest.fn(),\n triggerTask: jest.fn(),\n }));\n }\n\n export namespace urlReader {\n export const factory = () => urlReaderServiceFactory;\n export const mock = simpleMock(coreServices.urlReader, () => ({\n readTree: jest.fn(),\n readUrl: jest.fn(),\n search: jest.fn(),\n }));\n }\n\n /**\n * Creates a functional mock implementation of the\n * {@link @backstage/backend-events-node#eventsServiceRef}.\n */\n export function events(): EventsService {\n return new MockEventsService();\n }\n export namespace events {\n /**\n * Creates a functional mock factory for the\n * {@link @backstage/backend-events-node#eventsServiceRef}.\n */\n export const factory = simpleFactoryWithOptions(eventsServiceRef, events);\n /**\n * Creates a mock of the\n * {@link @backstage/backend-events-node#eventsServiceRef}, optionally\n * with some given method implementations.\n */\n export const mock = simpleMock(eventsServiceRef, () => ({\n publish: jest.fn(),\n subscribe: jest.fn(),\n }));\n }\n}\n"],"names":["createServiceFactory","mockServices","ConfigReader","rootConfig","coreServices","simpleMock","MockRootLoggerService","rootLogger","auditor","auditorServiceFactory","MockAuthService","auth","discovery","HostDiscovery","MockHttpAuthService","mockCredentials","httpAuth","MockUserInfoService","userInfo","cache","cacheServiceFactory","database","databaseServiceFactory","rootHealth","rootHealthServiceFactory","httpRouter","httpRouterServiceFactory","rootHttpRouter","rootHttpRouterServiceFactory","lifecycle","lifecycleServiceFactory","logger","loggerServiceFactory","permissions","MockPermissionsService","permissionsServiceFactory","permissionsRegistry","permissionsRegistryServiceFactory","rootLifecycle","rootLifecycleServiceFactory","MockSchedulerService","scheduler","urlReader","urlReaderServiceFactory","MockEventsService","events","eventsServiceRef"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"simpleMock.cjs.js","sources":["../../src/services/simpleMock.ts"],"sourcesContent":["/*\n * Copyright 2025 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n createServiceFactory,\n ServiceFactory,\n ServiceRef,\n} from '@backstage/backend-plugin-api';\n\n/** @public */\nexport type ServiceMock<TService> = {\n factory: ServiceFactory<TService>;\n} & {\n [Key in keyof TService]: TService[Key] extends (\n ...args: infer Args\n ) => infer Return\n ? TService[Key] & jest.MockInstance<Return, Args>\n : TService[Key];\n};\n\n/** @internal */\nexport function simpleMock<TService>(\n ref: ServiceRef<TService, any>,\n mockFactory: () => jest.Mocked<TService>,\n): (partialImpl?: Partial<TService>) => ServiceMock<TService> {\n return partialImpl => {\n const mock = mockFactory();\n if (partialImpl) {\n for (const [key, impl] of Object.entries(partialImpl)) {\n if (typeof impl === 'function') {\n (mock as any)[key].mockImplementation(impl);\n } else {\n (mock as any)[key] = impl;\n }\n }\n }\n return Object.assign(mock, {\n factory: createServiceFactory({\n service: ref,\n deps: {},\n factory: () => mock,\n }),\n }) as ServiceMock<TService>;\n };\n}\n"],"names":["createServiceFactory"],"mappings":";;;;
|
|
1
|
+
{"version":3,"file":"simpleMock.cjs.js","sources":["../../src/services/simpleMock.ts"],"sourcesContent":["/*\n * Copyright 2025 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n createServiceFactory,\n ServiceFactory,\n ServiceRef,\n} from '@backstage/backend-plugin-api';\n\n/** @public */\nexport type ServiceMock<TService> = {\n factory: ServiceFactory<TService>;\n} & {\n [Key in keyof TService]: TService[Key] extends (\n ...args: infer Args\n ) => infer Return\n ? TService[Key] & jest.MockInstance<Return, Args>\n : TService[Key];\n};\n\n/** @internal */\nexport function simpleMock<TService>(\n ref: ServiceRef<TService, any>,\n mockFactory: () => jest.Mocked<TService>,\n): (partialImpl?: Partial<TService>) => ServiceMock<TService> {\n return partialImpl => {\n const mock = mockFactory();\n if (partialImpl) {\n for (const [key, impl] of Object.entries(partialImpl)) {\n if (typeof impl === 'function') {\n (mock as any)[key].mockImplementation(impl);\n } else {\n (mock as any)[key] = impl;\n }\n }\n }\n return Object.assign(mock, {\n factory: createServiceFactory({\n service: ref,\n deps: {},\n factory: () => mock,\n }),\n }) as ServiceMock<TService>;\n };\n}\n"],"names":["createServiceFactory"],"mappings":";;;;AAiCO,SAAS,UAAA,CACd,KACA,WAAA,EAC4D;AAC5D,EAAA,OAAO,CAAA,WAAA,KAAe;AACpB,IAAA,MAAM,OAAO,WAAA,EAAY;AACzB,IAAA,IAAI,WAAA,EAAa;AACf,MAAA,KAAA,MAAW,CAAC,GAAA,EAAK,IAAI,KAAK,MAAA,CAAO,OAAA,CAAQ,WAAW,CAAA,EAAG;AACrD,QAAA,IAAI,OAAO,SAAS,UAAA,EAAY;AAC9B,UAAC,IAAA,CAAa,GAAG,CAAA,CAAE,kBAAA,CAAmB,IAAI,CAAA;AAAA,QAC5C,CAAA,MAAO;AACL,UAAC,IAAA,CAAa,GAAG,CAAA,GAAI,IAAA;AAAA,QACvB;AAAA,MACF;AAAA,IACF;AACA,IAAA,OAAO,MAAA,CAAO,OAAO,IAAA,EAAM;AAAA,MACzB,SAASA,qCAAA,CAAqB;AAAA,QAC5B,OAAA,EAAS,GAAA;AAAA,QACT,MAAM,EAAC;AAAA,QACP,SAAS,MAAM;AAAA,OAChB;AAAA,KACF,CAAA;AAAA,EACH,CAAA;AACF;;;;"}
|
|
@@ -4,7 +4,7 @@ var rootHttpRouter = require('@backstage/backend-defaults/rootHttpRouter');
|
|
|
4
4
|
var mockServices = require('../services/mockServices.cjs.js');
|
|
5
5
|
require('../services/mockCredentials.cjs.js');
|
|
6
6
|
|
|
7
|
-
function mockErrorHandler() {
|
|
7
|
+
function mockErrorHandler(_options, ..._args) {
|
|
8
8
|
return rootHttpRouter.MiddlewareFactory.create({
|
|
9
9
|
config: mockServices.mockServices.rootConfig(),
|
|
10
10
|
logger: mockServices.mockServices.rootLogger()
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"errorHandler.cjs.js","sources":["../../src/util/errorHandler.ts"],"sourcesContent":["/*\n * Copyright 2024 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { MiddlewareFactory } from '@backstage/backend-defaults/rootHttpRouter';\nimport { mockServices } from '../services';\n\n/**\n * A mock for error handler middleware that can be used in router tests.\n * @public\n */\nexport function mockErrorHandler() {\n return MiddlewareFactory.create({\n config: mockServices.rootConfig(),\n logger: mockServices.rootLogger(),\n }).error();\n}\n"],"names":["MiddlewareFactory","mockServices"],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"file":"errorHandler.cjs.js","sources":["../../src/util/errorHandler.ts"],"sourcesContent":["/*\n * Copyright 2024 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { MiddlewareFactory } from '@backstage/backend-defaults/rootHttpRouter';\nimport { mockServices } from '../services';\n\n/**\n * A mock for error handler middleware that can be used in router tests.\n * @public\n *\n * @example\n * ```ts\n * const app = express();\n * app.use(mockErrorHandler());\n * ```\n */\nexport function mockErrorHandler(_options?: {}, ..._args: never[]) {\n return MiddlewareFactory.create({\n config: mockServices.rootConfig(),\n logger: mockServices.rootLogger(),\n }).error();\n}\n"],"names":["MiddlewareFactory","mockServices"],"mappings":";;;;;;AA6BO,SAAS,gBAAA,CAAiB,aAAkB,KAAA,EAAgB;AACjE,EAAA,OAAOA,iCAAkB,MAAA,CAAO;AAAA,IAC9B,MAAA,EAAQC,0BAAa,UAAA,EAAW;AAAA,IAChC,MAAA,EAAQA,0BAAa,UAAA;AAAW,GACjC,EAAE,KAAA,EAAM;AACX;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getDockerImageForName.cjs.js","sources":["../../src/util/getDockerImageForName.ts"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport const getDockerImageForName = (name: string) => {\n return process.env.BACKSTAGE_TEST_DOCKER_REGISTRY\n ? `${process.env.BACKSTAGE_TEST_DOCKER_REGISTRY}/${name}`\n : name;\n};\n"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"getDockerImageForName.cjs.js","sources":["../../src/util/getDockerImageForName.ts"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport const getDockerImageForName = (name: string) => {\n return process.env.BACKSTAGE_TEST_DOCKER_REGISTRY\n ? `${process.env.BACKSTAGE_TEST_DOCKER_REGISTRY}/${name}`\n : name;\n};\n"],"names":[],"mappings":";;AAgBO,MAAM,qBAAA,GAAwB,CAAC,IAAA,KAAiB;AACrD,EAAA,OAAO,OAAA,CAAQ,IAAI,8BAAA,GACf,CAAA,EAAG,QAAQ,GAAA,CAAI,8BAA8B,CAAA,CAAA,EAAI,IAAI,CAAA,CAAA,GACrD,IAAA;AACN;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"isDockerDisabledForTests.cjs.js","sources":["../../src/util/isDockerDisabledForTests.ts"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport function isDockerDisabledForTests() {\n // If we are not running in continuous integration, the default is to skip\n // the (relatively heavy, long running) docker based tests. If you want to\n // still run local tests for all databases, just pass either the CI=1 env\n // parameter to your test runner, or individual connection strings per\n // database or cache.\n return (\n Boolean(process.env.BACKSTAGE_TEST_DISABLE_DOCKER) ||\n !Boolean(process.env.CI)\n );\n}\n"],"names":[],"mappings":";;AAgBO,SAAS,
|
|
1
|
+
{"version":3,"file":"isDockerDisabledForTests.cjs.js","sources":["../../src/util/isDockerDisabledForTests.ts"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport function isDockerDisabledForTests() {\n // If we are not running in continuous integration, the default is to skip\n // the (relatively heavy, long running) docker based tests. If you want to\n // still run local tests for all databases, just pass either the CI=1 env\n // parameter to your test runner, or individual connection strings per\n // database or cache.\n return (\n Boolean(process.env.BACKSTAGE_TEST_DISABLE_DOCKER) ||\n !Boolean(process.env.CI)\n );\n}\n"],"names":[],"mappings":";;AAgBO,SAAS,wBAAA,GAA2B;AAMzC,EAAA,OACE,OAAA,CAAQ,QAAQ,GAAA,CAAI,6BAA6B,KACjD,CAAC,OAAA,CAAQ,OAAA,CAAQ,GAAA,CAAI,EAAE,CAAA;AAE3B;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ServiceFactoryTester.cjs.js","sources":["../../src/wiring/ServiceFactoryTester.ts"],"sourcesContent":["/*\n * Copyright 2023 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ServiceFactory, ServiceRef } from '@backstage/backend-plugin-api';\nimport { defaultServiceFactories } from './TestBackend';\n// Direct internal import to avoid duplication.\n// This is a relative import in order to make sure that the implementation is duplicated\n// rather than leading to an import from @backstage/backend-app-api.\n// eslint-disable-next-line @backstage/no-relative-monorepo-imports\nimport { ServiceRegistry } from '../../../backend-app-api/src/wiring/ServiceRegistry';\n\n/**\n * Options for {@link ServiceFactoryTester}.\n * @public\n */\nexport interface ServiceFactoryTesterOptions {\n /**\n * Additional service factories to make available as dependencies.\n *\n * @remarks\n *\n * If a service factory is provided for a service that already has a default\n * implementation, the provided factory will override the default.\n */\n dependencies?: Array<ServiceFactory>;\n}\n\n/**\n * A utility to help test service factories in isolation.\n *\n * @public\n */\nexport class ServiceFactoryTester<\n TService,\n TScope extends 'root' | 'plugin',\n TInstances extends 'singleton' | 'multiton' = 'singleton',\n> {\n readonly #subject: ServiceRef<TService, TScope, TInstances>;\n readonly #registry: ServiceRegistry;\n\n /**\n * Creates a new {@link ServiceFactoryTester} used to test the provided subject.\n *\n * @param subject - The service factory to test.\n * @param options - Additional options\n * @returns A new tester instance for the provided subject.\n */\n static from<\n TService,\n TScope extends 'root' | 'plugin',\n TInstances extends 'singleton' | 'multiton' = 'singleton',\n >(\n subject: ServiceFactory<TService, TScope, TInstances>,\n options?: ServiceFactoryTesterOptions,\n ): ServiceFactoryTester<TService, TScope, TInstances> {\n const registry = ServiceRegistry.create([\n ...defaultServiceFactories,\n ...(options?.dependencies ?? []),\n subject,\n ]);\n return new ServiceFactoryTester(subject.service, registry);\n }\n\n private constructor(\n subject: ServiceRef<TService, TScope, TInstances>,\n registry: ServiceRegistry,\n ) {\n this.#subject = subject;\n this.#registry = registry;\n }\n\n /**\n * Returns the service instance for the subject.\n *\n * @remarks\n *\n * If the subject is a plugin scoped service factory a plugin ID\n * can be provided to instantiate the service for a specific plugin.\n *\n * By default the plugin ID 'test' is used.\n */\n async getSubject(\n ...args: 'root' extends TScope ? [] : [pluginId?: string]\n ): Promise<TInstances extends 'multiton' ? TService[] : TService> {\n const [pluginId] = args;\n const instance = this.#registry.get(this.#subject, pluginId ?? 'test')!;\n return instance;\n }\n\n /**\n * Return the service instance for any of the provided dependencies or built-in services.\n *\n * @remarks\n *\n * A plugin ID can optionally be provided for plugin scoped services, otherwise the plugin ID 'test' is used.\n */\n async getService<\n TGetService,\n TGetScope extends 'root' | 'plugin',\n TGetInstances extends 'singleton' | 'multiton' = 'singleton',\n >(\n service: ServiceRef<TGetService, TGetScope, TGetInstances>,\n ...args: 'root' extends TGetScope ? [] : [pluginId?: string]\n ): Promise<TGetInstances extends 'multiton' ? TGetService[] : TGetService> {\n const [pluginId] = args;\n const instance = await this.#registry.get(service, pluginId ?? 'test');\n if (instance === undefined) {\n throw new Error(`Service '${service.id}' not found`);\n }\n return instance;\n }\n}\n"],"names":["ServiceRegistry","defaultServiceFactories"],"mappings":";;;;;AA6CO,MAAM,
|
|
1
|
+
{"version":3,"file":"ServiceFactoryTester.cjs.js","sources":["../../src/wiring/ServiceFactoryTester.ts"],"sourcesContent":["/*\n * Copyright 2023 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ServiceFactory, ServiceRef } from '@backstage/backend-plugin-api';\nimport { defaultServiceFactories } from './TestBackend';\n// Direct internal import to avoid duplication.\n// This is a relative import in order to make sure that the implementation is duplicated\n// rather than leading to an import from @backstage/backend-app-api.\n// eslint-disable-next-line @backstage/no-relative-monorepo-imports\nimport { ServiceRegistry } from '../../../backend-app-api/src/wiring/ServiceRegistry';\n\n/**\n * Options for {@link ServiceFactoryTester}.\n * @public\n */\nexport interface ServiceFactoryTesterOptions {\n /**\n * Additional service factories to make available as dependencies.\n *\n * @remarks\n *\n * If a service factory is provided for a service that already has a default\n * implementation, the provided factory will override the default.\n */\n dependencies?: Array<ServiceFactory>;\n}\n\n/**\n * A utility to help test service factories in isolation.\n *\n * @public\n */\nexport class ServiceFactoryTester<\n TService,\n TScope extends 'root' | 'plugin',\n TInstances extends 'singleton' | 'multiton' = 'singleton',\n> {\n readonly #subject: ServiceRef<TService, TScope, TInstances>;\n readonly #registry: ServiceRegistry;\n\n /**\n * Creates a new {@link ServiceFactoryTester} used to test the provided subject.\n *\n * @param subject - The service factory to test.\n * @param options - Additional options\n * @returns A new tester instance for the provided subject.\n */\n static from<\n TService,\n TScope extends 'root' | 'plugin',\n TInstances extends 'singleton' | 'multiton' = 'singleton',\n >(\n subject: ServiceFactory<TService, TScope, TInstances>,\n options?: ServiceFactoryTesterOptions,\n ): ServiceFactoryTester<TService, TScope, TInstances> {\n const registry = ServiceRegistry.create([\n ...defaultServiceFactories,\n ...(options?.dependencies ?? []),\n subject,\n ]);\n return new ServiceFactoryTester(subject.service, registry);\n }\n\n private constructor(\n subject: ServiceRef<TService, TScope, TInstances>,\n registry: ServiceRegistry,\n ) {\n this.#subject = subject;\n this.#registry = registry;\n }\n\n /**\n * Returns the service instance for the subject.\n *\n * @remarks\n *\n * If the subject is a plugin scoped service factory a plugin ID\n * can be provided to instantiate the service for a specific plugin.\n *\n * By default the plugin ID 'test' is used.\n */\n async getSubject(\n ...args: 'root' extends TScope ? [] : [pluginId?: string]\n ): Promise<TInstances extends 'multiton' ? TService[] : TService> {\n const [pluginId] = args;\n const instance = this.#registry.get(this.#subject, pluginId ?? 'test')!;\n return instance;\n }\n\n /**\n * Return the service instance for any of the provided dependencies or built-in services.\n *\n * @remarks\n *\n * A plugin ID can optionally be provided for plugin scoped services, otherwise the plugin ID 'test' is used.\n */\n async getService<\n TGetService,\n TGetScope extends 'root' | 'plugin',\n TGetInstances extends 'singleton' | 'multiton' = 'singleton',\n >(\n service: ServiceRef<TGetService, TGetScope, TGetInstances>,\n ...args: 'root' extends TGetScope ? [] : [pluginId?: string]\n ): Promise<TGetInstances extends 'multiton' ? TGetService[] : TGetService> {\n const [pluginId] = args;\n const instance = await this.#registry.get(service, pluginId ?? 'test');\n if (instance === undefined) {\n throw new Error(`Service '${service.id}' not found`);\n }\n return instance;\n }\n}\n"],"names":["ServiceRegistry","defaultServiceFactories"],"mappings":";;;;;AA6CO,MAAM,oBAAA,CAIX;AAAA,EACS,QAAA;AAAA,EACA,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAST,OAAO,IAAA,CAKL,OAAA,EACA,OAAA,EACoD;AACpD,IAAA,MAAM,QAAA,GAAWA,gCAAgB,MAAA,CAAO;AAAA,MACtC,GAAGC,mCAAA;AAAA,MACH,GAAI,OAAA,EAAS,YAAA,IAAgB,EAAC;AAAA,MAC9B;AAAA,KACD,CAAA;AACD,IAAA,OAAO,IAAI,oBAAA,CAAqB,OAAA,CAAQ,OAAA,EAAS,QAAQ,CAAA;AAAA,EAC3D;AAAA,EAEQ,WAAA,CACN,SACA,QAAA,EACA;AACA,IAAA,IAAA,CAAK,QAAA,GAAW,OAAA;AAChB,IAAA,IAAA,CAAK,SAAA,GAAY,QAAA;AAAA,EACnB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAYA,MAAM,cACD,IAAA,EAC6D;AAChE,IAAA,MAAM,CAAC,QAAQ,CAAA,GAAI,IAAA;AACnB,IAAA,MAAM,WAAW,IAAA,CAAK,SAAA,CAAU,IAAI,IAAA,CAAK,QAAA,EAAU,YAAY,MAAM,CAAA;AACrE,IAAA,OAAO,QAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAM,UAAA,CAKJ,OAAA,EAAA,GACG,IAAA,EACsE;AACzE,IAAA,MAAM,CAAC,QAAQ,CAAA,GAAI,IAAA;AACnB,IAAA,MAAM,WAAW,MAAM,IAAA,CAAK,UAAU,GAAA,CAAI,OAAA,EAAS,YAAY,MAAM,CAAA;AACrE,IAAA,IAAI,aAAa,MAAA,EAAW;AAC1B,MAAA,MAAM,IAAI,KAAA,CAAM,CAAA,SAAA,EAAY,OAAA,CAAQ,EAAE,CAAA,WAAA,CAAa,CAAA;AAAA,IACrD;AACA,IAAA,OAAO,QAAA;AAAA,EACT;AACF;;;;"}
|