Skip to content

Commit

Permalink
Fix idempotency test results upload
Browse files Browse the repository at this point in the history
  • Loading branch information
andreaTP committed Sep 21, 2023
1 parent 13a3fa0 commit 7458534
Show file tree
Hide file tree
Showing 4 changed files with 126 additions and 67 deletions.
114 changes: 114 additions & 0 deletions .github/workflows/idempotency-tests.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
name: idempotency-tests

on:
workflow_dispatch:
push:
branches: [main]
paths-ignore:
[
"abstractions/**",
"authentication/**",
"serialization/**",
"http/**",
"**.md",
".vscode/**",
"**.svg",
]
pull_request:
paths-ignore:
[
"abstractions/**",
"authentication/**",
"serialization/**",
"http/**",
"**.md",
".vscode/**",
"**.svg",
]

concurrency:
# Only run once for latest commit per ref and cancel other (previous) runs.
group: ci-idempotency-tests-${{ github.ref }}
cancel-in-progress: true

jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Setup .NET
uses: actions/setup-dotnet@v3
with:
dotnet-version: 7.0.x
- name: Restore dependencies
run: dotnet restore kiota.sln
- name: Build
run: dotnet publish ./src/kiota/kiota.csproj -c Release -p:PublishSingleFile=true -p:PublishReadyToRun=true -o ./publish
# -p:PublishTrimmed=true -p:PublishAot=true should be enabled to make test run faster, but there are still limitations
- uses: actions/upload-artifact@v3
with:
name: generator
path: publish
idempotency:
runs-on: ubuntu-latest
needs: build
strategy:
fail-fast: false
matrix:
language:
- java
- csharp
- go
- typescript
- ruby
- php
- python
description:
- "./tests/Kiota.Builder.IntegrationTests/InheritingErrors.yaml"
- "./tests/Kiota.Builder.IntegrationTests/NoUnderscoresInModel.yaml"
- "oas::petstore"
- "apisguru::twitter.com:current"
- "apisguru::notion.com"
- "apisguru::stripe.com"
- "https://raw.githubusercontent.com/googlemaps/openapi-specification/main/dist/google-maps-platform-openapi3.yml"
- "apisguru::meraki.com"
- "https://developers.pipedrive.com/docs/api/v1/openapi.yaml"
- "apisguru::twilio.com:api"
- "apisguru::docusign.net"
steps:
- uses: actions/checkout@v4
- uses: actions/download-artifact@v3
with:
name: generator
path: publish
- run: chmod a+x ./publish/kiota
- name: Check if test is suppressed
id: check-suppressed
run: |
$isSuppressed = . ./it/get-is-suppressed.ps1 -descriptionUrl ${{ matrix.description }} -language ${{ matrix.language }} -kind idempotency
Write-Output "IS_SUPPRESSED=$($isSuppressed.ToString().ToLowerInvariant())" >> $Env:GITHUB_OUTPUT
shell: pwsh
- name: Verify idempotency
shell: pwsh
run: ./it/compare-generation.ps1 -descriptionUrl ${{ matrix.description }} -language ${{ matrix.language }}
continue-on-error: ${{ steps.check-suppressed.outputs.IS_SUPPRESSED == 'true' }}
- id: replace_url
if: always()
run: |
ORIGINAL="${{ matrix.description }}"
REPLACED="${ORIGINAL//[-:<>|\*\?\\\/\.]/_}"
echo "ARTKEY=$REPLACED" >> $GITHUB_OUTPUT
- uses: actions/upload-artifact@v3
if: always()
with:
name: idempotency-${{ matrix.language }}-${{ steps.replace_url.outputs.ARTKEY }}
path: idempotency-results/*.zip

cleanup:
runs-on: ubuntu-latest
needs: idempotency
steps:
- uses: jimschubert/delete-artifacts-action@v1
with:
artifact_name: "generator"
min_bytes: "0"
57 changes: 1 addition & 56 deletions .github/workflows/integration-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -154,64 +154,9 @@ jobs:
name: generation-results-${{ matrix.language }}-${{ steps.replace_url.outputs.ARTKEY }}
path: it/${{ matrix.language }}.zip

idempotency:
runs-on: ubuntu-latest
needs: build
strategy:
fail-fast: false
matrix:
language:
- java
- csharp
- go
- typescript
- ruby
- php
- python
description:
- "./tests/Kiota.Builder.IntegrationTests/InheritingErrors.yaml"
- "./tests/Kiota.Builder.IntegrationTests/NoUnderscoresInModel.yaml"
- "oas::petstore"
- "apisguru::twitter.com:current"
- "apisguru::notion.com"
- "apisguru::stripe.com"
- "https://raw.githubusercontent.com/googlemaps/openapi-specification/main/dist/google-maps-platform-openapi3.yml"
- "apisguru::meraki.com"
- "https://developers.pipedrive.com/docs/api/v1/openapi.yaml"
- "apisguru::twilio.com:api"
- "apisguru::docusign.net"
steps:
- uses: actions/checkout@v4
- uses: actions/download-artifact@v3
with:
name: generator
path: publish
- run: chmod a+x ./publish/kiota
- name: Check if test is suppressed
id: check-suppressed
run: |
$isSuppressed = . ./it/get-is-suppressed.ps1 -descriptionUrl ${{ matrix.description }} -language ${{ matrix.language }} -kind idempotency
Write-Output "IS_SUPPRESSED=$($isSuppressed.ToString().ToLowerInvariant())" >> $Env:GITHUB_OUTPUT
shell: pwsh
- name: Verify idempotency
shell: pwsh
run: ./it/compare-generation.ps1 -descriptionUrl ${{ matrix.description }} -language ${{ matrix.language }}
continue-on-error: ${{ steps.check-suppressed.outputs.IS_SUPPRESSED == 'true' }}
- id: replace_url
if: always()
run: |
ORIGINAL="${{ matrix.description }}"
REPLACED="${ORIGINAL//[-:<>|\*\?\\\/\.]/_}"
echo "ARTKEY=$REPLACED" >> $GITHUB_OUTPUT
- uses: actions/upload-artifact@v3
if: always()
with:
name: idempotency-${{ matrix.language }}-${{ steps.replace_url.outputs.ARTKEY }}
path: idempotency-folder*.zip

cleanup:
runs-on: ubuntu-latest
needs: [integration, idempotency]
needs: integration
steps:
- uses: jimschubert/delete-artifacts-action@v1
with:
Expand Down
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -449,4 +449,4 @@ reports/
samples/
it/openapi.yaml

idempotency*.zip
idempotency-results/
20 changes: 10 additions & 10 deletions it/compare-generation.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -95,21 +95,21 @@ if ($HashString1 -eq $HashString2) {
Exit 0
}
else {
Write-Error "The content of the folders is NOT identical"
$archivePath1 = Join-Path $rootPath -ChildPath "idempotency-folder1.zip"
$archivePath2 = Join-Path $rootPath -ChildPath "idempotency-folder2.zip"
Write-Host "The content of the folders is NOT identical"
$resultsFolder = Join-Path -Path $rootPath -ChildPath "idempotency-results"
$archivePath1 = Join-Path $resultsFolder -ChildPath "idempotency-folder1.zip"
$archivePath2 = Join-Path $resultsFolder -ChildPath "idempotency-folder2.zip"

if (Test-Path $archivePath1) {
Remove-Item $archivePath1 -Force -Verbose
}
if (Test-Path $archivePath2) {
Remove-Item $archivePath2 -Force -Verbose
if (Test-Path $resultsFolder) {
Remove-Item $resultsFolder -Force -Verbose -Recurse
}
New-Item -ItemType Directory -Path $resultsFolder -Force

if ($dev -eq $false) {
Write-Host "Creating archives at location $archivePath1 and $archivePath2"
Compress-Archive -Path $tmpFolder1 -DestinationPath $archivePath1
Compress-Archive -Path $tmpFolder1 -DestinationPath $archivePath2
Compress-Archive -Path $tmpFolder1 -DestinationPath $archivePath1 -Force
Compress-Archive -Path $tmpFolder2 -DestinationPath $archivePath2 -Force
}
Write-Error "Comparison failed as the generated code is NOT identical"
Exit 1
}

0 comments on commit 7458534

Please sign in to comment.