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

telemetry: Metrics for amazonq unit test generation #905

Closed
wants to merge 14 commits into from
273 changes: 273 additions & 0 deletions telemetry/definitions/commonDefinitions.json
Original file line number Diff line number Diff line change
Expand Up @@ -178,6 +178,16 @@
"type": "int",
"description": "The amount of time required for the build to complete (in seconds)."
},
{
"name": "buildStatus",
"type": "string",
"allowedValues": [
"SUCCESS",
"FAILED",
"CANCELLED"
],
"description": "The amount of time required for the build to complete (in seconds)."
},
{
"name": "buildSystemVersion",
"type": "string",
Expand All @@ -199,6 +209,16 @@
"type": "boolean",
"description": "Boolean value of whether or not a Cfn parameter file is provided."
},
{
"name": "charsOfCodeAccepted",
"type": "int",
"description": "Number of characters of code accepted"
},
{
"name": "charsOfCodeGenerated",
"type": "int",
"description": "Number of characters of code generated"
},
{
"name": "checkType",
"type": "string",
Expand Down Expand Up @@ -1417,6 +1437,26 @@
"type": "string",
"description": "Language used for the project."
},
{
"name": "latencyOfClientSideBuild",
"type": "int",
"description": "Time from start to end of Client-side build."
},
{
"name": "latencyOfGeneratingTests",
"type": "int",
"description": "Time from start to end of Generating unit tests"
},
{
"name": "linesOfCodeAccepted",
"type": "int",
"description": "Number of lines of code accepted"
},
{
"name": "linesOfCodeGenerated",
Copy link
Contributor

Choose a reason for hiding this comment

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

do you really need to track chars and lines? how is that the existing codewhisperer metrics don't already have fields for this?

Suggested change
"name": "linesOfCodeAccepted",
"type": "int",
"description": "Number of lines of code accepted"
},
{
"name": "linesOfCodeGenerated",
"name": "acceptedLinesCount",
"type": "int",
"description": "Number of lines of code accepted"
},
{
"name": "generatedLinesCount",

Copy link
Contributor Author

Choose a reason for hiding this comment

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

They are using cwsprChatAcceptedNumberOfLines which is specific name not generic but trying to use the same.

"type": "int",
"description": "Number of lines of code generated"
},
{
"name": "loadFileTime",
"type": "int",
Expand Down Expand Up @@ -1457,6 +1497,31 @@
"type": "int",
"description": "Number of generations before the user accepted or rejected"
},
{
"name": "numberOfBuildExecuted",
"type": "int",
"description": "Number of build executed in unit test generation build loop"
},
{
"name": "numberOfBuildFailed",
"type": "int",
"description": "Number of build failures in unit test generation build loop"
},
{
"name": "numberOfBuildPassed",
"type": "int",
"description": "Number of build succeeded in unit test generation build loop"
},
Copy link
Contributor

Choose a reason for hiding this comment

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

there are already some generic "successCount" and similar fields. use those. if you need to add a executedCount or something like that, that is preferred.

do not add over-specific fields for every metric.

{
"name": "numberOfUnitTestCasesAccepted",
"type": "int",
"description": "Number of unit test cases accepted"
},
{
"name": "numberOfUnitTestCasesGenerated",
"type": "int",
Copy link
Contributor

Choose a reason for hiding this comment

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

use or create generic fooCount metrics.

please always do this in the future. I have mentiond this in previous reviews.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Named these two fields to commonacceptedCount and generatedCount.

"description": "Number of unit test cases generated"
},
{
"name": "oldVersion",
"type": "string",
Expand Down Expand Up @@ -1670,11 +1735,21 @@
"type": "string",
"description": "Date/time that an SSO client registration expires."
},
{
"name": "step",
"type": "string",
"description": "Indicates the stage at which a user interface click action was performed."
},
{
"name": "successCount",
"type": "int",
"description": "The number of successful operations"
},
{
"name": "supportedLanguage",
"type": "boolean",
"description": "supported language"
},
Copy link
Contributor

@justinmk3 justinmk3 Nov 11, 2024

Choose a reason for hiding this comment

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

there are multiple such fields already. do not add redundant fields.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I didn't see a field which checks the supported language(boolean).
LMK If I am missing something.

Choose a reason for hiding this comment

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

This field should be isSupportedLanguage to indicate it is boolean field. SupportedLanguage seems like we are going to pass the actual value of language which could be string/enum type.

Also the comment should be "Indicate if the language is supported"

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I did not see convention naming isXXXX for boolean values in the json file so for keeping consistent went with supportedLanguage
Let me change this accordingly

{
"name": "syncedResources",
"type": "string",
Expand All @@ -1694,6 +1769,16 @@
"type": "string",
"description": "Generic name of a template"
},
{
"name": "testGenerationJobGroupName",
"type": "string",
"description": "Unit test generation job group name"
},
{
"name": "testGenerationJobId",
Copy link
Contributor

Choose a reason for hiding this comment

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

a group name and job id could be used in many metrics. please do not add hyper-specific fields for every metric.

I already see fields like codeTransformJobId, and that's another case where we're paying the price for those fields being over-specific.

Suggested change
"name": "testGenerationJobGroupName",
"type": "string",
"description": "Unit test generation job group name"
},
{
"name": "testGenerationJobId",
"name": "jobGroup",
"type": "string",
"description": "Job group name associated with the metric"
},
{
"name": "jobId",

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Will update with this

"type": "string",
"description": "Unit test generation job id"
},
{
"name": "toolId",
"type": "string",
Expand All @@ -1717,6 +1802,16 @@
"type": "string",
"description": "Unique identifier for the trace (a set of events) this metric belongs to"
},
{
"name": "unitTestGenerationBuildPayloadBytes",
"type": "int",
"description": "The uncompressed payload size in bytes of the source files in customer project context sent for unit test generation"
},
{
"name": "unitTestGenerationBuildZipFileBytes",
"type": "int",
"description": "The compressed payload size of source files in bytes of customer project context sent for unit test generation"
},
{
"name": "update",
"type": "boolean",
Expand All @@ -1732,6 +1827,11 @@
"type": "string",
"description": "User selection from a predefined menu (not user-provided input). See also `action`."
},
{
"name": "userEnteredPromptMessage",
"type": "boolean",
"description": "True if user enter prompt message as input else false"
},
{
"name": "userId",
"type": "string",
Expand Down Expand Up @@ -2214,6 +2314,175 @@
}
]
},
{
"name": "amazonq_unitTestGeneration",
"description": "Client side metrics of AmazonQ Unit Test Generation",
"metadata": [
{
"type": "charsOfCodeAccepted",
"required": false
},
{
"type": "charsOfCodeGenerated",
"required": false
},
{
"type": "credentialStartUrl",
"required": false
},
{
"type": "cwsprChatProgrammingLanguage"
},
{
"type": "linesOfCodeAccepted",
"required": false
},
{
"type": "linesOfCodeGenerated",
"required": false
},
{
"type": "numberOfBuildExecuted",
"required": false
},
{
"type": "numberOfBuildFailed",
"required": false
},
{
"type": "numberOfBuildPassed",
"required": false
},
{
"type": "numberOfUnitTestCasesAccepted",
"required": false
},
{
"type": "numberOfUnitTestCasesGenerated",
"required": false
},
{
"type": "supportedLanguage"
},
{
"type": "testGenerationJobGroupName",
"required": false
},
{
"type": "userEnteredPromptMessage"
}
]
},
{
"name": "amazonq_utg_buildLoop",
"description": "Client side invocation of the AmazonQ Unit Test Generation build loop",
"metadata": [
{
"type": "buildStatus",
"required": false
},
{
"type": "credentialStartUrl",
"required": false
},
{
"type": "cwsprChatProgrammingLanguage"
},
{
"type": "latencyOfClientSideBuild",
"required": false
},
{
"type": "source",
"required": false
},
{
"type": "supportedLanguage"
},
{
"type": "testGenerationJobGroupName",
"required": false
},
{
"type": "testGenerationJobId",
"required": false
},
{
"type": "userEnteredPromptMessage"
}
]
},
{
"name": "amazonq_utg_generateTests",
"description": "Client side invocation of the AmazonQ Unit Test Generation",
"metadata": [
{
"type": "artifactsUploadDuration",
"required": false
},
{
"type": "charsOfCodeAccepted",
"required": false
},
{
"type": "charsOfCodeGenerated",
"required": false
},
{
"type": "credentialStartUrl",
"required": false
},
{
"type": "cwsprChatProgrammingLanguage"
},
{
"type": "latencyOfGeneratingTests",
"required": false
},
{
"type": "linesOfCodeAccepted",
"required": false
},
{
"type": "linesOfCodeGenerated",
"required": false
},
{
"type": "numberOfUnitTestCasesAccepted",
"required": false
},
{
"type": "numberOfUnitTestCasesGenerated",
"required": false
},
{
"type": "source",
"required": false
},
{
"type": "supportedLanguage"
},
{
"type": "testGenerationJobGroupName",
"required": false
},
{
"type": "testGenerationJobId",
"required": false
},
{
"type": "unitTestGenerationBuildPayloadBytes",
"required": false
},
{
"type": "unitTestGenerationBuildZipFileBytes",
"required": false
},
{
"type": "userEnteredPromptMessage"
}
]
},
{
"name": "amazonq_viewChatPanel",
"description": "Captures if Q chat panel is successfully viewed or not",
Expand Down Expand Up @@ -6997,6 +7266,10 @@
"metadata": [
{
"type": "elementId"
},
{
"type": "step",
"required": false
}
]
},
Expand Down