Files
grafana/contribute/backend/manage-go-module.md
Leonor Oliveira f21362ad48 Convert pkg/apis/folder to a module (#102975)
* Convert pkg/apis to a module

* Update apistore module to use apis go module

* Add module to dependabot

* Group go dependencies

* Add guidelines for adding a new gomod

* Prettier

* Only convert apis/folder to a module for now

* Add replace directive

* Add missing go mod
2025-04-02 10:10:04 +02:00

1.9 KiB

Managing Go Modules in Grafana

Creating a New Module

Best Practices for Module Creation

Create a new module when:

  1. The code has a distinct responsibility or domain

  2. The code needs its own dependency management

  3. The code might be used independently of Grafana

  4. The code has complex dependencies that should be isolated

  5. The code needs to be versioned independently

  6. Initialize the module:

cd pkg/your/new/module
go mod init github.com/grafana/grafana/pkg/your/new/module
  1. Update the workspace:
make update-workspace
  1. Add module reference to go.work file

  2. Update module consumers If other modules depend on the new module you are introducing, you migh need to temporarily add a replace directive to these consumer modules, while the newly introduced module is not published / in the main branch. You can add a replace directive like this:

// In your module's go.mod
replace github.com/grafana/grafana/pkg/<my-module> => ../../../<my-module>
  1. Upadte Dockerfile to include the new module Example:
# Dockerfile
COPY pkg/your/new/module ./pkg/your/new/module
  1. Add module to dependabot.yml for dependency updates

Example:

# .github/dependabot.yml
updates:
  - package-ecosystem: 'github-actions'
    directory: '/'
    schedule:
      interval: 'daily'
  - package-ecosystem: 'gomod'
    directories:
      - '/'
      - '/pkg/your/new/module' # Add your new module here

[!IMPORTANT] When running the command above, you may notice there will be some invalid revision version errors. This is because the module doesn't exist in the main branch yet and the root go.mod can't find a reference to the new module yet.

  1. Second PR (after first PR is merged):
    • Run make update-workspace again
    • This will update the module versions in the root go.mod
    • The module will now be properly referenced from main
    • You can now remove replace directives from your module