Skip to content

Commit 1a7003d

Browse files
feat(notifications): notify users of their own actions by default
Users requested notifications for their own actions as a personal record/reminder in their inbox. This changes the default behavior of createNotification to include the actor in the recipient list. Changes: - notifications.ts: Set includeActor default to true - issues.ts: Remove redundant includeActor: true flags (now default) - issues.test.ts: Remove includeActor from test expectations - Integration tests: Add explicit includeActor: false to tests that specifically test actor exclusion or recipient preference behavior - database-queries.test.ts: Fix invalid UUID that was using "some-other-user-id" instead of a valid UUID format Fixes #849 Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
1 parent fd836ae commit 1a7003d

File tree

5 files changed

+6
-7
lines changed

5 files changed

+6
-7
lines changed

src/lib/notifications.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -44,7 +44,7 @@ export async function createNotification(
4444
resourceId,
4545
resourceType,
4646
actorId,
47-
includeActor,
47+
includeActor = true,
4848
issueTitle,
4949
machineName,
5050
formattedIssueId,

src/services/issues.test.ts

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -104,7 +104,6 @@ describe("Issue Service", () => {
104104
resourceId: issueId,
105105
resourceType: "issue",
106106
actorId,
107-
includeActor: true,
108107
issueTitle: "Test Issue",
109108
machineName: "Test Machine",
110109
formattedIssueId: "MM-01",
@@ -144,7 +143,6 @@ describe("Issue Service", () => {
144143
resourceId: "issue-new",
145144
resourceType: "issue",
146145
actorId: "user-1",
147-
includeActor: true,
148146
issueTitle: "New Issue",
149147
machineName: "Test Machine",
150148
formattedIssueId: "MM-01",

src/services/issues.ts

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -196,7 +196,6 @@ export async function createIssue({
196196
resourceId: issue.id,
197197
resourceType: "issue",
198198
...(reportedBy ? { actorId: reportedBy } : {}),
199-
includeActor: true,
200199
issueTitle: title,
201200
machineName: updatedMachine.name,
202201
formattedIssueId: formatIssueId(machineInitials, issueNumber),
@@ -282,7 +281,6 @@ export async function updateIssueStatus({
282281
resourceId: issueId,
283282
resourceType: "issue",
284283
actorId: userId,
285-
includeActor: true,
286284
issueTitle: currentIssue.title,
287285
machineName: currentIssue.machine.name,
288286
formattedIssueId: formatIssueId(
@@ -506,7 +504,6 @@ export async function assignIssue({
506504
resourceId: issueId,
507505
resourceType: "issue",
508506
actorId,
509-
includeActor: true,
510507
issueTitle: currentIssue.title,
511508
machineName: currentIssue.machine.name,
512509
formattedIssueId: formatIssueId(

src/test/integration/database-queries.test.ts

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -277,7 +277,8 @@ describe("Database Queries (PGlite)", () => {
277277
type: "new_issue",
278278
resourceId: issue.id,
279279
resourceType: "issue",
280-
actorId: "some-other-user-id", // Actor is someone else
280+
actorId: "00000000-0000-0000-0000-000000000002", // Actor is someone else
281+
includeActor: false, // Exclude actor to test global watch behavior
281282
issueTitle: "Test Issue",
282283
machineName: "Test Machine",
283284
issueContext: {

src/test/integration/notifications.test.ts

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -66,6 +66,7 @@ describe("createNotification (Integration)", () => {
6666
resourceId: issue.id,
6767
resourceType: "issue",
6868
actorId: actor.id,
69+
includeActor: false, // Explicitly test actor exclusion
6970
commentContent: "Test comment",
7071
},
7172
db
@@ -127,6 +128,7 @@ describe("createNotification (Integration)", () => {
127128
resourceId: issue.id,
128129
resourceType: "issue",
129130
actorId: actor.id,
131+
includeActor: false, // Exclude actor to test recipient preferences
130132
commentContent: "Test comment",
131133
},
132134
db
@@ -186,6 +188,7 @@ describe("createNotification (Integration)", () => {
186188
resourceId: issue.id,
187189
resourceType: "issue",
188190
actorId: actor.id,
191+
includeActor: false, // Exclude actor to test recipient granular toggles
189192
commentContent: "Test comment",
190193
},
191194
db

0 commit comments

Comments
 (0)