Summary
Three endpoints that take issue_number as a required parameter consistently fail when invoked with an integer, even though the tool schema declares issue_number as number. Other endpoints on the same server that take integer parameters work correctly, and the failure survives reconnecting the MCP server.
Affected tools
add_issue_comment
update_issue
get_issue
Unaffected tools (for comparison, same session, same repo, same auth)
create_issue — succeeds (does not take issue_number)
list_issues, search_issues — succeed
create_branch, create_or_update_file, push_files, create_pull_request — all succeed, including calls with integer fields like milestone
Reproduction
- Any repo the caller can write issues on.
- Call, e.g.:
{
"tool": "add_issue_comment",
"arguments": {
"owner": "<owner>",
"repo": "<repo>",
"issue_number": 11,
"body": "test"
}
}
- Call fails. Retrying multiple times, including after fully reconnecting the MCP server, reproduces the failure.
create_issue against the same repo in the same session succeeds, ruling out auth, permissions, and rate limiting.
- Reproduced across at least two independent sessions on the same day.
Expected
Comment is posted / issue is updated / issue is fetched, matching a direct REST call to POST /repos/{owner}/{repo}/issues/{issue_number}/comments (etc.).
Actual
Call is rejected before it reaches GitHub. The failure pattern is consistent with issue_number being serialised as a string somewhere in the request pipeline and then rejected by the server's own integer validation.
[TODO fill in with error string on next occurrence]
Hypothesis
The three broken endpoints are exactly the ones where issue_number is templated into a URL path segment (/repos/{owner}/{repo}/issues/{issue_number}[/comments]), whereas the working endpoints pass their integers in the request body or query string. Likely culprits:
- A path-parameter substitution step stringifies the value before an internal validator runs.
- A schema-validation layer runs after path substitution and sees a string where a
number is required.
Anywhere issue_number is interpolated into a URL is worth checking first.
Affected version
- MCP server: GitHub MCP http server
- Transport: stdio.
- Client: custom provider
Please run docker run -i --rm ghcr.io/github/github-mcp-server ./github-mcp-server --version and paste the output below
Workaround
None from the client side; the caller cannot influence how the server serialises the parameter. Affected users have to fall back to the GitHub REST API directly or edit the issue in the web UI.
Summary
Three endpoints that take
issue_numberas a required parameter consistently fail when invoked with an integer, even though the tool schema declaresissue_numberasnumber. Other endpoints on the same server that take integer parameters work correctly, and the failure survives reconnecting the MCP server.Affected tools
add_issue_commentupdate_issueget_issueUnaffected tools (for comparison, same session, same repo, same auth)
create_issue— succeeds (does not takeissue_number)list_issues,search_issues— succeedcreate_branch,create_or_update_file,push_files,create_pull_request— all succeed, including calls with integer fields likemilestoneReproduction
{ "tool": "add_issue_comment", "arguments": { "owner": "<owner>", "repo": "<repo>", "issue_number": 11, "body": "test" } }create_issueagainst the same repo in the same session succeeds, ruling out auth, permissions, and rate limiting.Expected
Comment is posted / issue is updated / issue is fetched, matching a direct REST call to
POST /repos/{owner}/{repo}/issues/{issue_number}/comments(etc.).Actual
Call is rejected before it reaches GitHub. The failure pattern is consistent with
issue_numberbeing serialised as a string somewhere in the request pipeline and then rejected by the server's own integer validation.[TODO fill in with error string on next occurrence]
Hypothesis
The three broken endpoints are exactly the ones where
issue_numberis templated into a URL path segment (/repos/{owner}/{repo}/issues/{issue_number}[/comments]), whereas the working endpoints pass their integers in the request body or query string. Likely culprits:numberis required.Anywhere
issue_numberis interpolated into a URL is worth checking first.Affected version
Please run
docker run -i --rm ghcr.io/github/github-mcp-server ./github-mcp-server --versionand paste the output belowWorkaround
None from the client side; the caller cannot influence how the server serialises the parameter. Affected users have to fall back to the GitHub REST API directly or edit the issue in the web UI.