Skip to content

Latest commit

 

History

History
600 lines (360 loc) · 47.1 KB

top-onboarding.md

File metadata and controls

600 lines (360 loc) · 47.1 KB

Azure portal onboarding using Easy Start

Introduction

Azure portal onboarding process is updated and teams looking to onboard new extensions or updating/removing existing extensions do NOT need to raise pull requests going forward. Azure portal has migrated the extension configuration for all clouds to service tree. Partner teams can now manage the configuration through Easy Start onboarding site.

Overview

  • Azure portal onboarding is now available through EasyStart Onboarding.

  • Azure portal onboarding is self-served using the service tree​ metadata

  • Partners won't be required to update any configuration files in Azure portal repositories.​

  • No need to raise pull requests or cherry-picking changes across different branches for onboarding or updating configuration

  • Partners can onboard to the Azure portal using Easy Start experience that will update the corresponding service tree database.

  • Portal team will pull the configuration from service tree and deploy the configuration to all clouds​ and across all portal and hosting service branches

  • Any manual updates to the Azure portal configuration using pull requests will be discarded or overridden by our automation pipeline.

  • Always update the extension configuration using the recommended tools that update the service tree database in the proper format required by Azure portal onboarding automation process.

  • Any updates to service tree database directly using tools other than recommended could corrupt the configuration and will impact your service availability.

Step by Step Process overview

Onboarding a service or developing a Portal extension has three phases: onboarding, development, and deployment. The process is specified in the following image.

alt-text

Phase 1 - Onboarding

Kickoff Meeting

Already own an extension in Portal

  • If your extension is already onboarded to either Dogfood or Public clouds and need to onboard to other environments/clouds in Portal, you can skip this meeting and go directly to the Onboarding requirements section.

who needs these meetings

  • If you have scenarios that do NOT use ARM RP(Resource Provider)or do NOT belong to Azure or need a customized experiences in Portal, you are recommended to setup a meeting a with the Azure portal onboarding team.

  • If you are planning to host an Internal only service or a 3rd party service or a non-Microsoft owned service, you must schedule a meeting with the onboarding team to get the required approvals and then start onboarding.

  • If you have scenarios that do NOT require a full fledged extension and plan to surface your existing web interface through Azure portal, you can send a meeting invite to Azure portal onboarding team.

There are lots of docs here. We recommend you send mail to [email protected] and request a kickoff meeting. Someone from our team will spend 30 minutes walking through the process at a high level. We can point you in the right direction regarding the latest patterns and practices. We can also answer any questions you have. Finally, we can talk about how the relationship between our teams is managed.

Onboard with related teams

Onboarding to Azure all up is a big task that spans many teams. The doc you are reading will help you onboard to the portal, but there are many other teams you will need to work with to get your entire service up and running. These include, but are not limited to the following teams.

NOTE: Contact information for these teams is available here

  1. Azure Resource Manager Team

    Reach out to this team to onboard your resource provider.

  2. Azure Marketing Team

  3. Support Team

    For integrating with the support system and UX integration.

  4. Azure.com team

    For a presence on the marketing site.

  5. Billing team

    To register meters and other billing related activities.

  6. AAD onboarding

    Reach out to AAD onboarding if the new extension service needs special permissions besides just calling your own resource provider servers. If the extension requires additional built-in support for standard Graph or ARM APIs, submit a partner request at the site located at https://aka.ms/portalfx/uservoice.

  7. Azure fundamentals and compliance

    The Azure Fundamentals are a set of tenets to which each Azure service is expected to adhere. The Azure Fundamentals program is described in the document located at https://aka.ms/azurefundamentals. The document also identifies the stakeholders and contacts for each of the tenets.

  8. Security and privacy reviews

  9. Start the CSS onboarding process with the CSS team at least three months previous to public preview. This process may coincide with the following step. For more information about development phases, see top-extensions-developmentPhases.md.

  10. Nearly 70% of Azure users are from outside of the United States. Therefore, it is important to make Azure a globalized product. There are a few requirements under the "Internationalization" criteria that your extension is required to support. This is the same set of languages that are supported by Azure Portal for GA. For more information about internationalization requirements, see http://aka.ms/AzureGR. For onboarding localization, please reach out to Bruno Lewin and the Internationalization team at Internationalization team.

  11. Decide on a name and URLs for the extension. You may need to contact emailing [email protected] to ensure that the name and URL's are unique.

  12. Schedule a UX feasibility review with the Ibiza team UX contact by emailing [email protected]. Many extensions have been made more successful by setting up early design reviews with the Azure Portal team. Taking the time to review the design gives extension owners an opportunity to understand how they can leverage Azure Portal design patterns, and ensure that the desired outcome is feasible.

While the portal team cannot help directly with all of these factors, see portalfx-extensions-contacts.md for a list of items with which we can assist you.

For less common scenarios, you might need to do a custom deployment. For example, if the extension needs to reach server services using certificate based authentication, then there should be controller code on the server that our hosting service does not support. You should be very sure that a custom hosting solution is the correct solution previous to developing one.

Join DLs and request permissions

Request the following permissions to stay current on product roadmaps, get news on latest features, and receive invites for ibiza related events.

  • PMs and Developer Leads should join the ibizapartners PM group here.

  • Developers should join the ibizapartners DEV group here.

  • Developers should join the appropriate group listed on http://aka.ms/standardaccess to get access to portal telemetry. All groups on this page receive access.

  • Developers should join the Azure Portal Partner Contributors - 19668(19668) group by using this link: https://myaccess.

  • PMs, Developers, and Developer Leads should subscribe to the partner request process by joining the Uservoice group at this link: https://aka.ms/portalfx/uservoice. For more information about the partner request process, see top-extensions-partner-request.md.

  • PMs, Developers, and Developer Leads should join Stackoverflow Forums that are located at https://stackoverflow.microsoft.com to let us know if you have any questions. Remember to tag questions with supported tags that are monitored by the Ibiza team. All supported tags are documented in portalfx-stackoverflow.md.

  • Developers who want to contribute to the test framework should join groups from the site located at http://aka.ms/azuregithub.

Get the SDK, docs, and samples to your developers

The development guide located in the main documentation index has all the right pointers.

Onboarding Requirements

  • All services must be registered in Service Tree and contain a valid service tree id with an IcM team registered for each cloud that the portal extension is onboarding to.

  • Services must decide on the name of the extension before onboarding. Obtain necessary leadership approval for the name that you intend to use to avoid changing the name in future.

  • Service must check with Marketing or CELA if required about the service name

  • Services must have a dedicated IcM service and team for the Portal extension per cloud.

  • Services must onboard to Azure Support and have required PESID. Please reach out to Azure supportability champs.

  • Services must have clearly defined Support Topics created for their Product along with corresponding root cause topics.

  • Service owners are responsible for their Preview and GA level KPIs as defined by Azure Global or Azure portal or Azure compliance teams.

  • A service tree id can be associated with one or more Azure portal extensions. Eg: Azure Portal, IaaS Experiences, AAD, Intune

  • Third Party services must have a VP/Partner level sponsor at Microsoft and must always be onboarded with the help of Azure portal team's guidance

  • Partners must hide assets in the environments that they do not want to show the portal extension specific assets.

  • Portal deployment SLAs may change based on the leadership guidance or other company events like //build, //ignite or other conferences

  • Partners must update their SDK version every 60-120-days failing which the extension may not work as expected and cause live site incidents.

  • Partners must acknowledge and resolve IcM alerts fired for extensions to avoid escalations.

  • SDK age alerts or other extension related service health alerts must be resolved with high priority

  • Orphaned services or extensions must be removed from Portal using the deprecation option.

  • Partners must create storage accounts for each of the environments in the respective clouds and subscriptions. Dogfood and Public environments can use storage accounts from Public subscriptions

  • Partners are responsible for any delays in onboarding to any cloud as portal automation deploys the changes from service tree as provided for a given extension.

  • Insufficient data in the extension configuration could affect the extension availability and performance.

  • Service tree entries must not be removed or cleared without informing the Azure portal team if you own an active extension in Azure portal.

Required and Optional fields

Please review the following required and optional fields for Portal extension.

Field Name Description Required Sample
Extension Name Name of the extension True Microsoft_Azure_DemoExtension
Hosting Service Name Name of the extension True demoextension
Feedback Email Email enabled security group consisting of PMs and Developers of the extension True [email protected]
Icm Team Id Team Id of the IcM for the given cloud True 12345 (numeric values only)
Storage Container URL URL of the storage container in the given cloud with Anonymous read access True https://demostorage.core.windows.net/containername
Redirect To Required only if you intend to redirect the new extension to an existing one owned by your team False Microsoft_Azure_OldDemoExtension
1st Party AAD App ID This should be a 1st party AAD App owned by your team False demoextension
Flags Pre-defined flags as listed False SupportsPrewarming, Disabled, ThirdPartyExtension
Flights Name of the flight False MpacFlight

Unsupported scenarios and fields

Step By Step guide to Portal onboarding

Example: https://eng.ms/tools/a0a46d95-77ef-4cb4-a6d8-6aa5a288c1db for Azure portal

  • Alternatively you can visit Onboarding Dashboard.

  • If you do not have access to this dashboard, please request access from Power Bi after clicking the link

  • You can also join ibizapartners-pm or ibizapartners-dev as appropriate.

  • Search your service from the list either by service tree name or service tree id or service tree admin.

  • Click on the link against your service under the "Easy Start Onboarding"

Service Tree List

  • For onboarding a new extension, please click "Onboard a new extension" under Azure portal Extensions card

    1. Validate the Service Tree Id
    2. Validate the IcM Team Name, Cloud are valid for the type of onboarding.
    3. Make sure the user is part of the admins group as listed in

Service Tree List

Onboading Wizard

Extension Name

  • Enter a unique Extension Name as per naming convention "Microsoft_Azure_ExtensionName".
  • Please check with Marketing team or your leadership team before deciding a name and onboard to Azure portal.​
  • Extension Name cannot be renamed.
  • Extension Name must be common across all clouds
  • Extension Name is shown in the URL and get stamped in user settings when accessing specific resource types.

Screenshot - 1 Service Tree List

Screenshot - 2 Service Tree List

Hosting Service Name

  • Must be unique across all extensions.

  • Used in the extension's csproj file as HostingServiceRoutePrefix. More Info.

Feedback Email Address

  • Please enter a valid email enabled security group with the list of PMs and Developers responsible for handling any issues with this extension.

  • User adding/udpating the extension configuration must be part of the feedback email group.

IcM Team Id (numeric values only)

  • Please enter a valid IcM Team Id(numeric values only) of the registered IcM service and team for this extension.

  • IcM Team Id must be cloud specific and must have assignable property set to true.

  • You may use the same Id for Dogfood and Production extensions.

  • Sovereign clouds must have their own valid IcM Team Id

  • IcM service and team must be registered in the same service tree id as the extension or its service group.

  • You can lookup Team Id in active IcM services report available at https://aka.ms/portalfx/partners/icm under the "All Active IcM Teams"

Note: IcM Team Ids are shown in Easy Start. Please click on the entries under Tenant Name on the IcM Tile.

Service Tree List

Storage Container URL

  • Please enter a valid storage container URL.

  • Dogfood and Production extensions can create storage accounts in public cloud subscription.

  • Sovereign clouds must always use respective cloud storage account from the corresponding cloud subscription. Eg: Fairfax storage account must be created in Fairfax subscription.

  • Create separate storage account for each environment eg: Dogfood, Prod, Mooncake, Fairfax and BlackForest

  • Create a container under the storage account with anonymous read access.

  • Upload the config.json and the generated zip file from your build. storage container

Redirect To

  • This is applicable only if you already have an extension registered in your service that you would like to redirect to.

  • Since Azure portal does not allow renaming of extensions, our recommendation is to create a new extension and redirect to old one using this option.

  • Extensions are NOT required to create a storage account to redirect extension or specify one if you intend to redirect to an existing extension. Extensions must specify the hosting service name that is used by the previous extension.

1st party AAD App Id

  • All extensions must register a 1st party AAD app if you are calling graph or other backend services.

  • Extensions do NOT need 1st party AAD app if you only call ARM

  • Do NOT use multiple 1st party AAD apps in one extension.

  • Extensions may use one AAD app across multiple extensions.

Flags

  • All new extension onboarding must use "SupportsPrewarming".

  • Do NOT use "Disabled" unless you have are a custom domain partner and require hiding your extension.

  • "ThirdPartyExtension" must be used if the service is non-Microsoft. Not using the ThirdPartyExtension for non-Microsoft services is considered as security and privacy violation and could potentially leak user data.

  • Any services calling services outside of Microsoft and NOT using ThirdPartyExtension flag will be removed from Azure portal.

Flights

  • Flights are named versions that can be loaded in MPAC. See more

  • You can add a flighted version to the config.json in your extension package and specify that name in this field.

Frequently Asked Questions

  • I am unable to update my existing extension as the next button is disabled. What am I doing wrong?

    • New onboarding process requires all extensions to be onboarded to be onboarded to Dogfood configuration prior to onboarding to Production or National clouds.

    • Missing Dogfood configuration may cause extensions not to show "Next" button

    • Check the IcM Team Id which must be a valid IcM team for your service. See above requirements for IcM Team Id.

    • You can fill in the values for dogfood configuration as per your existing production configuration in this section and continue to next screen.

    • You are recommended to use a different storage account for the dogfood environment.

    • You can disable your dogfood extension if you do not intend to use this.

  • I do NOT plan to onboard to Sovereign clouds immediately. Can I skip them?

    • All services that are in scope for National/Sovereign clouds are required to onboard to the respective clouds as per the guidelines provided by Azure Global team.

    • Please reach out to Azure Global team to check for the timelines and requirements on onboarding to National/Sovereign clouds.

  • Where can I find IcM Team Id?

How to verify onboarding status

Service Tree List

  • Easy Start shows the onboarding status for each extension that is onboarded.

    • In-Progress - Indicates the extension is onboarded only to Dogfood configuration.

    • Onboarded - Indicates the extension is onboarded to Production.

    • Deprecated - Indicates the extension is deprecated from all clouds.

Note : Deprecated extension configuration will not be written to Azure portal configuration. However this information continues to exist in Service tree database for governance reasons and partners can choose to revert if needed

  • Portal onboarding service checks every hour for any updates to the services tree database and reads the extension metadata from service tree database and updates the portal extension configuration files (Extension.*.json) in Azure portal framework repository for all branches Service Tree List

  • You can verify the commits written to the Portal Framework repositories in the Dev, Dogfood and Production branches and Hosting Service changes in Dev, Dogfood and Production branches.

  • You can also visit Onboarding Status to view the onboarding status in Portal configuration files.

  • Search or select your extension and check the details.

  • All extensions onboarded through service tree will be listed in this report. Any manual updates to the Portal configuration will NOT be included in this report and will be overridden by new onboarding automation.

  • Report will be refreshed every few hours. Service Tree List

How to verify deployment status

Ownership-transfer Requirements

  • Transferring ownership of a service or extension in Azure portal requires creating a task to Azure portal and working with Azure portal onboarding team to complete the task.

  • Partners must update SDK to the latest supported version before ownership transfer

  • Partners must update the IcM service and team if ownership is transferred along with the feedback email address of the new owners

Off-boarding / Deprecation of service

  • Deprecation or retiring experience of any service that is in GA requires 90 days notice to customers and services in Public Preview require 30days notice to customers.

  • Service owners can set the Flags to "Disabled" to turn of the extension rendering in Azure portal. Any bookmarks or deep-links will continue to work until the extension is fully deprecated.

AAD Onboarding

NOTE: ARM tokens obtained during portal login are meant only for calling ARM. For all other purposes, please create a 1st party App.

  • Register your 1st party AAD app from First Party Portal

  • Go to Provisioning tab and select unknown in the dropdown for How will you make your application available to customers and in the "Provide more detail" section, add "This app will be used by Azure portal extension to call graph and other backend services".

  • Go to the Owners tab and use an email enabled security group that you and your team are part of domain\securitygroup as the Owners Security Group

  • Use the Subject Name Issuer in the authentication tab as recommended in this document.

  • Add any other required fields as appropriate and submit your application.

  • After the PPE app is approved, you can edit and go to the app's environment section and promote to the Prod branch. Similarly you can promote to other environments if the Prod app is approved.

IMPORTANT NOTE: Partners are responsible for making sure the AAD app has all the required permissions and pre-authorization to access intended resources.

Phase 2 - Development

Develop your extension

The development guide located in the main documentation index has all the right pointers.

Learn about the hosting service / plan your deployment strategy

The Ibiza team provides and operates a common extension hosting service that makes it easy to get your extension into a globally distributed system without having to manage your own infrastructure. For more information see top-extensions-hosting-service.md.

For less common scenarios, you might need to do a custom deployment.

For example, if you need to talk to backend services using certificate-based authentication then you'll need controller code on the server. This is not supported with our hosting service. You should be very sure you require a custom hosting solution before going down this path.

NOTE: The deployment can be configured in such a way that the client portion of the extension uses the hosting service while the custom controller code can be deployed separately. For more information, see top-extensions-custom-deployment.md.

Register the extension with the portal product configuration

Once the name of the extension is finalized, it is time to register the extension in all environments. This requires a portal deployment and can take time. Our Service Level Agreements are located at top-extensions-svc-lvl-agreements.md. Please plan accordingly.

  • For internal partners, the request to register an extension is a pull request, as specified in top-extensions-publishing.md.

  • External teams can submit their requests by reaching out to the ibizafxpm team with an onboarding request.

  • NOTE: Extension names must use standard extension name format, as in the example located here.

  • NOTE: Extension URLs adhere to the naming requirements located in portalfx-extensions-cnames.md.

  • Show your asset types.

Onboarding to out-of-the-box alerts for your extension

In order to ensure that all teams meet quality standard to be included in the Azure Portal, we require teams onboard to our out-of-the box alerting infrastructure. This will not require any deployment on your part, but only submitting a PR with a JSON configuration specifying your thresholds, which you can learn more about in our alerting onboarding documentation

The following alerts are required:

  1. Extension SDK Age (automatically opted-in by default when onboarded to alerting)
  2. Performance
  3. Availability

Onboarding to A/B Testing

Ibiza offers out-of-the-box A/B testing and feature flighting through the ExP Experimentation Platform.

To learn how you can integrate your extension and learn more, visit the Ibiza Experimentation website

Phase 3 - Deployment

Release kind

There are three typical release kinds: private preview, public preview, and Global Availability (GA). For the purposes of deployment public preview and GA are the same. The only difference is that the UI may show preview labels and disclaimers where appropriate. For more information about the three kinds of releases, see top-extensions-developmentPhases.md.

Private preview

For a private preview, the goal is to hide your experience to the general public, but show it to a limited audience. This procedure assumes that the discoverable entry point in the product is the All Services menu, also known as the Browse menu.

Hiding or showing items in the all services menu is controlled by the extension configuration that gets deployed with your extension. The following example shows how to set it up. To do so, you should make a change to hide all your asset types in the environments you wish to stay hidden in. See hiding assets for help with the change.

When in the hidden state, users will not be able to browse to or search for the entry point of the extension. However, you can distribute a special link like the following one that enables the entry point by using a feature flag. https://portal.azure.com?extensionName_hideassettypes=none

A few notes about this path:

  • Any user that receives this URL will be able to see your entry point.

  • Any users who receives a deep link to blades within your extension will be able to see that experience even without the feature flag

  • If the extension is integrated into the Marketplace, then that team has its own way of hiding Marketplace items. Contact [email protected] for more details.

Public preview or GA

You are required to check the quality of your extension. We have standardized ways of measuring reliability and performance at key areas. If you have a private preview then we have already collected this data for you.

There is no blocking exit criteria, which means you do not have to prove that the extension's performance and reliability are in the required range. However, once you ship, the Portal team will monitor the quality of the extension. Extensions that do not meet the required quality bar will be flagged in executive reviews and will be asked to improve their quality as soon as possible.

When you are ready for all users to see your experience, you will enable your entry point as shown in the following example and then deploy your extension.

Useful links

Link Description
Architecture Azure portal architecture
Getting Started How To: Getting started with Azure portal SDK
Gallery Packages How To: Getting started with Gallery Packages
Onboarding PPT Azure portal Onboarding Powerpoint Slides
Samples Playground Azure portal Samples Playground
Authentication in Azure portal How To: Azure portal authentication
Azure portal Release Pipeline Check Framework Service release pipeline
Hosting Service Release Pipeline Check Hosting Service release pipeline
Check Framework Commits Check commit status for Framework
Check Hosting Service Commits Check commit status for Hosting Service
Commit History Check commit status for Hosting Service
Simonp-Sites Commits Alternative tool for framework commit status
Simonp-Sites Pipeline Alternative tool for pipeline
Simonp-Sites Environments Alternative tool for environments

You can ask developer community questions on Stackoverflow with the tag ibiza-onboarding or use the following for specific areas of Ibiza.

Stackoverflow Forums

The Ibiza team strives to answer the questions that are tagged with Ibiza tags on the Microsoft Stackoverflow Web site within 24 hours. If you do not receive a response within 24 hours, please email the owner associated with the tag.

To help the Azure UI team answer your questions, the submissions are categorized into various topics that are marked with tags. To read forum submissions, enter the following in the address bar of your browser:

https://stackoverflow.microsoft.com/questions/tagged/<ibizaTag>

To ask a question in a forum, enter the following in the address bar of your browser.

https://stackoverflow.microsoft.com/questions/ask?tags=<ibizaTag>

where

ibizaTag: One of the tags from the following table, without the angle brackets.

You can also click on the links in the table to open the correct Stackoverflow forum.

Tag Purpose Owner Contact
ibiza This is a generic Ibiza tag that should only be used when none of the below tags apply to your question. The 24 hour response SLA does not apply to this tag as someone from the Ibiza team has to triage the question and send it to the appropriate owner. Please use one of the below tags when possible and resort to this tag only when none of the other tags apply. Shrisha Kumar
ibiza-accessibility Questions regarding accessibility onboarding, best practices, supported accessible controls, etc. Also, questions regarding the accessibility bug process and exception process. Paymon Parsadmehr [email protected]
ibiza-alert A tag for questions related to the alerting and monitoring framework that Ibiza provides for extension owners. Ayesha Ghaffar
ibiza-az Questions related to the 'Az' FX feature that renders a standard HTML page into a Blade or Part (rendered in a child IFrame). Brad Olenick
ibiza-blades-parts A tag for all questions related to Ibiza Blades, Parts (Tiles), Commands. Sean Watson
ibiza-breaking-changes Breaking changes that are are insufficiently documented on https://aka.ms/portalfx/breaking Shrisha Kumar
ibiza-browse The primary navigation path in the Azure Portal. Browse consists of the Browse/Services menu, the resource list blade, and pinned part. Browse supports ARM subscription resources, ARM tenant resources, as well as custom data or simply launching your own blade. Learn more at http://aka.ms/portalfx/browse. Adrienne Chan
ibiza-controls Tag for questions related to Ibiza's control library Paymon Parsadmehr
ibiza-controls-grid A tag specially for questions related to Ibiza's Grid controls. Paymon Parsadmehr
ibiza-create A tag for questions related to Ibiza's resource create experiences and provisioning APIs. Balbir Singh
ibiza-data A tag for questions related to the Batch API that Ibiza supports. Balbir Singh
ibiza-declarative A tag for questions related to declarative extension development. Learn more. Shrisha Kumar
ibiza-development A tag for questions related local development of extensions like IDE integration, side-loading etc. Shrisha Kumar
ibiza-missing-docs Topics that are not included in https://aka.ms/portalfx/docs, are incomplete, or are difficult to understand Shrisha Kumar
ibiza-forms An Ibiza monitored tag for questions related to Azure Portal forms Paymon Parsadmehr
ibiza-hosting-service Questions related to the Hosting Service. For questions related to on-boarding to the Hosting Service, please use the ibiza-onboarding tag. Shrisha Kumar
ibiza-hubs Questions related to the Hubs extension. Balbir Singh
ibiza-localization-global Questions related to Localization or globalization within the portal. Guidence on what is or is not supported, and current languages that the Portal supports. Shrisha Kumar
ibiza-notifications Tag for questions related to notifications in the Azure Portal. Paymon Parsadmehr
ibiza-onboarding A tag for questions related to on-boarding a new extension to the Azure Portal or onboarding to the Hosting Service Santhosh Somayajula
ibiza-performance Questions related to Ibiza performance. Sean Watson [email protected]
ibiza-react Questions related to Ibiza React views development. Sean Watson
ibiza-sdkupdate Issues encountered during updating from one version of the ibiza sdk to another, for example, NuGet, Node Modules, PowerShell, or AzureUX-TemplateExtension project template-related issues Shrisha Kumar
ibiza-security-auth Questions related to Portal Authentication, Security model, AAD onboarding, Ibiza extension onboarding. Please provide details on your extension name and requirements/scenarios. Santhosh Somayajula
ibiza-telemetry All questions regarding Ibiza-Telemetry Ayesha Ghaffar [email protected]
ibiza-test The CSharp test framework Microsoft.Portal.TestFramework and the nodejs test framework msportalfx-test and msportalfx-ut Shrisha Kumar