Skip to content

Commit

Permalink
fix: sync observability on versions deploy
Browse files Browse the repository at this point in the history
In addition to logpush and tail_consumers, patch observability settings
on version deploy. This still doesn't quite match the behavior of
"wrangler deploy", which will disable observability if it is not defined
in wrangler.toml (as of #6776), but at least this is more correct for now.
  • Loading branch information
taylorlee committed Oct 24, 2024
1 parent 924ec18 commit 650dfd7
Show file tree
Hide file tree
Showing 3 changed files with 84 additions and 3 deletions.
7 changes: 7 additions & 0 deletions .changeset/chilled-apes-repeat.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
"wrangler": patch
---

fix: synchronize observability settings during versions deploy

When running `wrangler versions deploy`, wrangler will now update observability settings in addition to logpush and `tail_consumers`. Unlike `wrangler deploy`, it will not disable observability when observability is undefined in wrangler.toml
67 changes: 65 additions & 2 deletions packages/wrangler/src/__tests__/versions/versions.deploy.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -704,17 +704,78 @@ describe("versions deploy", () => {
│ Synced non-versioned settings:
│ logpush: true
│ observability: <skipped>
│ tail_consumers: <skipped>
╰ SUCCESS Deployed test-name version 00000000-0000-0000-0000-000000000000 at 100% (TIMINGS)"
`);
});

test("with observability disabled in wrangler.toml", async () => {
writeWranglerToml({
observability: {
enabled: false,
},
});

expect(normalizeOutput(std.out)).toContain("logpush: true");
const result = runWrangler(
"versions deploy 10000000-0000-0000-0000-000000000000 --yes --experimental-gradual-rollouts"
);

await expect(result).resolves.toBeUndefined();

expect(normalizeOutput(std.out)).toMatchInlineSnapshot(`
"╭ Deploy Worker Versions by splitting traffic between multiple versions
├ Fetching latest deployment
├ Your current deployment has 2 version(s):
│ (10%) 00000000-0000-0000-0000-000000000000
│ Created: TIMESTAMP
│ Tag: -
│ Message: -
│ (90%) 00000000-0000-0000-0000-000000000000
│ Created: TIMESTAMP
│ Tag: -
│ Message: -
├ Fetching deployable versions
├ Which version(s) do you want to deploy?
├ 1 Worker Version(s) selected
├ Worker Version 1: 00000000-0000-0000-0000-000000000000
│ Created: TIMESTAMP
│ Tag: -
│ Message: -
├ What percentage of traffic should Worker Version 1 receive?
├ 100% of traffic
├ Add a deployment message (skipped)
├ Deploying 1 version(s)
├ Syncing non-versioned settings
│ Synced non-versioned settings:
│ logpush: <skipped>
│ observability: enabled: false
│ tail_consumers: <skipped>
╰ SUCCESS Deployed test-name version 00000000-0000-0000-0000-000000000000 at 100% (TIMINGS)"
`);
});

test("with logpush and tail_consumers in wrangler.toml", async () => {
test("with logpush, tail_consumers, and observability in wrangler.toml", async () => {
writeWranglerToml({
logpush: false,
observability: {
enabled: true,
head_sampling_rate: 0.5,
},
tail_consumers: [
{ service: "worker-1" },
{ service: "worker-2", environment: "preview" },
Expand Down Expand Up @@ -766,6 +827,8 @@ describe("versions deploy", () => {
│ Synced non-versioned settings:
│ logpush: false
│ observability: enabled: true
│ head_sampling_rate: 0.5
│ tail_consumers: worker-1
│ worker-2 (preview)
│ worker-3 (staging)
Expand Down
13 changes: 12 additions & 1 deletion packages/wrangler/src/versions/deploy.ts
Original file line number Diff line number Diff line change
Expand Up @@ -558,11 +558,12 @@ async function promptPercentages(
async function maybePatchSettings(
accountId: string,
workerName: string,
config: Pick<Config, "logpush" | "tail_consumers">
config: Pick<Config, "logpush" | "tail_consumers" | "observability">
) {
const maybeUndefinedSettings = {
logpush: config.logpush,
tail_consumers: config.tail_consumers,
observability: config.observability, // TODO reconcile with how regular deploy handles empty state
};
const definedSettings = Object.fromEntries(
Object.entries(maybeUndefinedSettings).filter(
Expand All @@ -587,9 +588,19 @@ async function maybePatchSettings(
},
});

let observability = [];

Check failure on line 591 in packages/wrangler/src/versions/deploy.ts

View workflow job for this annotation

GitHub Actions / Checks

'observability' is never reassigned. Use 'const' instead
if (patchedSettings.observability) {
observability.push(`enabled: ${patchedSettings.observability.enabled}`);
if (patchedSettings.observability.head_sampling_rate) {
observability.push(
`head_sampling_rate: ${patchedSettings.observability.head_sampling_rate}`
);
}
}
const formattedSettings = formatLabelledValues(
{
logpush: String(patchedSettings.logpush ?? "<skipped>"),
observability: observability.join("\n") ?? "<skipped>",
tail_consumers:
patchedSettings.tail_consumers
?.map((tc) =>
Expand Down

0 comments on commit 650dfd7

Please sign in to comment.