mirror of
https://github.com/anthropics/claude-code-action.git
synced 2026-01-23 06:54:13 +08:00
feat: enhance mode routing with track_progress and context preservation
This PR implements enhanced mode routing to address two critical v1 migration issues: 1. Lost GitHub context when using custom prompts in tag mode 2. Missing tracking comments for automatic PR reviews Changes: - Add track_progress input to force tag mode with tracking comments for PR/issue events - Support custom prompt injection in tag mode via <custom_instructions> section - Inject GitHub context as environment variables in agent mode - Validate track_progress usage (only allowed for PR/issue events) - Comprehensive test coverage for new routing logic Event Routing: - Comment events: Default to tag mode, switch to agent with explicit prompt - PR/Issue events: Default to agent mode, switch to tag mode with track_progress - Custom prompts can now be used in tag mode without losing context This ensures backward compatibility while solving context preservation and tracking visibility issues reported in discussions #490 and #491.
This commit is contained in:
@@ -73,6 +73,10 @@ inputs:
|
|||||||
description: "Enable commit signing using GitHub's commit signature verification. When false, Claude uses standard git commands"
|
description: "Enable commit signing using GitHub's commit signature verification. When false, Claude uses standard git commands"
|
||||||
required: false
|
required: false
|
||||||
default: "false"
|
default: "false"
|
||||||
|
track_progress:
|
||||||
|
description: "Force tag mode with tracking comments for pull_request and issue events. Only applicable to pull_request (opened, synchronize, ready_for_review, reopened) and issue (opened, edited, labeled, assigned) events."
|
||||||
|
required: false
|
||||||
|
default: "false"
|
||||||
experimental_allowed_domains:
|
experimental_allowed_domains:
|
||||||
description: "Restrict network access to these domains only (newline-separated). If not set, no restrictions are applied. Provider domains are auto-detected."
|
description: "Restrict network access to these domains only (newline-separated). If not set, no restrictions are applied. Provider domains are auto-detected."
|
||||||
required: false
|
required: false
|
||||||
@@ -140,6 +144,7 @@ runs:
|
|||||||
USE_STICKY_COMMENT: ${{ inputs.use_sticky_comment }}
|
USE_STICKY_COMMENT: ${{ inputs.use_sticky_comment }}
|
||||||
DEFAULT_WORKFLOW_TOKEN: ${{ github.token }}
|
DEFAULT_WORKFLOW_TOKEN: ${{ github.token }}
|
||||||
USE_COMMIT_SIGNING: ${{ inputs.use_commit_signing }}
|
USE_COMMIT_SIGNING: ${{ inputs.use_commit_signing }}
|
||||||
|
TRACK_PROGRESS: ${{ inputs.track_progress }}
|
||||||
ADDITIONAL_PERMISSIONS: ${{ inputs.additional_permissions }}
|
ADDITIONAL_PERMISSIONS: ${{ inputs.additional_permissions }}
|
||||||
CLAUDE_ARGS: ${{ inputs.claude_args }}
|
CLAUDE_ARGS: ${{ inputs.claude_args }}
|
||||||
ALL_INPUTS: ${{ toJson(inputs) }}
|
ALL_INPUTS: ${{ toJson(inputs) }}
|
||||||
@@ -247,6 +252,7 @@ runs:
|
|||||||
PREPARE_ERROR: ${{ steps.prepare.outputs.prepare_error || '' }}
|
PREPARE_ERROR: ${{ steps.prepare.outputs.prepare_error || '' }}
|
||||||
USE_STICKY_COMMENT: ${{ inputs.use_sticky_comment }}
|
USE_STICKY_COMMENT: ${{ inputs.use_sticky_comment }}
|
||||||
USE_COMMIT_SIGNING: ${{ inputs.use_commit_signing }}
|
USE_COMMIT_SIGNING: ${{ inputs.use_commit_signing }}
|
||||||
|
TRACK_PROGRESS: ${{ inputs.track_progress }}
|
||||||
|
|
||||||
- name: Display Claude Code Report
|
- name: Display Claude Code Report
|
||||||
if: steps.prepare.outputs.contains_trigger == 'true' && steps.claude-code.outputs.execution_file != ''
|
if: steps.prepare.outputs.contains_trigger == 'true' && steps.claude-code.outputs.execution_file != ''
|
||||||
|
|||||||
@@ -99,4 +99,5 @@ export type EventData =
|
|||||||
// Combined type with separate eventData field
|
// Combined type with separate eventData field
|
||||||
export type PreparedContext = CommonFields & {
|
export type PreparedContext = CommonFields & {
|
||||||
eventData: EventData;
|
eventData: EventData;
|
||||||
|
githubContext?: import("../github/context").GitHubContext;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -75,6 +75,7 @@ type BaseContext = {
|
|||||||
useStickyComment: boolean;
|
useStickyComment: boolean;
|
||||||
useCommitSigning: boolean;
|
useCommitSigning: boolean;
|
||||||
allowedBots: string;
|
allowedBots: string;
|
||||||
|
trackProgress: boolean;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -122,6 +123,7 @@ export function parseGitHubContext(): GitHubContext {
|
|||||||
useStickyComment: process.env.USE_STICKY_COMMENT === "true",
|
useStickyComment: process.env.USE_STICKY_COMMENT === "true",
|
||||||
useCommitSigning: process.env.USE_COMMIT_SIGNING === "true",
|
useCommitSigning: process.env.USE_COMMIT_SIGNING === "true",
|
||||||
allowedBots: process.env.ALLOWED_BOTS ?? "",
|
allowedBots: process.env.ALLOWED_BOTS ?? "",
|
||||||
|
trackProgress: process.env.TRACK_PROGRESS === "true",
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -5,6 +5,37 @@ import type { PreparedContext } from "../../create-prompt/types";
|
|||||||
import { prepareMcpConfig } from "../../mcp/install-mcp-server";
|
import { prepareMcpConfig } from "../../mcp/install-mcp-server";
|
||||||
import { parseAllowedTools } from "./parse-tools";
|
import { parseAllowedTools } from "./parse-tools";
|
||||||
import { configureGitAuth } from "../../github/operations/git-config";
|
import { configureGitAuth } from "../../github/operations/git-config";
|
||||||
|
import type { GitHubContext } from "../../github/context";
|
||||||
|
import { isEntityContext } from "../../github/context";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Extract GitHub context as environment variables for agent mode
|
||||||
|
*/
|
||||||
|
function extractGitHubContext(context: GitHubContext): Record<string, string> {
|
||||||
|
const envVars: Record<string, string> = {};
|
||||||
|
|
||||||
|
// Basic repository info
|
||||||
|
envVars.GITHUB_REPOSITORY = context.repository.full_name;
|
||||||
|
envVars.GITHUB_TRIGGER_ACTOR = context.actor;
|
||||||
|
envVars.GITHUB_EVENT_NAME = context.eventName;
|
||||||
|
|
||||||
|
// Entity-specific context (PR/issue numbers, branches, etc.)
|
||||||
|
if (isEntityContext(context)) {
|
||||||
|
if (context.isPR) {
|
||||||
|
envVars.GITHUB_PR_NUMBER = String(context.entityNumber);
|
||||||
|
|
||||||
|
// Extract branch info from payload if available
|
||||||
|
if (context.payload && 'pull_request' in context.payload && context.payload.pull_request) {
|
||||||
|
envVars.GITHUB_BASE_REF = context.payload.pull_request.base?.ref || '';
|
||||||
|
envVars.GITHUB_HEAD_REF = context.payload.pull_request.head?.ref || '';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
envVars.GITHUB_ISSUE_NUMBER = String(context.entityNumber);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return envVars;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Agent mode implementation.
|
* Agent mode implementation.
|
||||||
@@ -136,6 +167,14 @@ export const agentMode: Mode = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
generatePrompt(context: PreparedContext): string {
|
generatePrompt(context: PreparedContext): string {
|
||||||
|
// Inject GitHub context as environment variables
|
||||||
|
if (context.githubContext) {
|
||||||
|
const envVars = extractGitHubContext(context.githubContext);
|
||||||
|
for (const [key, value] of Object.entries(envVars)) {
|
||||||
|
core.exportVariable(key, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Agent mode uses prompt field
|
// Agent mode uses prompt field
|
||||||
if (context.prompt) {
|
if (context.prompt) {
|
||||||
return context.prompt;
|
return context.prompt;
|
||||||
|
|||||||
@@ -3,31 +3,60 @@ import {
|
|||||||
isEntityContext,
|
isEntityContext,
|
||||||
isIssueCommentEvent,
|
isIssueCommentEvent,
|
||||||
isPullRequestReviewCommentEvent,
|
isPullRequestReviewCommentEvent,
|
||||||
|
isPullRequestEvent,
|
||||||
|
isIssuesEvent,
|
||||||
|
isPullRequestReviewEvent,
|
||||||
} from "../github/context";
|
} from "../github/context";
|
||||||
import { checkContainsTrigger } from "../github/validation/trigger";
|
import { checkContainsTrigger } from "../github/validation/trigger";
|
||||||
|
|
||||||
export type AutoDetectedMode = "tag" | "agent";
|
export type AutoDetectedMode = "tag" | "agent";
|
||||||
|
|
||||||
export function detectMode(context: GitHubContext): AutoDetectedMode {
|
export function detectMode(context: GitHubContext): AutoDetectedMode {
|
||||||
// If prompt is provided, use agent mode for direct execution
|
// Validate track_progress usage
|
||||||
if (context.inputs?.prompt) {
|
if (context.inputs.trackProgress) {
|
||||||
return "agent";
|
validateTrackProgressEvent(context);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check for @claude mentions (tag mode)
|
// If track_progress is set for PR/issue events, force tag mode
|
||||||
|
if (context.inputs.trackProgress && isEntityContext(context)) {
|
||||||
|
if (isPullRequestEvent(context) || isIssuesEvent(context)) {
|
||||||
|
return "tag";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Comment events (current behavior - unchanged)
|
||||||
if (isEntityContext(context)) {
|
if (isEntityContext(context)) {
|
||||||
if (
|
if (
|
||||||
isIssueCommentEvent(context) ||
|
isIssueCommentEvent(context) ||
|
||||||
isPullRequestReviewCommentEvent(context)
|
isPullRequestReviewCommentEvent(context) ||
|
||||||
|
isPullRequestReviewEvent(context)
|
||||||
) {
|
) {
|
||||||
|
// If prompt is provided on comment events, use agent mode
|
||||||
|
if (context.inputs.prompt) {
|
||||||
|
return "agent";
|
||||||
|
}
|
||||||
|
// Default to tag mode if @claude mention found
|
||||||
|
if (checkContainsTrigger(context)) {
|
||||||
|
return "tag";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Issue events
|
||||||
|
if (isEntityContext(context) && isIssuesEvent(context)) {
|
||||||
|
// Check for @claude mentions or labels/assignees
|
||||||
if (checkContainsTrigger(context)) {
|
if (checkContainsTrigger(context)) {
|
||||||
return "tag";
|
return "tag";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (context.eventName === "issues") {
|
// PR events (opened, synchronize, etc.)
|
||||||
if (checkContainsTrigger(context)) {
|
if (isEntityContext(context) && isPullRequestEvent(context)) {
|
||||||
return "tag";
|
const supportedActions = ["opened", "synchronize", "ready_for_review", "reopened"];
|
||||||
|
if (context.eventAction && supportedActions.includes(context.eventAction)) {
|
||||||
|
// If prompt is provided, use agent mode (default for automation)
|
||||||
|
if (context.inputs.prompt) {
|
||||||
|
return "agent";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -47,6 +76,28 @@ export function getModeDescription(mode: AutoDetectedMode): string {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function validateTrackProgressEvent(context: GitHubContext): void {
|
||||||
|
// track_progress is only valid for pull_request and issue events
|
||||||
|
const validEvents = ["pull_request", "issues"];
|
||||||
|
if (!validEvents.includes(context.eventName)) {
|
||||||
|
throw new Error(
|
||||||
|
`track_progress is only supported for pull_request and issue events. ` +
|
||||||
|
`Current event: ${context.eventName}`
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Additionally validate PR actions
|
||||||
|
if (context.eventName === "pull_request" && context.eventAction) {
|
||||||
|
const validActions = ["opened", "synchronize", "ready_for_review", "reopened"];
|
||||||
|
if (!validActions.includes(context.eventAction)) {
|
||||||
|
throw new Error(
|
||||||
|
`track_progress for pull_request events is only supported for actions: ` +
|
||||||
|
`${validActions.join(", ")}. Current action: ${context.eventAction}`
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export function shouldUseTrackingComment(mode: AutoDetectedMode): boolean {
|
export function shouldUseTrackingComment(mode: AutoDetectedMode): boolean {
|
||||||
return mode === "tag";
|
return mode === "tag";
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -177,7 +177,18 @@ export const tagMode: Mode = {
|
|||||||
githubData: FetchDataResult,
|
githubData: FetchDataResult,
|
||||||
useCommitSigning: boolean,
|
useCommitSigning: boolean,
|
||||||
): string {
|
): string {
|
||||||
return generateDefaultPrompt(context, githubData, useCommitSigning);
|
const defaultPrompt = generateDefaultPrompt(context, githubData, useCommitSigning);
|
||||||
|
|
||||||
|
// If a custom prompt is provided, inject it into the tag mode prompt
|
||||||
|
if (context.githubContext?.inputs?.prompt) {
|
||||||
|
return defaultPrompt + `
|
||||||
|
|
||||||
|
<custom_instructions>
|
||||||
|
${context.githubContext.inputs.prompt}
|
||||||
|
</custom_instructions>`;
|
||||||
|
}
|
||||||
|
|
||||||
|
return defaultPrompt;
|
||||||
},
|
},
|
||||||
|
|
||||||
getSystemPrompt() {
|
getSystemPrompt() {
|
||||||
|
|||||||
@@ -32,6 +32,7 @@ describe("prepareMcpConfig", () => {
|
|||||||
useStickyComment: false,
|
useStickyComment: false,
|
||||||
useCommitSigning: false,
|
useCommitSigning: false,
|
||||||
allowedBots: "",
|
allowedBots: "",
|
||||||
|
trackProgress: false,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -19,6 +19,7 @@ const defaultInputs = {
|
|||||||
useStickyComment: false,
|
useStickyComment: false,
|
||||||
useCommitSigning: false,
|
useCommitSigning: false,
|
||||||
allowedBots: "",
|
allowedBots: "",
|
||||||
|
trackProgress: false,
|
||||||
};
|
};
|
||||||
|
|
||||||
const defaultRepository = {
|
const defaultRepository = {
|
||||||
|
|||||||
@@ -68,6 +68,7 @@ describe("checkWritePermissions", () => {
|
|||||||
useStickyComment: false,
|
useStickyComment: false,
|
||||||
useCommitSigning: false,
|
useCommitSigning: false,
|
||||||
allowedBots: "",
|
allowedBots: "",
|
||||||
|
trackProgress: false,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
225
tests/modes/detector.test.ts
Normal file
225
tests/modes/detector.test.ts
Normal file
@@ -0,0 +1,225 @@
|
|||||||
|
import { describe, expect, it } from "bun:test";
|
||||||
|
import { detectMode } from "../../src/modes/detector";
|
||||||
|
import type { GitHubContext } from "../../src/github/context";
|
||||||
|
|
||||||
|
describe("detectMode with enhanced routing", () => {
|
||||||
|
const baseContext = {
|
||||||
|
runId: "test-run",
|
||||||
|
eventAction: "opened",
|
||||||
|
repository: {
|
||||||
|
owner: "test-owner",
|
||||||
|
repo: "test-repo",
|
||||||
|
full_name: "test-owner/test-repo",
|
||||||
|
},
|
||||||
|
actor: "test-user",
|
||||||
|
inputs: {
|
||||||
|
prompt: "",
|
||||||
|
triggerPhrase: "@claude",
|
||||||
|
assigneeTrigger: "",
|
||||||
|
labelTrigger: "",
|
||||||
|
branchPrefix: "claude/",
|
||||||
|
useStickyComment: false,
|
||||||
|
useCommitSigning: false,
|
||||||
|
allowedBots: "",
|
||||||
|
trackProgress: false,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
describe("PR Events with track_progress", () => {
|
||||||
|
it("should use tag mode when track_progress is true for pull_request.opened", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "pull_request",
|
||||||
|
eventAction: "opened",
|
||||||
|
payload: { pull_request: { number: 1 } } as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: true,
|
||||||
|
inputs: { ...baseContext.inputs, trackProgress: true },
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("tag");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should use tag mode when track_progress is true for pull_request.synchronize", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "pull_request",
|
||||||
|
eventAction: "synchronize",
|
||||||
|
payload: { pull_request: { number: 1 } } as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: true,
|
||||||
|
inputs: { ...baseContext.inputs, trackProgress: true },
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("tag");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should use agent mode when track_progress is false for pull_request.opened", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "pull_request",
|
||||||
|
eventAction: "opened",
|
||||||
|
payload: { pull_request: { number: 1 } } as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: true,
|
||||||
|
inputs: { ...baseContext.inputs, trackProgress: false },
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("agent");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should throw error when track_progress is used with unsupported PR action", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "pull_request",
|
||||||
|
eventAction: "closed",
|
||||||
|
payload: { pull_request: { number: 1 } } as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: true,
|
||||||
|
inputs: { ...baseContext.inputs, trackProgress: true },
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(() => detectMode(context)).toThrow(/track_progress for pull_request events is only supported for actions/);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("Issue Events with track_progress", () => {
|
||||||
|
it("should use tag mode when track_progress is true for issues.opened", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "issues",
|
||||||
|
eventAction: "opened",
|
||||||
|
payload: { issue: { number: 1, body: "Test" } } as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: false,
|
||||||
|
inputs: { ...baseContext.inputs, trackProgress: true },
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("tag");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should use agent mode when track_progress is false for issues", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "issues",
|
||||||
|
eventAction: "opened",
|
||||||
|
payload: { issue: { number: 1, body: "Test" } } as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: false,
|
||||||
|
inputs: { ...baseContext.inputs, trackProgress: false },
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("agent");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("Comment Events (unchanged behavior)", () => {
|
||||||
|
it("should use tag mode for issue_comment with @claude mention", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "issue_comment",
|
||||||
|
payload: {
|
||||||
|
issue: { number: 1, body: "Test" },
|
||||||
|
comment: { body: "@claude help" }
|
||||||
|
} as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: false,
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("tag");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should use agent mode for issue_comment with prompt provided", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "issue_comment",
|
||||||
|
payload: {
|
||||||
|
issue: { number: 1, body: "Test" },
|
||||||
|
comment: { body: "@claude help" }
|
||||||
|
} as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: false,
|
||||||
|
inputs: { ...baseContext.inputs, prompt: "Review this PR" },
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("agent");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should use tag mode for PR review comments with @claude mention", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "pull_request_review_comment",
|
||||||
|
payload: {
|
||||||
|
pull_request: { number: 1, body: "Test" },
|
||||||
|
comment: { body: "@claude check this" }
|
||||||
|
} as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: true,
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("tag");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("Automation Events (should error with track_progress)", () => {
|
||||||
|
it("should throw error when track_progress is used with workflow_dispatch", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "workflow_dispatch",
|
||||||
|
payload: {} as any,
|
||||||
|
inputs: { ...baseContext.inputs, trackProgress: true },
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(() => detectMode(context)).toThrow(/track_progress is only supported for pull_request and issue events/);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should use agent mode for workflow_dispatch without track_progress", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "workflow_dispatch",
|
||||||
|
payload: {} as any,
|
||||||
|
inputs: { ...baseContext.inputs, prompt: "Run workflow" },
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("agent");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("Custom prompt injection in tag mode", () => {
|
||||||
|
it("should use tag mode for PR events when both track_progress and prompt are provided", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "pull_request",
|
||||||
|
eventAction: "opened",
|
||||||
|
payload: { pull_request: { number: 1 } } as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: true,
|
||||||
|
inputs: {
|
||||||
|
...baseContext.inputs,
|
||||||
|
trackProgress: true,
|
||||||
|
prompt: "Review for security issues"
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("tag");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should use tag mode for issue events when both track_progress and prompt are provided", () => {
|
||||||
|
const context: GitHubContext = {
|
||||||
|
...baseContext,
|
||||||
|
eventName: "issues",
|
||||||
|
eventAction: "opened",
|
||||||
|
payload: { issue: { number: 1, body: "Test" } } as any,
|
||||||
|
entityNumber: 1,
|
||||||
|
isPR: false,
|
||||||
|
inputs: {
|
||||||
|
...baseContext.inputs,
|
||||||
|
trackProgress: true,
|
||||||
|
prompt: "Analyze this issue"
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(detectMode(context)).toBe("tag");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user