kairos-agent/tests/mocks/runner_mock.go
2024-03-01 12:27:26 +01:00

130 lines
3.4 KiB
Go

/*
Copyright © 2022 SUSE LLC
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package mocks
import (
"fmt"
sdkTypes "github.com/kairos-io/kairos-sdk/types"
"os/exec"
"strings"
)
type FakeRunner struct {
cmds [][]string
ReturnValue []byte
SideEffect func(command string, args ...string) ([]byte, error)
ReturnError error
Logger *sdkTypes.KairosLogger
}
func NewFakeRunner() *FakeRunner {
return &FakeRunner{cmds: [][]string{}, ReturnValue: []byte{}, SideEffect: nil, ReturnError: nil}
}
func (r *FakeRunner) Run(command string, args ...string) ([]byte, error) {
r.InitCmd(command, args...)
return r.RunCmd(nil)
}
func (r *FakeRunner) RunCmd(cmd *exec.Cmd) ([]byte, error) {
if r.SideEffect != nil {
if len(r.cmds) > 0 {
lastCmd := len(r.cmds) - 1
return r.SideEffect(r.cmds[lastCmd][0], r.cmds[lastCmd][1:]...)
}
}
return r.ReturnValue, r.ReturnError
}
func (r *FakeRunner) InitCmd(command string, args ...string) *exec.Cmd {
r.cmds = append(r.cmds, append([]string{command}, args...))
return nil
}
func (r *FakeRunner) ClearCmds() {
r.cmds = [][]string{}
}
// CmdsMatch matches the commands list in order. Note HasPrefix is being used to evaluate the
// match, so expecting initial part of the command is enough to get a match.
// It facilitates testing commands with dynamic arguments (aka temporary files)
func (r FakeRunner) CmdsMatch(cmdList [][]string) error {
if len(cmdList) != len(r.cmds) {
return fmt.Errorf("number of calls mismatch, expected %d calls but got %d", len(cmdList), len(r.cmds))
}
for i, cmd := range cmdList {
expect := strings.Join(cmd[:], " ")
got := strings.Join(r.cmds[i][:], " ")
if !strings.HasPrefix(got, expect) {
return fmt.Errorf("Expected command: '%s.*' got: '%s'", expect, got)
}
}
return nil
}
// IncludesCmds checks the given commands were executed in any order.
// Note it uses HasPrefix to match commands, see CmdsMatch.
func (r FakeRunner) IncludesCmds(cmdList [][]string) error {
for _, cmd := range cmdList {
expect := strings.Join(cmd[:], " ")
found := false
for _, rcmd := range r.cmds {
got := strings.Join(rcmd[:], " ")
if strings.HasPrefix(got, expect) {
found = true
break
}
}
if !found {
return fmt.Errorf("command '%s.*' not found", expect)
}
}
return nil
}
// MatchMilestones matches all the given commands were executed in the provided
// order. Note it uses HasPrefix to match commands, see CmdsMatch.
func (r FakeRunner) MatchMilestones(cmdList [][]string) error {
var match string
for _, cmd := range r.cmds {
if len(cmdList) == 0 {
break
}
got := strings.Join(cmd[:], " ")
match = strings.Join(cmdList[0][:], " ")
if !strings.HasPrefix(got, match) {
continue
} else {
cmdList = cmdList[1:]
}
}
if len(cmdList) > 0 {
return fmt.Errorf("command '%s' not executed", match)
}
return nil
}
func (r *FakeRunner) GetLogger() *sdkTypes.KairosLogger {
return r.Logger
}
func (r *FakeRunner) SetLogger(logger *sdkTypes.KairosLogger) {
r.Logger = logger
}