Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
The goal of this article is to present Fabric developers with different options for building CI/CD processes in Fabric, based on common customer scenarios. This article focuses more on the continuous integration (CI) part of the CI/CD process. For a discussion of the continuous delivery (CD) part, see manage deployment pipelines.
This article outlines a few distinct integration options, but many organizations use a combination of them.
Prerequisites
To integrate Git with your Microsoft Fabric workspace, you need to set up the following prerequisites for both Fabric and Git.
Fabric prerequisites
To access the Git integration feature, you need a Fabric capacity. A Fabric capacity is required to use all supported Fabric items. If you don't have one yet, sign up for a free trial. Customers that already have a Power BI Premium capacity, can use that capacity, but keep in mind that certain Power BI SKUs only support Power BI items.
In addition, the following tenant switches must be enabled from the Admin portal:
- Users can create Fabric items
- Users can synchronize workspace items with their Git repositories
- Create workspaces (only if you want to branch out to a new workspace.)
- Users can synchronize workspace items with GitHub repositories: For GitHub users only
These switches can be enabled by the tenant admin, capacity admin, or workspace admin, depending on your organization's settings.
Git prerequisites
Git integration is currently supported for Azure DevOps and GitHub. To use Git integration with your Fabric workspace, you need the following in either Azure DevOps or GitHub:
- An Active Azure DevOps account registered to the same user and tenant that is using the Fabric workspace (cross-tenant support is currently in preview). Create a free account.
- Access to an existing repository.
Development process
The Fabric workspace is a shared environment that accesses live items. Any changes made directly in the workspace override and affect all other workspace users. Therefore, Git best practice is for developers to work in isolation outside of the shared workspaces. There are two ways for a developer to work in their own protected workspace.
- Develop using client tools, such as Power BI Desktop for reports and semantic models, or VS Code for Notebooks.
- Develop in a separate Fabric workspace. Each developer has their own workspace where they connect their own separate branch, sync the content into that workspace, and then commit back to the branch.
To work with branches using Git integration, first connect the shared development team’s workspace to a single shared branch. For example, if your team uses one shared workspace, connect it to the main branch in your team’s repository, and sync between the workspace and the repo. If your team’s workflow has multiple shared branches like Dev/Test/Prod branches, each branch can be connected to a different workspace.
Then, each developer can choose the isolated environment in which to work.
Scenario 1 - Develop using client tools
If the items you're developing are available in other tools, you can work on those items directly in the client tool. Not all items are available in every tool. Items that are only available in Fabric need to be developed in Fabric.
The workflow for developers using a client tool like Power BI Desktop should look something like this:
- Clone the repo onto a local machine. (You only need to do this step once.) 
- Open the project in Power BI Desktop using the local copy of the PBIProj. 
- Make changes and save the updated files locally. Commit to the local repo. 
- When ready, push the branch and commits to the remote repo. 
- Test the changes against other items or against more data. To test the changes, connect the new branch to a separate workspace, and upload the semantic model and reports using the update all button in the source control panel. Do any tests or configuration changes there before merging into the main branch. - If no tests are required in the workspace, the developer can merge changes directly into the main branch, without the need for another workspace. 
- Once the changes are merged, the shared team’s workspace is prompted to accept the new commit. The changes are updated into the shared workspace and everyone can see the changes to those semantic models and reports. 
 
For a specific guidance on how to use the new Power BI Desktop file format in git, see Source code format.
Scenario 2 - Develop using another workspace
For a developer who works in the web, the flow would be as follows:
- From the Branches tab of the Source control menu, select Branch out to another workspace.   
- Specify if you want to create a new workspace or switch to an existing one. Specify the names of the new branch and workspace, or select the existing workspace from the dropdown list. You will see the following screenshot when creating a new workspace. 
Note
When you branch out to a workspace, any items that aren't saved to Git can get lost. We recommend that you commit any items you want to keep before branching out.
 
Important
When you branch out to an existing workspace some items may be deleted.
For an existing workspace, you will see the screenshot below which warns that connecting to an existing workspace may result in some items being deleted.
 
- Select Branch out. - Fabric creates the new workspace and branch. You're automatically taken to the new workspace. - The workspace syncs with your feature branch, and becomes an isolated environment to work in, as illustrated. You can now work in this new isolated environment. The sync might take a few minutes. For more information on branching out, see troubleshooting tips.   
- Save your changes and commit them into the feature branch. 
- When ready, create a PR to the main branch. The review and merge processes are done through Azure Repos based on the configuration your team defined for that repo. 
Once the review and merge are complete, a new commit is created to the main branch. This commit prompts the user to update the content in the Dev team's workspace with the merged changes.
For more information, see branching out limitations.
Release process
The release process begins once new updates complete a Pull Request process and merge into the team’s shared branch (such as Main, Dev, etc.). From this point, There are different options to build a release process in Fabric. To read about different options to consider when designing your workflow, see release process.
Switch branches
If your workspace is connected to a Git branch and you want to switch to another branch, you can do so quickly from the Source control pane without disconnecting and reconnecting.
When you switch branches, the workspace syncs with the new branch and all items in the workspace are overridden. If there are different versions of the same item in each branch, the item is replaced. If an item is in the old branch, but not the new one, it gets deleted.
Important
When switching branches, if the workspace contains an item in the old branch but not the new one, the item is deleted.
To switch between branches, follow these steps:
- From the Branches tab of the Source control menu, select Switch branch.   
- Specify the branch you want to connect to or create a new branch. This branch must contain the same directory as the current branch. 
- Place a check in I understand workspace items may be deleted and can't be restored. and select Switch branch.   
You can't switch branches if you have any uncommitted changes in the workspace. Select Cancel to go back and commit your changes before switching branches.
To connect the current workspace to a new branch while keeping the existing workspace status, select Checkout new branch. Learn more about checking out a new branch at Resolve conflicts in Git.
 
