Plugins: Identify plugin ID when provisioning fails for any reason (#111543)

This commit is contained in:
Matheus Macabu 2025-09-24 14:05:43 +02:00 committed by GitHub
parent a98870f8f9
commit 6c8ca56651
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 32 additions and 6 deletions

View File

@ -3,6 +3,7 @@ package plugins
import ( import (
"context" "context"
"errors" "errors"
"fmt"
"github.com/grafana/grafana/pkg/infra/log" "github.com/grafana/grafana/pkg/infra/log"
"github.com/grafana/grafana/pkg/services/org" "github.com/grafana/grafana/pkg/services/org"
@ -10,6 +11,11 @@ import (
"github.com/grafana/grafana/pkg/services/pluginsintegration/pluginstore" "github.com/grafana/grafana/pkg/services/pluginsintegration/pluginstore"
) )
var (
ErrPluginProvisioningNotFound = errors.New("plugin not found")
ErrPluginProvisioningAutoEnabled = errors.New("plugin is auto enabled and cannot be disabled")
)
// Provision scans a directory for provisioning config files // Provision scans a directory for provisioning config files
// and provisions the app in those files. // and provisions the app in those files.
func Provision(ctx context.Context, configDirectory string, pluginStore pluginstore.Store, pluginSettings pluginsettings.Service, orgService org.Service) error { func Provision(ctx context.Context, configDirectory string, pluginStore pluginstore.Store, pluginSettings pluginsettings.Service, orgService org.Service) error {
@ -49,10 +55,10 @@ func (ap *PluginProvisioner) apply(ctx context.Context, cfg *pluginsAsConfig) er
p, found := ap.pluginStore.Plugin(ctx, app.PluginID) p, found := ap.pluginStore.Plugin(ctx, app.PluginID)
if !found { if !found {
return errors.New("plugin not found") return fmt.Errorf("%w: %s", ErrPluginProvisioningNotFound, app.PluginID)
} }
if p.AutoEnabled && !app.Enabled { if p.AutoEnabled && !app.Enabled {
return errors.New("plugin is auto enabled and cannot be disabled") return fmt.Errorf("%w: %s", ErrPluginProvisioningAutoEnabled, app.PluginID)
} }
ps, err := ap.pluginSettings.GetPluginSettingByPluginID(ctx, &pluginsettings.GetByPluginIDArgs{ ps, err := ap.pluginSettings.GetPluginSettingByPluginID(ctx, &pluginsettings.GetByPluginIDArgs{
@ -61,7 +67,7 @@ func (ap *PluginProvisioner) apply(ctx context.Context, cfg *pluginsAsConfig) er
}) })
if err != nil { if err != nil {
if !errors.Is(err, pluginsettings.ErrPluginSettingNotFound) { if !errors.Is(err, pluginsettings.ErrPluginSettingNotFound) {
return err return fmt.Errorf("%w: %s", err, app.PluginID)
} }
} else { } else {
app.PluginVersion = ps.PluginVersion app.PluginVersion = ps.PluginVersion
@ -77,7 +83,7 @@ func (ap *PluginProvisioner) apply(ctx context.Context, cfg *pluginsAsConfig) er
SecureJSONData: app.SecureJSONData, SecureJSONData: app.SecureJSONData,
PluginVersion: app.PluginVersion, PluginVersion: app.PluginVersion,
}); err != nil { }); err != nil {
return err return fmt.Errorf("%w: %s", err, app.PluginID)
} }
} }

View File

@ -100,8 +100,28 @@ func TestPluginProvisioner(t *testing.T) {
} }
err := ap.applyChanges(context.Background(), "") err := ap.applyChanges(context.Background(), "")
require.Error(t, err) require.ErrorIs(t, err, ErrPluginProvisioningAutoEnabled)
require.Contains(t, err.Error(), "plugin is auto enabled and cannot be disabled") })
t.Run("Should return error trying to configure a non-existing plugin", func(t *testing.T) {
cfg := []*pluginsAsConfig{
{
Apps: []*appFromConfig{
{PluginID: "test-plugin", OrgID: 2, Enabled: false},
},
},
}
reader := &testConfigReader{result: cfg}
store := &mockStore{}
ap := PluginProvisioner{
log: log.New("test"),
cfgProvider: reader,
pluginSettings: store,
pluginStore: pluginstore.NewFakePluginStore(),
}
err := ap.applyChanges(context.Background(), "")
require.ErrorIs(t, err, ErrPluginProvisioningNotFound)
}) })
} }