From deeaf506cdbac5e25a994e6b68e9339780324912 Mon Sep 17 00:00:00 2001 From: Yury Semikhatsky Date: Wed, 9 Aug 2023 12:05:12 -0700 Subject: [PATCH] cherry-pick(#26382): docs(merge): use azcopy for uploads --- docs/src/test-sharding-js.md | 20 ++++++++++++++++++-- 1 file changed, 18 insertions(+), 2 deletions(-) diff --git a/docs/src/test-sharding-js.md b/docs/src/test-sharding-js.md index 66081d0673331..fbc9ea9ab33a4 100644 --- a/docs/src/test-sharding-js.md +++ b/docs/src/test-sharding-js.md @@ -126,7 +126,18 @@ We can utilize Azure Storage's static websites hosting capabilities to easily an 1. Create an [Azure Storage account](https://learn.microsoft.com/en-us/azure/storage/common/storage-account-create). 1. Enable [Static website hosting](https://learn.microsoft.com/en-us/azure/storage/blobs/storage-blob-static-website-how-to#enable-static-website-hosting) for the storage account. -1. Add the Azure connection string as a [GitHub Actions secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) called `AZURE_CONNECTION_STRING`. +1. Create a Service Principal in Azure and grant it access to Azure Blob storage. Upon successful execution, the command will display the credentials which will be used in the next step. + + ```bash + az ad sp create-for-rbac --name "github-actions" --role "Storage Blob Data Contributor" --scopes /subscriptions//resourceGroups//providers/Microsoft.Storage/storageAccounts/ + ``` +1. Use the credentials from the previous step to set up encrypted secrets in your GitHub repository. Go to your repository's settings, under [GitHub Actions secrets](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository), and add the following secrets: + + - `AZCOPY_SPA_APPLICATION_ID` + - `AZCOPY_SPA_CLIENT_SECRET` + - `AZCOPY_TENANT_ID` + + For a detailed guide on how to authorize a service principal using a client secret, refer to [this Microsoft documentation](https://learn.microsoft.com/en-us/azure/storage/common/storage-use-azcopy-authorize-azure-active-directory#authorize-a-service-principal-by-using-a-client-secret-1). 1. Add a step that uploads HTML report to Azure Storage. ```yaml @@ -135,7 +146,12 @@ We can utilize Azure Storage's static websites hosting capabilities to easily an shell: bash run: | REPORT_DIR='run-${{ github.run_id }}-${{ github.run_attempt }}' - az storage blob upload-batch -s playwright-report -d "\$web/$REPORT_DIR" --connection-string "${{ secrets.AZURE_CONNECTION_STRING }}" + azcopy cp --recursive "./playwright-report/*" "https://.blob.core.windows.net/\$web/$REPORT_DIR" + env: + AZCOPY_AUTO_LOGIN_TYPE: SPN + AZCOPY_SPA_APPLICATION_ID: '${{ secrets.AZCOPY_SPA_APPLICATION_ID }}' + AZCOPY_SPA_CLIENT_SECRET: '${{ secrets.AZCOPY_SPA_CLIENT_SECRET }}' + AZCOPY_TENANT_ID: '${{ secrets.AZCOPY_TENANT_ID }}' ``` The contents of `$web` storage container can be accessed from a browser by using the [public URL](https://learn.microsoft.com/en-us/azure/storage/blobs/storage-blob-static-website-how-to?tabs=azure-portal#portal-find-url) of the website.