Skip to content

Latest commit

 

History

History
128 lines (91 loc) · 5.05 KB

development-guide.md

File metadata and controls

128 lines (91 loc) · 5.05 KB

Promitor Development Guide

This guide explains the layout of the Promitor repository, along with the tools and technologies required to develop Promitor.

Repository Structure

The promitor repository is made up of a number of different directories:

  • / - contains documentation about the repository including the main README file and some configuration files for various tools used for development.
  • /.github - contains github specific files including issue and PR templates.
  • /.vscode - contains shared configuration files for VS Code.
  • /build - contains the configuration files for Promitor's CI process.
  • /changelog - contains the source code for building https://changelog.promitor.io
  • /charts - contains Promitor's Helm chart.
  • /config - contains the configuration to run Promitor locally or in the CI
  • /deploy - contains the automation that is being used to manage Promitor, such as the automated updates concerning new Docker images in a pull request.
  • /docs - contains the source code (mainly markdown files) for building the https://promitor.io.
  • /media - contains all media such as images and sources of schematics used in the docs
  • /src - contains the .NET source code for the Promitor application.

Helm Chart

The code for Promitor's Helm chart can be found in charts/promitor-agent-scraper.

To work on the Helm chart, you need the following tools:

  • Helm.
  • A working Kubernetes cluster. For local development you can use Docker Desktop which has an option to install a local cluster for you, or a tool such as Minikube or kind.

The chart's README contains information about how to install the chart in your Kubernetes cluster. For local development, you can substitute the relative path to the chart instead of using the chart name, for example:

helm install --name promitor-agent-scraper ./charts/promitor-agent-scraper \
  --set azureAuthentication.appId='<azure-ad-app-id>' \
  ...

Please follow Helm's Best Practices when developing the chart.

Documentation

The documentation for Promitor is stored in /docs. When adding new functionality to Promitor or modifying existing functionality, please add associated documentation. Information about how to build and run the documentation locally can be found in the README for the documentation.

.NET Development

Promitor is written in C# using .NET Core. To make changes to Promitor you need the following tools:

  • .NET Core SDK.
  • Visual Studio 2017+, or an alternative editor like VS Code.

The C# code for Promitor can be found in the /src folder in the repository. The Promitor code is split into multiple projects by functionality, with the following projects worth highlighting:

  • Promitor.Agents.Scraper - contains the main console application that runs Promitor.
  • Promitor.Tests.Unit - contains the XUnit unit tests.
  • Promitor.Docker - contains a Visual Studio Docker project for running Promitor during development.

Visual Studio

If you are using Visual Studio, the solution file for Promitor is src/Promitor.sln.

Running Tests

To run the unit tests for Promitor, open a terminal and navigate to src/Promitor.Tests.Unit, and run the following command:

dotnet test

If you want to perform TDD, you can use the dotnet watch command to watch for changes and re-run the tests:

dotnet watch test

Alternatively, you can use the built-in tests runners in Visual Studio or whatever tool you are using to edit the code.

Running Promitor

To run Promitor, edit src/docker-compose.override.yml and set the following environment variables:

  • PROMITOR_AUTH_APPID - the client Id of the service principal used to access the Azure Monitor API.
  • PROMITOR_AUTH_APPKEY - your service principal secret.

Next, edit config/promitor/scraper/metrics.yaml and set the following keys:

  • azureMetadata.tenantId - your Azure tenant Id.
  • azureMetadata.subscriptionId - your Azure subscription Id.
  • azureMetadata.resourceGroupName - the default resource group to use if none is specified for a metric.

Configure at least one scraper under the metrics section and finally, run the Promitor.Docker project.

You can find more information about how to configure Promitor here.

NOTE: Please make sure not to commit your changes to docker-compose.override.yml or metrics.yaml. If you do, you may end up publishing your Azure credentials by accident.

Docker

To build the Docker image, run the following command from the /src directory:

docker build . --file .\Promitor.Agents.Scraper\Dockerfile.linux --tag promitor --no-cache