Skip to main content

Notifications

Dynamics 365 Community / Blogs / Dreaming in CRM / Handling Azure AD MFA promp...

Handling Azure AD MFA prompt in Playwright

Last month, I was working on the problem of handling MFA code prompt with Playwright and finally figured out an approach to tackle the problem. I did not blog about it though. But I did share a small video about how it works on Twitter. I then saw Marcus‘s post today on how to handle AD authentication in Playwright, and thought that I should definitely blog about this now.

The key pieces in the sample are:

  1. Azure Identity library for getting the user name while you are running it from your local machine, or from variable if running using GitHub Actions
  2. Filling MFA code using otpauth npm package

If you just want to have a look at the code before reading the post, you can head over to https://github.com/rajyraman/playwright-azure-ad-mfa

Approach:

If you already have Microsoft Authenticator with prompt setup, the first step is to ensure that you will use code and not prompt. Head over to https://mysignins.microsoft.com/security-info and add a new sign in method for Authenticator app. Use the account that you will use in Playwright.

Add a signin method screenshot

Now click on the link that says that you would like to use a different authenticator app.

Screenshot: Choose different authenticator app

Rather than scan the QR code click on the button to get the secret code.

Screenshot: Choose secret code for MFA

Now copy the secret code to your clipboard. You would need this for generating the MFA code.

Screenshot: Copying MFA secret

The last step is to choose “App based authentication or hardware token – code” as default MFA auth method and click the Confirm button.

Screenshot: Choose default method for MFA

Once you do this you can add this code along with the account password on the local env file. Since this is a PoC, and I really only want to demonstrate the MFA + Playwright capability, I am storing this in plaintext locally. You would want to store both the TOTP secret and password securely and retrieve them on demand in a production environment. Below is how my I have setup my .env file.

Screenshot: .env file

Playwright can also be run via GitHub Actions and so in this case I have securely stored the password and TOTP secret in the repo.

Screenshot: GitHub secret

Since I am not too bothered by the URL and Username being shown in the action output I have stored these as variables.

Screenshot: GitHub variable

I refer these inside the workflow itself and surface these as environment variables.

Screenshot: GitHub workflow file with environment variables

This setup allows me to run the test in GitHub Actions also. The runner logs in with username, password and MFA code and runs the test.

Screenshot: GitHub action run

Hope this helps with testing Power Apps or any app that is behind Azure AD.

Sample Repo: https://github.com/rajyraman/playwright-azure-ad-mfa

References:

  1. globalSetup – Playwright Docs
  2. fixtures – Playwright Docs
  3. Checkly YouTube video on fixtures
  4. Playwright Discord

Comments

*This post is locked for comments