Item Types¶
Activators¶
- Parameterization:- The find_replacesection in theparameter.ymlfile is not applied.
 
- The 
- Initial deployment may not reflect streaming data immediately.
- Reflex is the item name in source control. Source control may not support all activators/reflexes, as not all sources are compatible.
Apache Airflow Jobs¶
- Parameterization:- The referenced items in DAG files will always point to the original item unless parameterized in the find_replacesection of theparameter.ymlfile.
 
- The referenced items in DAG files will always point to the original item unless parameterized in the 
- Connections are not source controlled and must be created manually.
- See known CI/CD limitations here.
API for GraphQL¶
- Parameterization:- The source will always point to the source in the original workspace unless parameterized in the find_replacesection of theparameter.ymlfile.
- It is recommended to use the supported variables in find_replacefor dynamic replacement of the source workspace and item IDs.
- If you are using a connection and expect it to change between different environments, then it needs to be parameterized in the parameter.ymlfile.
 
- The source will always point to the source in the original workspace unless parameterized in the 
- When using the Saved Credential method to connect to data sources, developers must have access to the Saved Credential information in order to successfully deploy GraphQL item.
- Changes made to the original API query are not source controlled. You will need to manually update the query in the GraphQL item's query editor within the target workspace.
- Only user authentication is currently supported for GraphQL items that source data from the SQL Analytics Endpoint.
Azure Data Factory¶
- Parameterization:- The find_replacesection in theparameter.ymlfile is not applied.
 
- The 
- Deploys a mounted Azure Data Factory to a Fabric Workspace.
- Before deployment, ensure the Azure Data Factory resource exists with proper permissions.
Copy Jobs¶
- Parameterization:- Connections will always point to the original data source unless parameterized in the find_replacesection of theparameter.ymlfile.
 
- Connections will always point to the original data source unless parameterized in the 
- Initial deployment requires manual configuration of the connection after deployment.
Dataflows¶
- Parameterization:- Source/destination items (e.g., Dataflow, Lakehouse, Warehouse) will always reference the original item unless parameterized in the find_replacesection of theparameter.ymlfile.
- The recommended approach for re-pointing source/destination items that exist in the same workspace as the Dataflow is to use replace_valuevariables in thefind_replaceparameter along with afind_valueregex (literal string works too). For more guidance, see Parameterization -> Dataflows.
- Important for Dataflows that reference another Dataflow in the same workspace, ONLY parameterize the referenced dataflowId in the mashup.pqfile (workspaceId re-pointing is handled automatically in this approach) using the followingreplace_value:$items.Dataflow.<The Source Dataflow Name>.id. This ensures proper dependency resolution and ordered publishing.
 
- Source/destination items (e.g., Dataflow, Lakehouse, Warehouse) will always reference the original item unless parameterized in the 
- Initial deployment will require a manual publish and refresh of the dataflow. After re-pointing dataflows during deployment, temporary errors may appear but should resolve after refreshing and allowing time for processing (especially when a dataflow sources from another dataflow in the target workspace).
- fabric ci-cdautomatically manages ordered deployment of dataflows that source from other dataflows in the same workspace.
- Connections are not source controlled and require manual creation.
- If you use connections that differ between environments, parameterize them in the parameter.ymlfile.
Data Agents¶
- Parameterization:- Data source items (e.g., Lakehouse, Warehouse, Semantic Model) will always reference the original item unless parameterized in the find_replacesection of theparameter.ymlfile.
 
- Data source items (e.g., Lakehouse, Warehouse, Semantic Model) will always reference the original item unless parameterized in the 
Data Pipelines¶
- Parameterization:- Activities connected to items that exist in a different workspace will always point to the original item unless parameterized in the find_replacesection of theparameter.ymlfile.
- Activities connected to items within the same workspace are automatically re-pointed to the new item in the target workspace. Note: Activities referencing items that don't use logical ID and default workspace ID (such as Refresh Dataflow and Refresh Semantic Model) require parameterization.
 
- Activities connected to items that exist in a different workspace will always point to the original item unless parameterized in the 
- Connections are not source controlled and must be created manually.
- If you are using connections and expect them to change between different environments, then those need to be parameterized in the parameter.ymlfile.
- The executing identity of the deployment must have access to the connections, or the deployment will fail.
Environments¶
- Parameterization:- Environments attached to custom spark pools attach to the default starter pool unless parameterized in the spark_poolssection of theparameter.ymlfile.
- The find_replacesection in theparameter.ymlfile is not applied to Environments.
 
- Environments attached to custom spark pools attach to the default starter pool unless parameterized in the 
- Resources are not source controlled and will not be deployed.
- Environments with libraries will have high initial publish times (sometimes 20+ minutes).
Eventhouses¶
- Parameterization:- The find_replacesection in theparameter.ymlfile is not applied.
 
- The 
- The exclude_pathvariable is required when deploying an Eventhouse that is attached to a KQL Database (common scenario).
- There may be significant differences in the streaming data between the source eventhouse and the deployed eventhouse.
- Unpublish is disabled by default, enable with feature flag enable_eventhouse_unpublish.
Eventstreams¶
- Parameterization:- Destinations connected to items that exist in a different workspace will always point to the original item unless parameterized in the find_replacesection of theparameter.ymlfile.
- Destinations connected to items within the same workspace are re-pointed to the new item in the target workspace.
 
- Destinations connected to items that exist in a different workspace will always point to the original item unless parameterized in the 
- Initial deployment requires waiting for the table to populate in the destination lakehouse if a lakehouse destination is present in the eventstream.
KQL Databases¶
- Parameterization:- The find_replacesection in theparameter.ymlfile is not applied.
 
- The 
- In Fabric, a KQL database is not a standalone item. However, during deployment, it is treated as such. Its source control files are located within a .childrenfolder under the directory of the attached eventhouse.
- Data in KQL database tables is not source controlled and may not consistently appear in the database UI after deployment. Some tables may be empty post-deployment.
KQL Querysets¶
- Parameterization:- KQL querysets attached to KQL databases always point to the original KQL database unless parameterized in the find_replacesection of theparameter.ymlfile.
 
- KQL querysets attached to KQL databases always point to the original KQL database unless parameterized in the 
- The cluster/query URI of the KQL database must be present in the KQL queryset JSON for rebinding. If the KQL queryset is attached to a KQL database within the same workspace, the cluster URI value is empty and needs to be re-added. fabric ci-cdhandles this automatically.
- KQL querysets can still exist after the KQL database source has been deleted. However, errors will reflect in the KQL queryset.
Lakehouses¶
- Parameterization:- The find_replacesection in theparameter.ymlfile is not applied.
 
- The 
- Shortcut publish is disabled by default (for now), enable with feature flag enable_shortcut_publish.
- Schemas are not deployed unless the schema has a shortcut present.
- Unpublish is disabled by default, enable with feature flag enable_lakehouse_unpublish.
Mirrored Databases¶
- Parameterization:- Connections will always point to the original source database unless parameterized in the find_replacesection of theparameter.ymlfile.
 
- Connections will always point to the original source database unless parameterized in the 
- Initial deployment for Azure SQL Database or Azure SQL Managed Instance requires manual granting of System Assigned Managed Identity (SAMI) Read and Write permission to the mirrored database for replication to be successful after deployment. ref -> (Prerequisites)
- Unpublish - a warning is shown for any default Semantic Models created by the Mirror Database. This is a current limitation of the Fabric API and can be ignored.
Notebooks¶
- Parameterization:- Notebooks attached to lakehouses always point to the original lakehouse unless parameterized in the find_replacesection of theparameter.ymlfile.
 
- Notebooks attached to lakehouses always point to the original lakehouse unless parameterized in the 
- Resources are not source controlled and will not be deployed.
Real-Time Dashboard¶
- Parameterization:- Real-Time Dashboard attached to KQL databases always point to the original KQL database unless parameterized in the find_replacesection of theparameter.ymlfile.
 
- Real-Time Dashboard attached to KQL databases always point to the original KQL database unless parameterized in the 
- The cluster/query URI of the KQL database(s) used in the dashboard must be present in the Real-Time Dashboard JSON for rebinding. If the Real-Time Dashboard is attached to a KQL database within the same workspace, the cluster URI value is empty and needs to be re-added. fabric ci-cdhandles this automatically.
Reports¶
- Parameterization:- Reports connected to Semantic Models outside of the same workspace always point to the original Semantic Model unless parameterized in the find_replacesection of theparameter.ymlfile.
- Reports connected to Semantic Models within the same workspace are re-pointed to the new item in the target workspace.
 
- Reports connected to Semantic Models outside of the same workspace always point to the original Semantic Model unless parameterized in the 
Semantic Models¶
- Parameterization:- Semantic Models connected to sources outside of the same workspace always point to the original item unless parameterized in the find_replacesection of theparameter.ymlfile.
- Semantic Models connected to sources within the same workspace may or may not be re-pointed; it is best to test this before taking a dependency. Use the find_replacesection of theparameter.ymlfile as needed.
 
- Semantic Models connected to sources outside of the same workspace always point to the original item unless parameterized in the 
- Initial deployment requires manual configuration of the connection after deployment.
SQL Databases¶
- Parameterization:- The find_replacesection in theparameter.ymlfile is not applied.
 
- The 
- SQL Database content is not deployed. Only the item shell is deployed. The SQL database schema (DDL) must be deployed separately using a DACPAC or other tools such as dbt.
- Unpublish is disabled by default, enable with feature flag enable_sqldatabase_unpublish.
Variable Libraries¶
- Parameterization:- The active value set of the variable library is defined by the environmentfield passed into theFabricWorkspaceobject. If noenvironmentis specified, the active Value Set will not be changed.
 
- The active value set of the variable library is defined by the 
- Changing Value Sets:- Variable Libraries do not support programmatically changing the name of value set which is active
- After the initial deployment, if an active set is renamed, or removed, the deployment will fail
- Manual intervention will be required to make the necessary changes in the Fabric UI and then restart the deployment
 
Warehouses¶
- Parameterization:- The find_replacesection in theparameter.ymlfile is not applied.
 
- The 
- Warehouse content is not deployed. Only the item shell is deployed. Warehouse DDL must be deployed separately using a DACPAC or other tools such as dbt.
- Case insensitive collation is supported custom collation must be manually edited in the .platformfile creation payload. See How to: Create a warehouse with case-insensitive (CI) collation for more details.
- Unpublish is disabled by default, enable with feature flag enable_warehouse_unpublish.