-
Notifications
You must be signed in to change notification settings - Fork 5.2k
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
[TypeSpec APIView] Ensure apiview only triggers on packages directly changed by the pr #31871
base: main
Are you sure you want to change the base?
Conversation
Next Steps to MergeNext steps that must be taken to merge this PR:
|
Generated ApiView
|
API change check APIView has identified API level changes in this PR and created following API reviews. |
@@ -17,12 +17,6 @@ model Employee is TrackedResource<EmployeeProperties> { | |||
|
|||
/** Employee properties */ | |||
model EmployeeProperties { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
model EmployeeProperties { | |
model EmployeeProperties { | |
/** Age of employee */ | |
age?: int32; | |
/** City of employee */ | |
city?: string; | |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
temp removal for testing
Do we really want to show entire npm package tree in log? This makes it difficult to read the logs that's more important. |
You can use the log grouping similar to azure-rest-api-specs/eng/scripts/Create-APIView.ps1 Lines 143 to 147 in d7d8b18
which will hide the lengthy logs in a toggle. That way people can still expand to view it if they want to. |
while ($filePathParts.Length -and !$configFilesInTypeSpecProjects) { | ||
$filePathParts = $filePathParts | Select-Object -SkipLast 1 | ||
$typeSpecProjectBaseDirectory = $filePathParts -join [IO.Path]::DirectorySeparatorChar | ||
$configFilesInTypeSpecProjects = Get-ChildItem -Path $typeSpecProjectBaseDirectory -File "tspconfig.yaml" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This will still be an issue. It is possible to have tspconfig.yaml in sub folders for a shared project. Current logic will stop looking further upwards and move to next block to check if current directory has main.tsp. It won't come back and check again the parent path of current file path if there is no main.tsp.
We can simplify this logic that will work for shared projects also.
for each changed files, strip the prefix before `specification/' from path:
- check if current path has tspconfig.yaml and main.tsp.
- If yes, add this folder to project set
- If no, then go upwards and continue step 2 until we match current path to 'specification/[^\/]+/+`
APIView needs to be generated from paths that contain both main.tsp and tspconfig.yaml (at least to retain same behavior as current one.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmm I don't think I understand the exact situation where this might not work.
The code right now is checking all parent directory of the changed file till we reach root.
line 96 $filePathParts = $filePathParts | Select-Object -SkipLast 1
deletes the leaf directory on each iteration
@@ -86,6 +86,32 @@ function Get-ResourceProviderFromReadMePath { | |||
return $null | |||
} | |||
|
|||
function Get-ImpactedTypespecProjects { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this logic truly APIView specific? I would feel better if this was in the common functions and shared as I want to avoid different selecting algorithms for each tool that depends on finding typespec projects.
cc @mikeharder
$filePathParts = $TypeSpecFile.split([IO.Path]::DirectorySeparatorChar) | ||
while ($filePathParts.Length -and !$configFilesInTypeSpecProjects) { | ||
$filePathParts = $filePathParts | Select-Object -SkipLast 1 | ||
$typeSpecProjectBaseDirectory = $filePathParts -join [IO.Path]::DirectorySeparatorChar |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Split-Path makes pulling off the parents pretty simple. Split-Path -Parent
|
||
if ($configFilesInTypeSpecProjects) { | ||
foreach($configFilesInTypeSpecProject in $configFilesInTypeSpecProjects) { | ||
$entryPointFile = Get-ChildItem -Path $($configFilesInTypeSpecProject.Directory.FullName) -File "main.tsp" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why main.tsp? What about client.tsp?
I disabled the TypeSpec APIView pipeline until this is merged. From my testing I think this PR resolves the TypeSpec project discovery bug but giving there are many ongoing discussions here I will let @ckairen finish it up. For now, the legacy TypeSpec APIView is still running and will generate APIView. This pipeline is causing some confusion at the moment. Please enable re-enable https://dev.azure.com/azure-sdk/public/_build?definitionId=7325 when this is merged. |
closes #31870