chore: update vscode-based modules (wip)
This commit is contained in:
parent
5d9cbce8b6
commit
1fc998cdff
@ -99,6 +99,7 @@ describe("antigravity", async () => {
|
|||||||
|
|
||||||
it("writes ~/.gemini/antigravity/mcp_config.json when mcp provided", async () => {
|
it("writes ~/.gemini/antigravity/mcp_config.json when mcp provided", async () => {
|
||||||
const id = await runContainer("alpine");
|
const id = await runContainer("alpine");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const mcp = JSON.stringify({
|
const mcp = JSON.stringify({
|
||||||
servers: { demo: { url: "http://localhost:1234" } },
|
servers: { demo: { url: "http://localhost:1234" } },
|
||||||
@ -108,7 +109,7 @@ describe("antigravity", async () => {
|
|||||||
agent_id: "foo",
|
agent_id: "foo",
|
||||||
mcp,
|
mcp,
|
||||||
});
|
});
|
||||||
|
|
||||||
const script = findResourceInstance(
|
const script = findResourceInstance(
|
||||||
state,
|
state,
|
||||||
"coder_script",
|
"coder_script",
|
||||||
@ -121,6 +122,7 @@ describe("antigravity", async () => {
|
|||||||
console.log(resp.stderr);
|
console.log(resp.stderr);
|
||||||
}
|
}
|
||||||
expect(resp.exitCode).toBe(0);
|
expect(resp.exitCode).toBe(0);
|
||||||
|
|
||||||
const content = await readFileContainer(
|
const content = await readFileContainer(
|
||||||
id,
|
id,
|
||||||
"/root/.gemini/antigravity/mcp_config.json",
|
"/root/.gemini/antigravity/mcp_config.json",
|
||||||
|
|||||||
@ -53,7 +53,7 @@ variable "display_name" {
|
|||||||
variable "mcp" {
|
variable "mcp" {
|
||||||
type = string
|
type = string
|
||||||
description = "JSON-encoded string to configure MCP servers for Antigravity. When set, writes $HOME/.gemini/antigravity/mcp_config.json."
|
description = "JSON-encoded string to configure MCP servers for Antigravity. When set, writes $HOME/.gemini/antigravity/mcp_config.json."
|
||||||
default = ""
|
default = null
|
||||||
}
|
}
|
||||||
|
|
||||||
data "coder_workspace" "me" {}
|
data "coder_workspace" "me" {}
|
||||||
@ -73,7 +73,7 @@ module "vscode-desktop-core" {
|
|||||||
|
|
||||||
folder = var.folder
|
folder = var.folder
|
||||||
open_recent = var.open_recent
|
open_recent = var.open_recent
|
||||||
mcp_config = var.mcp
|
mcp_config = var.mcp != null ? jsondecode(var.mcp) : null # turn MCP JSON string into map(any) for vscode-desktop-core module
|
||||||
|
|
||||||
protocol = "antigravity"
|
protocol = "antigravity"
|
||||||
config_folder = "$HOME/.gemini/antigravity"
|
config_folder = "$HOME/.gemini/antigravity"
|
||||||
|
|||||||
@ -79,7 +79,7 @@ describe("cursor", async () => {
|
|||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("writes ~/.cursor/mcp.json when mcp provided", async () => {
|
it("writes ~/.cursor/mcp.json when var.mcp provided", async () => {
|
||||||
const id = await runContainer("alpine");
|
const id = await runContainer("alpine");
|
||||||
try {
|
try {
|
||||||
const mcp = JSON.stringify({
|
const mcp = JSON.stringify({
|
||||||
|
|||||||
@ -53,7 +53,7 @@ variable "display_name" {
|
|||||||
variable "mcp" {
|
variable "mcp" {
|
||||||
type = string
|
type = string
|
||||||
description = "JSON-encoded string to configure MCP servers for Cursor. When set, writes ~/.cursor/mcp.json."
|
description = "JSON-encoded string to configure MCP servers for Cursor. When set, writes ~/.cursor/mcp.json."
|
||||||
default = ""
|
default = null
|
||||||
}
|
}
|
||||||
|
|
||||||
data "coder_workspace" "me" {}
|
data "coder_workspace" "me" {}
|
||||||
@ -61,12 +61,11 @@ data "coder_workspace" "me" {}
|
|||||||
data "coder_workspace_owner" "me" {}
|
data "coder_workspace_owner" "me" {}
|
||||||
|
|
||||||
locals {
|
locals {
|
||||||
mcp_b64 = var.mcp != "" ? base64encode(var.mcp) : ""
|
mcp_b64 = var.mcp != null ? base64encode(var.mcp) : null
|
||||||
}
|
}
|
||||||
|
|
||||||
module "vscode-desktop-core" {
|
module "vscode-desktop-core" {
|
||||||
source = "registry.coder.com/coder/vscode-desktop-core/coder"
|
source = "git::https://github.com/coder/registry.git//registry/coder/modules/vscode-desktop-core?ref=phorcys/vscode-desktop-core-mcp"
|
||||||
version = "1.0.0"
|
|
||||||
|
|
||||||
agent_id = var.agent_id
|
agent_id = var.agent_id
|
||||||
|
|
||||||
@ -78,11 +77,14 @@ module "vscode-desktop-core" {
|
|||||||
|
|
||||||
folder = var.folder
|
folder = var.folder
|
||||||
open_recent = var.open_recent
|
open_recent = var.open_recent
|
||||||
protocol = "cursor"
|
# TODO: set mcp_config instead of coder_script
|
||||||
|
|
||||||
|
protocol = "cursor"
|
||||||
|
config_folder = "$HOME/.cursor"
|
||||||
}
|
}
|
||||||
|
|
||||||
resource "coder_script" "cursor_mcp" {
|
resource "coder_script" "cursor_mcp" {
|
||||||
count = var.mcp != "" ? 1 : 0
|
count = var.mcp != null ? 1 : 0
|
||||||
agent_id = var.agent_id
|
agent_id = var.agent_id
|
||||||
display_name = "Cursor MCP"
|
display_name = "Cursor MCP"
|
||||||
icon = "/icon/cursor.svg"
|
icon = "/icon/cursor.svg"
|
||||||
|
|||||||
@ -58,7 +58,7 @@ describe("kiro", async () => {
|
|||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("writes ~/.kiro/settings/mcp.json when mcp provided", async () => {
|
it("writes ~/.kiro/settings/mcp.json when var.mcp provided", async () => {
|
||||||
const id = await runContainer("alpine");
|
const id = await runContainer("alpine");
|
||||||
try {
|
try {
|
||||||
const mcp = JSON.stringify({
|
const mcp = JSON.stringify({
|
||||||
|
|||||||
@ -41,19 +41,18 @@ variable "group" {
|
|||||||
variable "mcp" {
|
variable "mcp" {
|
||||||
type = string
|
type = string
|
||||||
description = "JSON-encoded string to configure MCP servers for Kiro. When set, writes ~/.kiro/settings/mcp.json."
|
description = "JSON-encoded string to configure MCP servers for Kiro. When set, writes ~/.kiro/settings/mcp.json."
|
||||||
default = ""
|
default = null
|
||||||
}
|
}
|
||||||
|
|
||||||
data "coder_workspace" "me" {}
|
data "coder_workspace" "me" {}
|
||||||
data "coder_workspace_owner" "me" {}
|
data "coder_workspace_owner" "me" {}
|
||||||
|
|
||||||
locals {
|
locals {
|
||||||
mcp_b64 = var.mcp != "" ? base64encode(var.mcp) : ""
|
mcp_b64 = var.mcp != null ? base64encode(var.mcp) : null
|
||||||
}
|
}
|
||||||
|
|
||||||
module "vscode-desktop-core" {
|
module "vscode-desktop-core" {
|
||||||
source = "registry.coder.com/coder/vscode-desktop-core/coder"
|
source = "git::https://github.com/coder/registry.git//registry/coder/modules/vscode-desktop-core?ref=phorcys/vscode-desktop-core-mcp"
|
||||||
version = "1.0.0"
|
|
||||||
|
|
||||||
agent_id = var.agent_id
|
agent_id = var.agent_id
|
||||||
|
|
||||||
@ -65,11 +64,14 @@ module "vscode-desktop-core" {
|
|||||||
|
|
||||||
folder = var.folder
|
folder = var.folder
|
||||||
open_recent = var.open_recent
|
open_recent = var.open_recent
|
||||||
protocol = "kiro"
|
# TODO: set mcp_config instead of coder_script
|
||||||
|
|
||||||
|
protocol = "kiro"
|
||||||
|
config_folder = "$HOME/.kiro"
|
||||||
}
|
}
|
||||||
|
|
||||||
resource "coder_script" "kiro_mcp" {
|
resource "coder_script" "kiro_mcp" {
|
||||||
count = var.mcp != "" ? 1 : 0
|
count = var.mcp != null ? 1 : 0
|
||||||
agent_id = var.agent_id
|
agent_id = var.agent_id
|
||||||
display_name = "Kiro MCP"
|
display_name = "Kiro MCP"
|
||||||
icon = "/icon/kiro.svg"
|
icon = "/icon/kiro.svg"
|
||||||
|
|||||||
@ -39,8 +39,7 @@ variable "group" {
|
|||||||
}
|
}
|
||||||
|
|
||||||
module "vscode-desktop-core" {
|
module "vscode-desktop-core" {
|
||||||
source = "registry.coder.com/coder/vscode-desktop-core/coder"
|
source = "git::https://github.com/coder/registry.git//registry/coder/modules/vscode-desktop-core?ref=phorcys/vscode-desktop-core-mcp"
|
||||||
version = "1.0.0"
|
|
||||||
|
|
||||||
agent_id = var.agent_id
|
agent_id = var.agent_id
|
||||||
|
|
||||||
@ -52,7 +51,9 @@ module "vscode-desktop-core" {
|
|||||||
|
|
||||||
folder = var.folder
|
folder = var.folder
|
||||||
open_recent = var.open_recent
|
open_recent = var.open_recent
|
||||||
protocol = "vscode"
|
|
||||||
|
protocol = "vscode"
|
||||||
|
config_folder = "$HOME/.vscode"
|
||||||
}
|
}
|
||||||
|
|
||||||
output "vscode_url" {
|
output "vscode_url" {
|
||||||
|
|||||||
@ -79,27 +79,32 @@ describe("windsurf", async () => {
|
|||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("writes ~/.codeium/windsurf/mcp_config.json when mcp provided", async () => {
|
it("writes ~/.codeium/windsurf/mcp_config.json when var.mcp is provided", async () => {
|
||||||
const id = await runContainer("alpine");
|
const id = await runContainer("alpine");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const mcp = JSON.stringify({
|
const mcp = JSON.stringify({
|
||||||
servers: { demo: { url: "http://localhost:1234" } },
|
servers: { demo: { url: "http://localhost:1234" } },
|
||||||
});
|
});
|
||||||
|
|
||||||
const state = await runTerraformApply(import.meta.dir, {
|
const state = await runTerraformApply(import.meta.dir, {
|
||||||
agent_id: "foo",
|
agent_id: "foo",
|
||||||
mcp,
|
mcp,
|
||||||
});
|
});
|
||||||
|
|
||||||
const script = findResourceInstance(
|
const script = findResourceInstance(
|
||||||
state,
|
state,
|
||||||
"coder_script",
|
"coder_script",
|
||||||
"windsurf_mcp",
|
"vscode-desktop-mcp", // from "vscode-desktop-core" module
|
||||||
).script;
|
).script;
|
||||||
|
|
||||||
const resp = await execContainer(id, ["sh", "-c", script]);
|
const resp = await execContainer(id, ["sh", "-c", script]);
|
||||||
if (resp.exitCode !== 0) {
|
if (resp.exitCode !== 0) {
|
||||||
console.log(resp.stdout);
|
console.log(resp.stdout);
|
||||||
console.log(resp.stderr);
|
console.log(resp.stderr);
|
||||||
}
|
}
|
||||||
expect(resp.exitCode).toBe(0);
|
expect(resp.exitCode).toBe(0);
|
||||||
|
|
||||||
const content = await readFileContainer(
|
const content = await readFileContainer(
|
||||||
id,
|
id,
|
||||||
"/root/.codeium/windsurf/mcp_config.json",
|
"/root/.codeium/windsurf/mcp_config.json",
|
||||||
|
|||||||
@ -53,19 +53,14 @@ variable "display_name" {
|
|||||||
variable "mcp" {
|
variable "mcp" {
|
||||||
type = string
|
type = string
|
||||||
description = "JSON-encoded string to configure MCP servers for Windsurf. When set, writes ~/.codeium/windsurf/mcp_config.json."
|
description = "JSON-encoded string to configure MCP servers for Windsurf. When set, writes ~/.codeium/windsurf/mcp_config.json."
|
||||||
default = ""
|
default = null
|
||||||
}
|
}
|
||||||
|
|
||||||
data "coder_workspace" "me" {}
|
data "coder_workspace" "me" {}
|
||||||
data "coder_workspace_owner" "me" {}
|
data "coder_workspace_owner" "me" {}
|
||||||
|
|
||||||
locals {
|
|
||||||
mcp_b64 = var.mcp != "" ? base64encode(var.mcp) : ""
|
|
||||||
}
|
|
||||||
|
|
||||||
module "vscode-desktop-core" {
|
module "vscode-desktop-core" {
|
||||||
source = "registry.coder.com/coder/vscode-desktop-core/coder"
|
source = "git::https://github.com/coder/registry.git//registry/coder/modules/vscode-desktop-core?ref=phorcys/vscode-desktop-core-mcp"
|
||||||
version = "1.0.0"
|
|
||||||
|
|
||||||
agent_id = var.agent_id
|
agent_id = var.agent_id
|
||||||
|
|
||||||
@ -77,23 +72,10 @@ module "vscode-desktop-core" {
|
|||||||
|
|
||||||
folder = var.folder
|
folder = var.folder
|
||||||
open_recent = var.open_recent
|
open_recent = var.open_recent
|
||||||
protocol = "windsurf"
|
mcp_config = var.mcp != null ? jsondecode(var.mcp) : null # turn MCP JSON string into map(any) for vscode-desktop-core module
|
||||||
}
|
|
||||||
|
|
||||||
resource "coder_script" "windsurf_mcp" {
|
protocol = "windsurf"
|
||||||
count = var.mcp != "" ? 1 : 0
|
config_folder = "$HOME/.codeium/windsurf"
|
||||||
agent_id = var.agent_id
|
|
||||||
display_name = "Windsurf MCP"
|
|
||||||
icon = "/icon/windsurf.svg"
|
|
||||||
run_on_start = true
|
|
||||||
start_blocks_login = false
|
|
||||||
script = <<-EOT
|
|
||||||
#!/bin/sh
|
|
||||||
set -eu
|
|
||||||
mkdir -p "$HOME/.codeium/windsurf"
|
|
||||||
echo -n "${local.mcp_b64}" | base64 -d > "$HOME/.codeium/windsurf/mcp_config.json"
|
|
||||||
chmod 600 "$HOME/.codeium/windsurf/mcp_config.json"
|
|
||||||
EOT
|
|
||||||
}
|
}
|
||||||
|
|
||||||
output "windsurf_url" {
|
output "windsurf_url" {
|
||||||
|
|||||||
@ -54,8 +54,7 @@ data "coder_workspace" "me" {}
|
|||||||
data "coder_workspace_owner" "me" {}
|
data "coder_workspace_owner" "me" {}
|
||||||
|
|
||||||
module "vscode-desktop-core" {
|
module "vscode-desktop-core" {
|
||||||
source = "registry.coder.com/coder/vscode-desktop-core/coder"
|
source = "git::https://github.com/coder/registry.git//registry/coder/modules/vscode-desktop-core?ref=phorcys/vscode-desktop-core-mcp"
|
||||||
version = "1.0.0"
|
|
||||||
|
|
||||||
agent_id = var.agent_id
|
agent_id = var.agent_id
|
||||||
|
|
||||||
@ -67,7 +66,9 @@ module "vscode-desktop-core" {
|
|||||||
|
|
||||||
folder = var.folder
|
folder = var.folder
|
||||||
open_recent = var.open_recent
|
open_recent = var.open_recent
|
||||||
protocol = "positron"
|
|
||||||
|
protocol = "positron"
|
||||||
|
config_folder = "$HOME/.positron" # TODO: verify this
|
||||||
}
|
}
|
||||||
|
|
||||||
output "positron_url" {
|
output "positron_url" {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user