mirror of
https://github.com/anthropics/claude-code-action.git
synced 2026-01-22 22:44:13 +08:00
The parseAllowedTools() function previously used .match() which only returns the first match. This caused tools specified in subsequent --allowed-tools flags to be ignored during MCP server initialization. Changes: - Add /g flag to regex patterns for global matching - Use matchAll() to find all occurrences - Deduplicate tools while preserving order - Make unquoted pattern not match quoted values Fixes #800 #vibe Co-authored-by: Claude <noreply@anthropic.com>
120 lines
3.8 KiB
TypeScript
120 lines
3.8 KiB
TypeScript
import { describe, test, expect } from "bun:test";
|
|
import { parseAllowedTools } from "../../src/modes/agent/parse-tools";
|
|
|
|
describe("parseAllowedTools", () => {
|
|
test("parses unquoted tools", () => {
|
|
const args = "--allowedTools mcp__github__*,mcp__github_comment__*";
|
|
expect(parseAllowedTools(args)).toEqual([
|
|
"mcp__github__*",
|
|
"mcp__github_comment__*",
|
|
]);
|
|
});
|
|
|
|
test("parses double-quoted tools", () => {
|
|
const args = '--allowedTools "mcp__github__*,mcp__github_comment__*"';
|
|
expect(parseAllowedTools(args)).toEqual([
|
|
"mcp__github__*",
|
|
"mcp__github_comment__*",
|
|
]);
|
|
});
|
|
|
|
test("parses single-quoted tools", () => {
|
|
const args = "--allowedTools 'mcp__github__*,mcp__github_comment__*'";
|
|
expect(parseAllowedTools(args)).toEqual([
|
|
"mcp__github__*",
|
|
"mcp__github_comment__*",
|
|
]);
|
|
});
|
|
|
|
test("returns empty array when no allowedTools", () => {
|
|
const args = "--someOtherFlag value";
|
|
expect(parseAllowedTools(args)).toEqual([]);
|
|
});
|
|
|
|
test("handles empty string", () => {
|
|
expect(parseAllowedTools("")).toEqual([]);
|
|
});
|
|
|
|
test("handles --allowedTools followed by another --allowedTools flag", () => {
|
|
const args = "--allowedTools --allowedTools mcp__github__*";
|
|
// The second --allowedTools is consumed as a value of the first, then skipped.
|
|
// This is an edge case with malformed input - returns empty.
|
|
expect(parseAllowedTools(args)).toEqual([]);
|
|
});
|
|
|
|
test("parses multiple separate --allowed-tools flags", () => {
|
|
const args =
|
|
"--allowed-tools 'mcp__context7__*' --allowed-tools 'Read,Glob' --allowed-tools 'mcp__github_inline_comment__*'";
|
|
expect(parseAllowedTools(args)).toEqual([
|
|
"mcp__context7__*",
|
|
"Read",
|
|
"Glob",
|
|
"mcp__github_inline_comment__*",
|
|
]);
|
|
});
|
|
|
|
test("parses multiple --allowed-tools flags on separate lines", () => {
|
|
const args = `--model 'claude-haiku'
|
|
--allowed-tools 'mcp__context7__*'
|
|
--allowed-tools 'Read,Glob,Grep'
|
|
--allowed-tools 'mcp__github_inline_comment__create_inline_comment'`;
|
|
expect(parseAllowedTools(args)).toEqual([
|
|
"mcp__context7__*",
|
|
"Read",
|
|
"Glob",
|
|
"Grep",
|
|
"mcp__github_inline_comment__create_inline_comment",
|
|
]);
|
|
});
|
|
|
|
test("deduplicates tools from multiple flags", () => {
|
|
const args =
|
|
"--allowed-tools 'Read,Glob' --allowed-tools 'Glob,Grep' --allowed-tools 'Read'";
|
|
expect(parseAllowedTools(args)).toEqual(["Read", "Glob", "Grep"]);
|
|
});
|
|
|
|
test("handles typo --alloedTools", () => {
|
|
const args = "--alloedTools mcp__github__*";
|
|
expect(parseAllowedTools(args)).toEqual([]);
|
|
});
|
|
|
|
test("handles multiple flags with allowedTools in middle", () => {
|
|
const args =
|
|
'--flag1 value1 --allowedTools "mcp__github__*" --flag2 value2';
|
|
expect(parseAllowedTools(args)).toEqual(["mcp__github__*"]);
|
|
});
|
|
|
|
test("trims whitespace from tool names", () => {
|
|
const args = "--allowedTools 'mcp__github__* , mcp__github_comment__* '";
|
|
expect(parseAllowedTools(args)).toEqual([
|
|
"mcp__github__*",
|
|
"mcp__github_comment__*",
|
|
]);
|
|
});
|
|
|
|
test("handles tools with special characters", () => {
|
|
const args =
|
|
'--allowedTools "mcp__github__create_issue,mcp__github_comment__update"';
|
|
expect(parseAllowedTools(args)).toEqual([
|
|
"mcp__github__create_issue",
|
|
"mcp__github_comment__update",
|
|
]);
|
|
});
|
|
|
|
test("parses kebab-case --allowed-tools", () => {
|
|
const args = "--allowed-tools mcp__github__*,mcp__github_comment__*";
|
|
expect(parseAllowedTools(args)).toEqual([
|
|
"mcp__github__*",
|
|
"mcp__github_comment__*",
|
|
]);
|
|
});
|
|
|
|
test("parses quoted kebab-case --allowed-tools", () => {
|
|
const args = '--allowed-tools "mcp__github__*,mcp__github_comment__*"';
|
|
expect(parseAllowedTools(args)).toEqual([
|
|
"mcp__github__*",
|
|
"mcp__github_comment__*",
|
|
]);
|
|
});
|
|
});
|