@google/gemini-cli-core 0.16.0-nightly.20251112.c961f274 → 0.16.0-preview.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.
Files changed (98) hide show
  1. package/dist/src/code_assist/experiments/client_metadata.js +2 -1
  2. package/dist/src/code_assist/experiments/client_metadata.js.map +1 -1
  3. package/dist/src/code_assist/experiments/client_metadata.test.js +7 -2
  4. package/dist/src/code_assist/experiments/client_metadata.test.js.map +1 -1
  5. package/dist/src/config/config.d.ts +0 -1
  6. package/dist/src/config/config.js +3 -26
  7. package/dist/src/config/config.js.map +1 -1
  8. package/dist/src/config/config.test.js +25 -21
  9. package/dist/src/config/config.test.js.map +1 -1
  10. package/dist/src/config/defaultModelConfigs.js +3 -0
  11. package/dist/src/config/defaultModelConfigs.js.map +1 -1
  12. package/dist/src/confirmation-bus/message-bus.d.ts +1 -1
  13. package/dist/src/confirmation-bus/message-bus.js +2 -2
  14. package/dist/src/confirmation-bus/message-bus.js.map +1 -1
  15. package/dist/src/confirmation-bus/message-bus.test.js +30 -24
  16. package/dist/src/confirmation-bus/message-bus.test.js.map +1 -1
  17. package/dist/src/core/client.js +3 -2
  18. package/dist/src/core/client.js.map +1 -1
  19. package/dist/src/core/geminiChat.d.ts +2 -2
  20. package/dist/src/core/geminiChat.js +12 -14
  21. package/dist/src/core/geminiChat.js.map +1 -1
  22. package/dist/src/core/geminiChat.test.js +65 -0
  23. package/dist/src/core/geminiChat.test.js.map +1 -1
  24. package/dist/src/core/logger.d.ts +7 -2
  25. package/dist/src/core/logger.js +15 -9
  26. package/dist/src/core/logger.js.map +1 -1
  27. package/dist/src/core/logger.test.js +31 -16
  28. package/dist/src/core/logger.test.js.map +1 -1
  29. package/dist/src/generated/git-commit.d.ts +2 -2
  30. package/dist/src/generated/git-commit.js +2 -2
  31. package/dist/src/generated/git-commit.js.map +1 -1
  32. package/dist/src/hooks/hookAggregator.d.ts +68 -0
  33. package/dist/src/hooks/hookAggregator.js +262 -0
  34. package/dist/src/hooks/hookAggregator.js.map +1 -0
  35. package/dist/src/hooks/hookAggregator.test.d.ts +6 -0
  36. package/dist/src/hooks/hookAggregator.test.js +387 -0
  37. package/dist/src/hooks/hookAggregator.test.js.map +1 -0
  38. package/dist/src/policy/config.js +3 -1
  39. package/dist/src/policy/config.js.map +1 -1
  40. package/dist/src/policy/config.test.js +118 -1
  41. package/dist/src/policy/config.test.js.map +1 -1
  42. package/dist/src/policy/policies/write.toml +10 -0
  43. package/dist/src/policy/policy-engine.d.ts +12 -3
  44. package/dist/src/policy/policy-engine.js +61 -7
  45. package/dist/src/policy/policy-engine.js.map +1 -1
  46. package/dist/src/policy/policy-engine.test.js +422 -86
  47. package/dist/src/policy/policy-engine.test.js.map +1 -1
  48. package/dist/src/policy/toml-loader.d.ts +2 -1
  49. package/dist/src/policy/toml-loader.js +103 -6
  50. package/dist/src/policy/toml-loader.js.map +1 -1
  51. package/dist/src/policy/toml-loader.test.js +32 -88
  52. package/dist/src/policy/toml-loader.test.js.map +1 -1
  53. package/dist/src/policy/types.d.ts +65 -0
  54. package/dist/src/policy/types.js +4 -0
  55. package/dist/src/policy/types.js.map +1 -1
  56. package/dist/src/safety/built-in.d.ts +21 -0
  57. package/dist/src/safety/built-in.js +106 -0
  58. package/dist/src/safety/built-in.js.map +1 -0
  59. package/dist/src/safety/built-in.test.d.ts +6 -0
  60. package/dist/src/safety/built-in.test.js +199 -0
  61. package/dist/src/safety/built-in.test.js.map +1 -0
  62. package/dist/src/safety/checker-runner.d.ts +48 -0
  63. package/dist/src/safety/checker-runner.js +208 -0
  64. package/dist/src/safety/checker-runner.js.map +1 -0
  65. package/dist/src/safety/checker-runner.test.d.ts +6 -0
  66. package/dist/src/safety/checker-runner.test.js +238 -0
  67. package/dist/src/safety/checker-runner.test.js.map +1 -0
  68. package/dist/src/safety/context-builder.d.ts +23 -0
  69. package/dist/src/safety/context-builder.js +47 -0
  70. package/dist/src/safety/context-builder.js.map +1 -0
  71. package/dist/src/safety/context-builder.test.d.ts +6 -0
  72. package/dist/src/safety/context-builder.test.js +49 -0
  73. package/dist/src/safety/context-builder.test.js.map +1 -0
  74. package/dist/src/safety/protocol.d.ts +88 -0
  75. package/dist/src/safety/protocol.js +15 -0
  76. package/dist/src/safety/protocol.js.map +1 -0
  77. package/dist/src/safety/registry.d.ts +26 -0
  78. package/dist/src/safety/registry.js +65 -0
  79. package/dist/src/safety/registry.js.map +1 -0
  80. package/dist/src/safety/registry.test.d.ts +6 -0
  81. package/dist/src/safety/registry.test.js +31 -0
  82. package/dist/src/safety/registry.test.js.map +1 -0
  83. package/dist/src/services/test-data/resolved-aliases.golden.json +16 -12
  84. package/dist/src/telemetry/loggers.js +2 -2
  85. package/dist/src/telemetry/loggers.js.map +1 -1
  86. package/dist/src/telemetry/metrics.d.ts +8 -4
  87. package/dist/src/telemetry/metrics.js +10 -4
  88. package/dist/src/telemetry/metrics.js.map +1 -1
  89. package/dist/src/telemetry/metrics.test.js +42 -0
  90. package/dist/src/telemetry/metrics.test.js.map +1 -1
  91. package/dist/src/tools/base-tool-invocation.test.js +2 -2
  92. package/dist/src/tools/base-tool-invocation.test.js.map +1 -1
  93. package/dist/src/tools/write-todos.d.ts +29 -0
  94. package/dist/src/tools/write-todos.js +33 -0
  95. package/dist/src/tools/write-todos.js.map +1 -1
  96. package/dist/tsconfig.tsbuildinfo +1 -1
  97. package/package.json +1 -1
  98. package/dist/google-gemini-cli-core-0.16.0-nightly.20251112.2abc288c.tgz +0 -0
@@ -0,0 +1,387 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { describe, it, expect, beforeEach } from 'vitest';
7
+ import { HookAggregator } from './hookAggregator.js';
8
+ import { HookType, HookEventName } from './types.js';
9
+ // Helper function to create proper HookExecutionResult objects
10
+ function createHookExecutionResult(output, success = true, duration = 100, error) {
11
+ return {
12
+ success,
13
+ output,
14
+ duration,
15
+ error,
16
+ hookConfig: {
17
+ type: HookType.Command,
18
+ command: 'test-command',
19
+ timeout: 30000,
20
+ },
21
+ eventName: HookEventName.BeforeTool,
22
+ };
23
+ }
24
+ describe('HookAggregator', () => {
25
+ let aggregator;
26
+ beforeEach(() => {
27
+ aggregator = new HookAggregator();
28
+ });
29
+ describe('aggregateResults', () => {
30
+ it('should handle empty results', () => {
31
+ const results = [];
32
+ const aggregated = aggregator.aggregateResults(results, HookEventName.BeforeTool);
33
+ expect(aggregated.success).toBe(true);
34
+ expect(aggregated.allOutputs).toHaveLength(0);
35
+ expect(aggregated.errors).toHaveLength(0);
36
+ expect(aggregated.totalDuration).toBe(0);
37
+ expect(aggregated.finalOutput).toBeUndefined();
38
+ });
39
+ it('should aggregate successful results', () => {
40
+ const results = [
41
+ createHookExecutionResult({ decision: 'allow', reason: 'Hook 1 approved' }, true, 100),
42
+ createHookExecutionResult({ decision: 'allow', reason: 'Hook 2 approved' }, true, 150),
43
+ ];
44
+ const aggregated = aggregator.aggregateResults(results, HookEventName.BeforeTool);
45
+ expect(aggregated.success).toBe(true);
46
+ expect(aggregated.allOutputs).toHaveLength(2);
47
+ expect(aggregated.errors).toHaveLength(0);
48
+ expect(aggregated.totalDuration).toBe(250);
49
+ expect(aggregated.finalOutput?.decision).toBe('allow');
50
+ expect(aggregated.finalOutput?.reason).toBe('Hook 1 approved\nHook 2 approved');
51
+ });
52
+ it('should handle errors in results', () => {
53
+ const results = [
54
+ {
55
+ hookConfig: {
56
+ type: HookType.Command,
57
+ command: 'test-command',
58
+ timeout: 30000,
59
+ },
60
+ eventName: HookEventName.BeforeTool,
61
+ success: false,
62
+ error: new Error('Hook failed'),
63
+ duration: 50,
64
+ },
65
+ {
66
+ hookConfig: {
67
+ type: HookType.Command,
68
+ command: 'test-command',
69
+ timeout: 30000,
70
+ },
71
+ eventName: HookEventName.BeforeTool,
72
+ success: true,
73
+ output: { decision: 'allow' },
74
+ duration: 100,
75
+ },
76
+ ];
77
+ const aggregated = aggregator.aggregateResults(results, HookEventName.BeforeTool);
78
+ expect(aggregated.success).toBe(false);
79
+ expect(aggregated.allOutputs).toHaveLength(1);
80
+ expect(aggregated.errors).toHaveLength(1);
81
+ expect(aggregated.errors[0].message).toBe('Hook failed');
82
+ expect(aggregated.totalDuration).toBe(150);
83
+ });
84
+ it('should handle blocking decisions with OR logic', () => {
85
+ const results = [
86
+ {
87
+ hookConfig: {
88
+ type: HookType.Command,
89
+ command: 'test-command',
90
+ timeout: 30000,
91
+ },
92
+ eventName: HookEventName.BeforeTool,
93
+ success: true,
94
+ output: { decision: 'allow', reason: 'Hook 1 allowed' },
95
+ duration: 100,
96
+ },
97
+ {
98
+ hookConfig: {
99
+ type: HookType.Command,
100
+ command: 'test-command',
101
+ timeout: 30000,
102
+ },
103
+ eventName: HookEventName.BeforeTool,
104
+ success: true,
105
+ output: { decision: 'block', reason: 'Hook 2 blocked' },
106
+ duration: 150,
107
+ },
108
+ ];
109
+ const aggregated = aggregator.aggregateResults(results, HookEventName.BeforeTool);
110
+ expect(aggregated.success).toBe(true);
111
+ expect(aggregated.finalOutput?.decision).toBe('block');
112
+ expect(aggregated.finalOutput?.reason).toBe('Hook 1 allowed\nHook 2 blocked');
113
+ });
114
+ it('should handle continue=false with precedence', () => {
115
+ const results = [
116
+ {
117
+ hookConfig: {
118
+ type: HookType.Command,
119
+ command: 'test-command',
120
+ timeout: 30000,
121
+ },
122
+ eventName: HookEventName.BeforeTool,
123
+ success: true,
124
+ output: { decision: 'allow', continue: true },
125
+ duration: 100,
126
+ },
127
+ {
128
+ hookConfig: {
129
+ type: HookType.Command,
130
+ command: 'test-command',
131
+ timeout: 30000,
132
+ },
133
+ eventName: HookEventName.BeforeTool,
134
+ success: true,
135
+ output: {
136
+ decision: 'allow',
137
+ continue: false,
138
+ stopReason: 'Stop requested',
139
+ },
140
+ duration: 150,
141
+ },
142
+ ];
143
+ const aggregated = aggregator.aggregateResults(results, HookEventName.BeforeTool);
144
+ expect(aggregated.success).toBe(true);
145
+ expect(aggregated.finalOutput?.continue).toBe(false);
146
+ expect(aggregated.finalOutput?.stopReason).toBe('Stop requested');
147
+ });
148
+ });
149
+ describe('BeforeToolSelection merge strategy', () => {
150
+ it('should merge tool configurations with NONE mode precedence', () => {
151
+ const results = [
152
+ {
153
+ hookConfig: {
154
+ type: HookType.Command,
155
+ command: 'test-command',
156
+ timeout: 30000,
157
+ },
158
+ eventName: HookEventName.BeforeToolSelection,
159
+ success: true,
160
+ output: {
161
+ hookSpecificOutput: {
162
+ hookEventName: 'BeforeToolSelection',
163
+ toolConfig: {
164
+ mode: 'ANY',
165
+ allowedFunctionNames: ['tool1', 'tool2'],
166
+ },
167
+ },
168
+ },
169
+ duration: 100,
170
+ },
171
+ {
172
+ hookConfig: {
173
+ type: HookType.Command,
174
+ command: 'test-command',
175
+ timeout: 30000,
176
+ },
177
+ eventName: HookEventName.BeforeToolSelection,
178
+ success: true,
179
+ output: {
180
+ hookSpecificOutput: {
181
+ hookEventName: 'BeforeToolSelection',
182
+ toolConfig: {
183
+ mode: 'NONE',
184
+ allowedFunctionNames: [],
185
+ },
186
+ },
187
+ },
188
+ duration: 150,
189
+ },
190
+ ];
191
+ const aggregated = aggregator.aggregateResults(results, HookEventName.BeforeToolSelection);
192
+ expect(aggregated.success).toBe(true);
193
+ const output = aggregated.finalOutput;
194
+ const toolConfig = output.hookSpecificOutput?.toolConfig;
195
+ expect(toolConfig?.mode).toBe('NONE');
196
+ expect(toolConfig?.allowedFunctionNames).toEqual([]);
197
+ });
198
+ it('should merge tool configurations with ANY mode', () => {
199
+ const results = [
200
+ {
201
+ hookConfig: {
202
+ type: HookType.Command,
203
+ command: 'test-command',
204
+ timeout: 30000,
205
+ },
206
+ eventName: HookEventName.BeforeToolSelection,
207
+ success: true,
208
+ output: {
209
+ hookSpecificOutput: {
210
+ hookEventName: 'BeforeToolSelection',
211
+ toolConfig: {
212
+ mode: 'AUTO',
213
+ allowedFunctionNames: ['tool1'],
214
+ },
215
+ },
216
+ },
217
+ duration: 100,
218
+ },
219
+ {
220
+ hookConfig: {
221
+ type: HookType.Command,
222
+ command: 'test-command',
223
+ timeout: 30000,
224
+ },
225
+ eventName: HookEventName.BeforeToolSelection,
226
+ success: true,
227
+ output: {
228
+ hookSpecificOutput: {
229
+ hookEventName: 'BeforeToolSelection',
230
+ toolConfig: {
231
+ mode: 'ANY',
232
+ allowedFunctionNames: ['tool2', 'tool3'],
233
+ },
234
+ },
235
+ },
236
+ duration: 150,
237
+ },
238
+ ];
239
+ const aggregated = aggregator.aggregateResults(results, HookEventName.BeforeToolSelection);
240
+ expect(aggregated.success).toBe(true);
241
+ const output = aggregated.finalOutput;
242
+ const toolConfig = output.hookSpecificOutput?.toolConfig;
243
+ expect(toolConfig?.mode).toBe('ANY');
244
+ expect(toolConfig?.allowedFunctionNames).toEqual([
245
+ 'tool1',
246
+ 'tool2',
247
+ 'tool3',
248
+ ]);
249
+ });
250
+ it('should merge tool configurations with AUTO mode when all are AUTO', () => {
251
+ const results = [
252
+ {
253
+ hookConfig: {
254
+ type: HookType.Command,
255
+ command: 'test-command',
256
+ timeout: 30000,
257
+ },
258
+ eventName: HookEventName.BeforeToolSelection,
259
+ success: true,
260
+ output: {
261
+ hookSpecificOutput: {
262
+ hookEventName: 'BeforeToolSelection',
263
+ toolConfig: {
264
+ mode: 'AUTO',
265
+ allowedFunctionNames: ['tool1'],
266
+ },
267
+ },
268
+ },
269
+ duration: 100,
270
+ },
271
+ {
272
+ hookConfig: {
273
+ type: HookType.Command,
274
+ command: 'test-command',
275
+ timeout: 30000,
276
+ },
277
+ eventName: HookEventName.BeforeToolSelection,
278
+ success: true,
279
+ output: {
280
+ hookSpecificOutput: {
281
+ hookEventName: 'BeforeToolSelection',
282
+ toolConfig: {
283
+ mode: 'AUTO',
284
+ allowedFunctionNames: ['tool2'],
285
+ },
286
+ },
287
+ },
288
+ duration: 150,
289
+ },
290
+ ];
291
+ const aggregated = aggregator.aggregateResults(results, HookEventName.BeforeToolSelection);
292
+ expect(aggregated.success).toBe(true);
293
+ const output = aggregated.finalOutput;
294
+ const toolConfig = output.hookSpecificOutput?.toolConfig;
295
+ expect(toolConfig?.mode).toBe('AUTO');
296
+ expect(toolConfig?.allowedFunctionNames).toEqual(['tool1', 'tool2']);
297
+ });
298
+ });
299
+ describe('BeforeModel/AfterModel merge strategy', () => {
300
+ it('should use field replacement strategy', () => {
301
+ const results = [
302
+ {
303
+ hookConfig: {
304
+ type: HookType.Command,
305
+ command: 'test-command',
306
+ timeout: 30000,
307
+ },
308
+ eventName: HookEventName.BeforeModel,
309
+ success: true,
310
+ output: {
311
+ decision: 'allow',
312
+ hookSpecificOutput: {
313
+ hookEventName: 'BeforeModel',
314
+ llm_request: { model: 'model1', config: {}, contents: [] },
315
+ },
316
+ },
317
+ duration: 100,
318
+ },
319
+ {
320
+ hookConfig: {
321
+ type: HookType.Command,
322
+ command: 'test-command',
323
+ timeout: 30000,
324
+ },
325
+ eventName: HookEventName.BeforeModel,
326
+ success: true,
327
+ output: {
328
+ decision: 'block',
329
+ hookSpecificOutput: {
330
+ hookEventName: 'BeforeModel',
331
+ llm_request: { model: 'model2', config: {}, contents: [] },
332
+ },
333
+ },
334
+ duration: 150,
335
+ },
336
+ ];
337
+ const aggregated = aggregator.aggregateResults(results, HookEventName.BeforeModel);
338
+ expect(aggregated.success).toBe(true);
339
+ expect(aggregated.finalOutput?.decision).toBe('block'); // Later value wins
340
+ const output = aggregated.finalOutput;
341
+ const llmRequest = output.hookSpecificOutput?.llm_request;
342
+ expect(llmRequest?.['model']).toBe('model2'); // Later value wins
343
+ });
344
+ });
345
+ describe('extractAdditionalContext', () => {
346
+ it('should extract additional context from hook outputs', () => {
347
+ const results = [
348
+ {
349
+ hookConfig: {
350
+ type: HookType.Command,
351
+ command: 'test-command',
352
+ timeout: 30000,
353
+ },
354
+ eventName: HookEventName.AfterTool,
355
+ success: true,
356
+ output: {
357
+ hookSpecificOutput: {
358
+ hookEventName: 'AfterTool',
359
+ additionalContext: 'Context from hook 1',
360
+ },
361
+ },
362
+ duration: 100,
363
+ },
364
+ {
365
+ hookConfig: {
366
+ type: HookType.Command,
367
+ command: 'test-command',
368
+ timeout: 30000,
369
+ },
370
+ eventName: HookEventName.AfterTool,
371
+ success: true,
372
+ output: {
373
+ hookSpecificOutput: {
374
+ hookEventName: 'AfterTool',
375
+ additionalContext: 'Context from hook 2',
376
+ },
377
+ },
378
+ duration: 150,
379
+ },
380
+ ];
381
+ const aggregated = aggregator.aggregateResults(results, HookEventName.AfterTool);
382
+ expect(aggregated.success).toBe(true);
383
+ expect(aggregated.finalOutput?.hookSpecificOutput?.['additionalContext']).toBe('Context from hook 1\nContext from hook 2');
384
+ });
385
+ });
386
+ });
387
+ //# sourceMappingURL=hookAggregator.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hookAggregator.test.js","sourceRoot":"","sources":["../../../src/hooks/hookAggregator.test.ts"],"names":[],"mappings":"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"}
@@ -82,7 +82,7 @@ export function formatPolicyError(error) {
82
82
  export async function createPolicyEngineConfig(settings, approvalMode, defaultPoliciesDir) {
83
83
  const policyDirs = getPolicyDirectories(defaultPoliciesDir);
84
84
  // Load policies from TOML files
85
- const { rules: tomlRules, errors } = await loadPoliciesFromToml(approvalMode, policyDirs, (dir) => getPolicyTier(dir, defaultPoliciesDir));
85
+ const { rules: tomlRules, checkers: tomlCheckers, errors, } = await loadPoliciesFromToml(approvalMode, policyDirs, (dir) => getPolicyTier(dir, defaultPoliciesDir));
86
86
  // Emit any errors encountered during TOML loading to the UI
87
87
  // coreEvents has a buffer that will display these once the UI is ready
88
88
  if (errors.length > 0) {
@@ -91,6 +91,7 @@ export async function createPolicyEngineConfig(settings, approvalMode, defaultPo
91
91
  }
92
92
  }
93
93
  const rules = [...tomlRules];
94
+ const checkers = [...tomlCheckers];
94
95
  // Priority system for policy rules:
95
96
  // - Higher priority numbers win over lower priority numbers
96
97
  // - When multiple rules match, the highest priority rule is applied
@@ -178,6 +179,7 @@ export async function createPolicyEngineConfig(settings, approvalMode, defaultPo
178
179
  }
179
180
  return {
180
181
  rules,
182
+ checkers,
181
183
  defaultDecision: PolicyDecision.ASK_USER,
182
184
  };
183
185
  }
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/policy/config.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/policy/config.ts"],"names":[],"mappings":"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"}
@@ -5,7 +5,7 @@
5
5
  */
6
6
  import { describe, it, expect, vi, afterEach, beforeEach } from 'vitest';
7
7
  import nodePath from 'node:path';
8
- import { ApprovalMode, PolicyDecision } from './types.js';
8
+ import { ApprovalMode, PolicyDecision, InProcessCheckerType } from './types.js';
9
9
  import { Storage } from '../config/storage.js';
10
10
  afterEach(() => {
11
11
  vi.clearAllMocks();
@@ -400,6 +400,123 @@ priority = 150
400
400
  expect(rule?.argsPattern?.test('{"command":"git push"}')).toBe(false);
401
401
  vi.doUnmock('node:fs/promises');
402
402
  });
403
+ it('should load safety_checker configuration from TOML', async () => {
404
+ const actualFs = await vi.importActual('node:fs/promises');
405
+ const mockReaddir = vi.fn(async (path, options) => {
406
+ if (typeof path === 'string' &&
407
+ nodePath
408
+ .normalize(path)
409
+ .includes(nodePath.normalize('.gemini/policies'))) {
410
+ return [
411
+ {
412
+ name: 'safety.toml',
413
+ isFile: () => true,
414
+ isDirectory: () => false,
415
+ },
416
+ ];
417
+ }
418
+ return actualFs.readdir(path, options);
419
+ });
420
+ const mockReadFile = vi.fn(async (path, options) => {
421
+ if (typeof path === 'string' &&
422
+ nodePath
423
+ .normalize(path)
424
+ .includes(nodePath.normalize('.gemini/policies/safety.toml'))) {
425
+ return `
426
+ [[rule]]
427
+ toolName = "write_file"
428
+ decision = "allow"
429
+ priority = 10
430
+
431
+ [[rule]]
432
+ toolName = "write_file"
433
+ decision = "allow"
434
+ priority = 10
435
+
436
+ [[safety_checker]]
437
+ toolName = "write_file"
438
+ priority = 10
439
+ [safety_checker.checker]
440
+ type = "in-process"
441
+ name = "allowed-path"
442
+ required_context = ["environment"]
443
+ [safety_checker.checker.config]
444
+ `;
445
+ }
446
+ return actualFs.readFile(path, options);
447
+ });
448
+ vi.doMock('node:fs/promises', () => ({
449
+ ...actualFs,
450
+ default: { ...actualFs, readFile: mockReadFile, readdir: mockReaddir },
451
+ readFile: mockReadFile,
452
+ readdir: mockReaddir,
453
+ }));
454
+ vi.resetModules();
455
+ const { createPolicyEngineConfig } = await import('./config.js');
456
+ const settings = {};
457
+ const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
458
+ const rule = config.rules?.find((r) => r.toolName === 'write_file' && r.decision === PolicyDecision.ALLOW);
459
+ expect(rule).toBeDefined();
460
+ const checker = config.checkers?.find((c) => c.toolName === 'write_file' && c.checker.type === 'in-process');
461
+ expect(checker).toBeDefined();
462
+ expect(checker?.checker.type).toBe('in-process');
463
+ expect(checker?.checker.name).toBe(InProcessCheckerType.ALLOWED_PATH);
464
+ expect(checker?.checker.required_context).toEqual(['environment']);
465
+ vi.doUnmock('node:fs/promises');
466
+ });
467
+ it('should reject invalid in-process checker names', async () => {
468
+ const actualFs = await vi.importActual('node:fs/promises');
469
+ const mockReaddir = vi.fn(async (path, options) => {
470
+ if (typeof path === 'string' &&
471
+ nodePath
472
+ .normalize(path)
473
+ .includes(nodePath.normalize('.gemini/policies'))) {
474
+ return [
475
+ {
476
+ name: 'invalid_safety.toml',
477
+ isFile: () => true,
478
+ isDirectory: () => false,
479
+ },
480
+ ];
481
+ }
482
+ return actualFs.readdir(path, options);
483
+ });
484
+ const mockReadFile = vi.fn(async (path, options) => {
485
+ if (typeof path === 'string' &&
486
+ nodePath
487
+ .normalize(path)
488
+ .includes(nodePath.normalize('.gemini/policies/invalid_safety.toml'))) {
489
+ return `
490
+ [[rule]]
491
+ toolName = "write_file"
492
+ decision = "allow"
493
+ priority = 10
494
+
495
+ [[safety_checker]]
496
+ toolName = "write_file"
497
+ priority = 10
498
+ [safety_checker.checker]
499
+ type = "in-process"
500
+ name = "invalid-name"
501
+ `;
502
+ }
503
+ return actualFs.readFile(path, options);
504
+ });
505
+ vi.doMock('node:fs/promises', () => ({
506
+ ...actualFs,
507
+ default: { ...actualFs, readFile: mockReadFile, readdir: mockReaddir },
508
+ readFile: mockReadFile,
509
+ readdir: mockReaddir,
510
+ }));
511
+ vi.resetModules();
512
+ const { createPolicyEngineConfig } = await import('./config.js');
513
+ const settings = {};
514
+ const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
515
+ // The rule should be rejected because 'invalid-name' is not in the enum
516
+ const rule = config.rules?.find((r) => r.toolName === 'write_file');
517
+ expect(rule).toBeUndefined();
518
+ vi.doUnmock('node:fs/promises');
519
+ });
403
520
  it('should have default ASK_USER rule for discovered tools', async () => {
404
521
  vi.resetModules();
405
522
  vi.doUnmock('node:fs/promises');