Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: modify segment event to remove message content #70

Merged

Conversation

varshamenon4
Copy link
Member

COSMO-547

Modify segment event to remove message contents and PII.

Copy link
Member Author

@varshamenon4 varshamenon4 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A quick question.

@@ -46,7 +46,6 @@ export function addChatMessage(role, content, courseId, promptExperimentVariatio
user_id: userId,
timestamp: message.timestamp,
role: message.role,
content: message.content,
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pretty straightforward and easy change, but I'm not sure how to test Segment locally? Is this possible? Do I need to merge/deploy to stage and test there?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think there are two things to test.

  • That we no longer call sendTrackEvent with the content key in the event.
    • I think that this can be accomplished in testing or local development.
  • That the content key in the event does not appear in Segment events.
    • I think that this can be accomplished in stage or production.

Testing
One thing I think we should consider is adding a test suite thunks.test.js to test this thunk. As part of that test, we could mock out the sendTrackEvent function and verify that it's not called with content. I don't think you'd need to test the entire thunk, since it predates this change. That's one way to verify that your change worked at a unit test level. Here is an existing example.

In terms of testing this additionally, I think we have some options, and it depends on what you want to test.

Local Development
This would be another form of asserting 1 above.

By default, when you call initialize in the Learning MFE to initialize the app, it'll set up the SegmentAnalyticsService here.

I'm actually not sure how that class functions locally, but I would expect that the call to sendTrackEvent will return early here when running the Learning MFE locally, so the execution of sendTrackEvent wouldn't even get far enough to validate the contents of the event. But it may be worth throwing a breakpoint in to see if it does get to sendTrackEvent.

If not, we could consider overriding the analytics service via the Javascript configuration using the analyticsService key. The Javascript configuration file can be defined locally; see frontend-plugin-advertisements for an example. Here is an example of us overriding the logging utility in stage. My approach would be to copy the MockAnalyticsService class and replace the calls to Jest with console.log statements or debugger statements.

That said, this won't tell you anything about the Segment side of things, because that's not being called locally. It would pretty much just give you the same benefit as the testing - that is, asserting sendTrackEvent was called without content - without needing to write tests. But I think the test would probably be more valuable.

For asserting 2 above, we can test in stage and/or production.

Stage

We do seem to have a SEGMENT_KEY set up in the stage Learning MFE. However, I'm not sure where those events go and whether we can look at them. I'll ask around!

Production
Events sent to Segment in production can be viewed in Snowflake for verification. As you said, this is a very straightforward change, so I think the risk associated with letting this go to production without validation in stage is very low. But it's not zero. If you'd feel more comfortable verifying in stage first, let's see if we can check the stage Segment events somehow.

My recommendation would be throw in a quick Jest test for the call to sendTrackEvent from this thunk and to validate in stage. If it's not possible to validate in stage, I would be comfortable with testing in production, but I'd like other's opinions as well.

I hope this was helpful. Let me know what you think!

@varshamenon4 varshamenon4 changed the title feat: modify segment event tor remove message content feat: modify segment event to remove message content Dec 10, 2024
@varshamenon4 varshamenon4 force-pushed the varshamenon4/feat-modify-segment-event-message-data branch 2 times, most recently from 15e4565 to 9876817 Compare December 13, 2024 15:35
}));

const mockState = {
learningAssistant: { messageList: [] },
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: You could add a conversationId so that the id attribute on the properties object does not have to be undefined, but it's not a big deal.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good call, will do!

Copy link
Member

@MichaelRoytman MichaelRoytman left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for adding that test - looks good to me!

@varshamenon4 varshamenon4 force-pushed the varshamenon4/feat-modify-segment-event-message-data branch from 3f91f14 to 1c33a42 Compare December 13, 2024 17:21
@varshamenon4 varshamenon4 merged commit 56d4bbf into main Dec 13, 2024
4 checks passed
@varshamenon4 varshamenon4 deleted the varshamenon4/feat-modify-segment-event-message-data branch December 13, 2024 17:26
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants