Andrey Smirnov bc4c21f41a
test: add json logs test environment
Add an option to `talosctl cluster create` to start a JSON log receiver,
and enabled it optionally.

Enable in `integration-qemu`.

See #9510

Signed-off-by: Andrey Smirnov <andrey.smirnov@siderolabs.com>
2024-10-17 16:23:26 +04:00

101 lines
2.2 KiB
Go

// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
package qemu
import (
"context"
"fmt"
"os"
"github.com/siderolabs/talos/pkg/provision"
"github.com/siderolabs/talos/pkg/provision/providers/vm"
)
// Destroy Talos cluster as set of qemu VMs.
//
//nolint:gocyclo
func (p *provisioner) Destroy(ctx context.Context, cluster provision.Cluster, opts ...provision.Option) error {
options := provision.DefaultOptions()
for _, opt := range opts {
if err := opt(&options); err != nil {
return err
}
}
complete := false
deleteStateDirectory := func(shouldDelete bool) error {
if complete || !shouldDelete {
return nil
}
complete = true
stateDirectoryPath, err := cluster.StatePath()
if err != nil {
return err
}
return os.RemoveAll(stateDirectoryPath)
}
defer deleteStateDirectory(options.DeleteStateOnErr) //nolint:errcheck
fmt.Fprintln(options.LogWriter, "stopping VMs")
if err := p.DestroyNodes(cluster.Info(), &options); err != nil {
return err
}
if err := p.destroyVirtualTPM2s(cluster.Info()); err != nil {
return err
}
state, ok := cluster.(*vm.State)
if !ok {
return fmt.Errorf("error inspecting QEMU state, %#+v", cluster)
}
fmt.Fprintln(options.LogWriter, "removing dhcpd")
if err := p.DestroyDHCPd(state); err != nil {
return fmt.Errorf("error stopping dhcpd: %w", err)
}
fmt.Fprintln(options.LogWriter, "removing load balancer")
if err := p.DestroyLoadBalancer(state); err != nil {
return fmt.Errorf("error stopping loadbalancer: %w", err)
}
fmt.Fprintln(options.LogWriter, "removing kms")
if err := p.DestroyKMS(state); err != nil {
return err
}
fmt.Fprintln(options.LogWriter, "removing json logs")
if err := p.DestroyJSONLogs(state); err != nil {
return err
}
fmt.Fprintln(options.LogWriter, "removing network")
if err := p.DestroyNetwork(state); err != nil {
return err
}
fmt.Fprintln(options.LogWriter, "removing siderolink agent")
if err := p.DestroySiderolinkAgent(state); err != nil {
return err
}
fmt.Fprintln(options.LogWriter, "removing state directory")
return deleteStateDirectory(true)
}