Skip to content

Latest commit

 

History

History
403 lines (279 loc) · 15 KB

DEVELOPER.md

File metadata and controls

403 lines (279 loc) · 15 KB

Developer Guide


The Terraform Provider for Microsoft Fabric extends Terraform's capabilities to allow Terraform to manage Microsoft Fabric infrastructure and services. The provider is built on the modern Terraform Plugin Framework and NOT on the the older Terraform SDK. Ensure that you are referencing the correct Plugin Framework documentation when developing for this provider.

If you want to contribute to the provider, refer to the Contributing Guide which can help you learn about the different types of contributions you can make to the repo. The following documentation will help developers get setup and prepared to make code contributions to the repo.

Microsoft Fabric prerequisites

  • Microsoft Entra ID Tenant with Global Admin access
  • Microsoft Fabric with Admin access

You can request a free development Entra ID tenant via Microsoft 365 Developer Program. Using created tenant above, request a free Fabric trial license using Get started with Microsoft Fabric page.

Development Environment

Depends on your preferences you can use pre-configured development environment with DevContainer or your machine directly.

DevContainer development

DevContainer is the preferred way for contribution to the project.

The DevContainer feature in Visual Studio Code creates a consistent and isolated development environment. A DevContainer is a Docker container that has all the tools and dependencies needed to work with the codebase. You can open any folder inside the container and use VS Code's full feature set, including IntelliSense, code navigation, debugging, and extensions.

Prerequisites

To use the DevContainer in this repo, you need to have the following prerequisites:

Opening the DevContainer

Once you have the prerequisites, you can follow these steps to open the repo in a DevContainer:

  1. Clone or fork this repo to your local machine.
  2. Open VS Code and press F1 to open the command palette. Type "Remote-Containers: Open Folder in Container..." and select it.
  3. Browse to the folder where you cloned or forked the repo and click "Open".
  4. VS Code will reload and start building the DevContainer image. This may take a few minutes depending on your network speed and the size of the image.
  5. When the DevContainer is ready, you will see "Dev Container: Terraform Provider" in the lower left corner of the VS Code status bar. You can also open a new terminal (Ctrl+Shift+`) and see that you are inside the container.
  6. You can now edit, run, debug, and test the code as if you were on your local machine. Any changes you make will be reflected in the container and in your local file system.

Note

To work with the repository you will need to verify or configure your GIT credentials, you can do it as follows in the dev Container terminal:

  • Verify Git user name and email:
git config --list

You should see your username and email listed, if they do not appear or you want to change them you must establish them following the step below, (to quit the "git config" mode type "q").

  • Change or set your Git username and email in the DevContainer:
git config --global user.name "Your Name"
git config --global user.email "your.email@address"

Note

If you logging to docker container's shell outside the VS Code, in order to work with git repository, run the following commands:

export SSH_AUTH_SOCK=$(ls -t /tmp/vscode-ssh-auth* | head -1)
export REMOTE_CONTAINERS_IPC=$(ls -t /tmp/vscode-remote-containers-ipc* | head -1)

For more information about DevContainers, you can check out the DevContainer documentation and sharing Git credentials with your container.

Local development

DevContainer is the preferred way for contribution to the project. It contains all necessary tools and configuration that is ready to start corking on the code without thinking on development environment setup.

Local development is still possible on Windows, Linux and macOS, but requires additional step to setup development environment.

[!NOTE] Treat all instructions, commands or scripts in Local development section as examples. Depending on your local environment and configuration, the final commands or script may vary.

Requirements

  • Git >= 2.47.1
  • Go >= 1.23.5
    • We recommend you to use Go version manager go-nv/goenv
      • goenv install 1.23.5
  • Terraform >= 1.10.4
    • We recommend you to use Terraform version manager tfutils/tfenv
      • tfenv install 1.10.4, tfenv use 1.10.4
  • Task >= 3.40.1

Linux

Below you can find examples of tools setup for Ubuntu/Debian.

Install Git

sudo apt update && sudo apt install git

Install Go

goVersion=$(curl https://go.dev/dl/?mode=json | jq -r '.[0].version')
curl -LO https://go.dev/dl/$goVersion.linux-amd64.tar.gz
sudo rm -rf /usr/local/go && sudo tar -C /usr/local/ -xzf $goVersion.linux-amd64.tar.gz
rm -f $goVersion.linux-amd64.tar.gz
echo 'export PATH="$PATH:/usr/local/go/bin"' | sudo tee /etc/profile.d/go-lang.sh >/dev/null
echo 'export GOROOT=/usr/local/go' >>~/.bashrc
echo 'export GOPATH=$HOME/go' >>~/.bashrc
echo 'export PATH=$PATH:$GOROOT/bin:$GOPATH/bin' >>~/.bashrc
source ~/.bashrc

Install Terraform

wget -O- https://apt.releases.hashicorp.com/gpg | sudo gpg --dearmor -o /usr/share/keyrings/hashicorp-archive-keyring.gpg
echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/hashicorp-archive-keyring.gpg] https://apt.releases.hashicorp.com $(lsb_release -cs) main" | sudo tee /etc/apt/sources.list.d/hashicorp.list
sudo apt update && sudo apt install terraform

Install Task

sh -c "$(curl --location https://taskfile.dev/install.sh)" -- -d -b ~/.local/bin

Windows

For Git for Windows, at the step of "Adjusting your PATH environment", please choose "Use Git and optional Unix tools from Windows Command Prompt". Git for Windows must be installed per steps above

Install via winget

winget install GoLang.Go Hashicorp.Terraform Task.Task

or via Chocolatey

choco install golang terraform go-task -y
refreshenv

Linting

Markdown

To lint Markdown files use markdownlint tools. For the installation you can run:

task install:markdownlint

You can integrate markdownlint with vscode by using extension: DavidAnson.vscode-markdownlint

To execute linter, run:

task lint:md

Note

Markdown linter runs automatically just after task docs as well to lint autogenerated files.

Provider Dev Overrides

Note

You can omit below configuration if you work under DevContainer. It uses pre-configured terraformrc.

With Terraform v0.14 and later, development overrides for provider developers can be leveraged in order to use the provider built from source.

Warning

If you already use terraformrc, be careful not to overwrite your existing settings and only add the necessary configuration for this project to your existing ones.

To do this, populate a Terraform CLI configuration file ~/.terraformrc for all platforms other than Windows:

provider_installation {
  dev_overrides {
    "microsoft/fabric" = "/home/{REPLACE WITH YOUR SOURCE CODE PATH}/terraform-provider-fabric/bin/{REPLACE WITH darwin FOR MACOS OR linux FOR LINUX}-amd64"
  }

  # Install all other providers directly from their origin provider
  # registries as normal. If you omit this, no other providers will be available.
  direct {}
}

For Windows use terraform.rc in the %APPDATA% directory:

provider_installation {
  dev_overrides {
    "microsoft/fabric" = "C:\\Users\\{YOUR USERNAME}\\{REPLACE WITH YOUR SOURCE CODE PATH}\\terraform-provider-fabric\\bin\\windows-amd64"
  }

  # Install all other providers directly from their origin provider
  # registries as normal. If you omit this, no other providers will be available.
  direct {}
}

Building

To compile the provider, run task deps and task build. This will build the provider and put the provider binary in the bin directory.

task deps
task build

Debugging

This provider support terraform plugin debugging pattern.

Debugging with VS Code

  1. Open VS Code with the source code root folder
  2. Launch "Run and Debug" from VS Code.

When the debugger start you should see the Terraform debugging information similar to below:

Provider started. To attach Terraform CLI, set the TF_REATTACH_PROVIDERS environment variable with the following:

 Command Prompt: set "TF_REATTACH_PROVIDERS={"registry.terraform.io/microsoft/fabric":{"Protocol":"grpc","ProtocolVersion":6,"Pid":69004,"Test":true,"Addr":{"Network":"tcp","String":"127.0.0.1:56897"}}}"
 PowerShell: $env:TF_REATTACH_PROVIDERS='{"registry.terraform.io/microsoft/fabric":{"Protocol":"grpc","ProtocolVersion":6,"Pid":69004,"Test":true,"Addr":{"Network":"tcp","String":"127.0.0.1:56897"}}}'
  1. Copy TF_REATTACH_PROVIDERS value from the Debug Console
  2. Set TF_REATTACH_PROVIDERS environment variable in the terminal with the value copied from the above step
# Linux / macOS
export TF_REATTACH_PROVIDERS={...}
# Windows
$env:TF_REATTACH_PROVIDERS='{...}'
  1. Add breakpoints
  2. cd to a parent folder where main.tf exists
  3. Run terraform commands

Testing

Well-Known resources

To run tests, especially "Acceptance Tests" some resources on the Fabric, Entra and Azure DevOps side have to be pre-created first. To setup them, set input environment variables:

# Required
FABRIC_TESTACC_WELLKNOWN_ENTRA_TENANT_ID="<ENTRA TENANT ID>"
FABRIC_TESTACC_WELLKNOWN_AZURE_SUBSCRIPTION_ID="<AZURE SUBSCRIPTION ID>"
FABRIC_TESTACC_WELLKNOWN_FABRIC_CAPACITY_NAME="<FABRIC CAPACITY NAME>"
FABRIC_TESTACC_WELLKNOWN_AZDO_ORGANIZATION_NAME="<AZURE DEVOPS ORGANIZATION NAME>"
FABRIC_TESTACC_WELLKNOWN_NAME_PREFIX="<RESOURCES PREFIX>"

# Optional
FABRIC_TESTACC_WELLKNOWN_NAME_SUFFIX=""
FABRIC_TESTACC_WELLKNOWN_NAME_BASE=""

You can set those variables into ./wellknown.env files as well.

Then run:

task testacc:setup

Unit Tests

Note

Unit tests won't create the actual resources since they will be run against a fake server.

To run all unit tests

task testunit

To run single unit test

task testunit -- <test_name>

Note

The tests require permissions on the folders, these permissions are assigned when creating your container. If you have permission problems when running the unit tests, you can rebuild your development container or run the following commands again to assign the permissions to the necessary folders.

sudo chown -R vscode /workspace
sudo chown -R vscode /go/pkg

Acceptance Tests

Note

Acceptance tests will create the actual resources since they will be run against real APIs.

To run all acceptance tests

task testacc

To run single acceptance test

task testacc -- <test_name>

Dependencies

Adding

This provider uses Go modules. Please see the Go documentation for the most up to date information about using Go modules.

To add a new dependency github.com/author/dependency to the provider:

go get github.com/author/dependency
task deps

Updating

In the terminal type and run:

task deps

Documentation

User documentation markdown files in ./docs are auto-generated by the terraform plugin docs tool.

DO NOT manually edit the markdown files in ./docs. If you need to edit documentation edit the following sources:

task docs

User documentation is temporarily served on GitHub Pages which requires the ghpages.yml GitHub workflow to transform ./docs markdown files into a static website. Once this provider is published to the Terraform registry, documentation will be hosted on the registry instead.

Release

Our releases use semantic versioning.

Given a version number MAJOR.MINOR.PATCH, increment the:

  • MAJOR version when you make incompatible changes
  • MINOR version when you add functionality in a backward compatible manner
  • PATCH version when you make backward compatible bug fixes

Use the beta suffix with identifier to the MAJOR.MINOR.PATCH format for preview release such as v0.1.0-beta.1.