Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[1/4] Move methods under the redfishwrapper for reuse #369

Merged
merged 27 commits into from
Nov 29, 2023
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
bc60233
redfish/inventory: move Inventory method under internal/redfishwrapper
joelrebel Nov 27, 2023
551b709
providers/redfish: firmware methods moved into redfishwrapper
joelrebel Nov 27, 2023
1cb2383
providers/redfish: moved GetBiosConfiguration method under redfishwra…
joelrebel Nov 27, 2023
f595026
redfishwrapper/power: move implementation here for re-use
joelrebel Nov 27, 2023
79d80d0
providers/redfish: Inventory, FirmwareInstall, PowerSet, PowerState m…
joelrebel Nov 27, 2023
b9c4846
redfishwrapper: minor lint fixes
joelrebel Nov 27, 2023
05d943e
redfishwrapper/task: include task message in info
joelrebel Nov 27, 2023
619188e
redfishwrapper/task: lowercase task status before match
joelrebel Nov 27, 2023
d58aaec
bmc/firmware: fix up inconsistent metadata obj init and error collection
joelrebel Nov 27, 2023
3e6a6f1
providers/redfish: purge un-used methods
joelrebel Nov 27, 2023
b7f3de9
supermicro: implement Inventory, PowerSet, PowerStateGet methods
joelrebel Nov 27, 2023
bbc734d
providers/supermicro: fix up redfish session init and purge unused me…
joelrebel Nov 27, 2023
d22930a
providers/supermicro: fix TestOpen()
joelrebel Nov 28, 2023
5622adc
redfish/GetBiosconfiguration: tests and fixtures moved under redfishw…
joelrebel Nov 27, 2023
63f4d53
redfishwrapper/firmware: lets not strip the JID_ prefix, since the me…
joelrebel Nov 27, 2023
9f0b439
bmc/firmware: initialize metadata object properly
joelrebel Nov 27, 2023
37d8981
bmc/firmware: defines interface to upload and install firmware in the…
joelrebel Nov 27, 2023
e14321b
providers/dell: adds a helper method and implements Inventory(), Powe…
joelrebel Nov 27, 2023
ba60fa0
providers/dell: Implements FirmwareInstallSteps(), FirmwareInstallUpl…
joelrebel Nov 27, 2023
6ee715b
go: update gofish to include Task Oem data fix
joelrebel Nov 27, 2023
41cb5fa
providers/redfish: task methods moved under redfishwrapper package
joelrebel Nov 28, 2023
04eb8ca
squash
joelrebel Nov 28, 2023
cdc6f14
providers/redfish: dell tests moved under dell provider
joelrebel Nov 28, 2023
8c3aefb
redfishwrapper: minor fix for test
joelrebel Nov 28, 2023
95d52c0
Merge pull request #372 from bmc-toolbox/redfish-dell
joelrebel Nov 29, 2023
ef9c38c
Merge pull request #371 from bmc-toolbox/redfishwrapper-bios
joelrebel Nov 29, 2023
ee0f228
Merge pull request #370 from bmc-toolbox/smc-redfish-fixes
joelrebel Nov 29, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
35 changes: 18 additions & 17 deletions bmc/firmware.go
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ func firmwareInstall(ctx context.Context, component, operationApplyTime string,
taskID, vErr := elem.FirmwareInstall(ctx, component, operationApplyTime, forceInstall, reader)
if vErr != nil {
err = multierror.Append(err, errors.WithMessagef(vErr, "provider: %v", elem.name))
err = multierror.Append(err, vErr)
metadata.FailedProviderDetail[elem.name] = err.Error()
continue

}
Expand Down Expand Up @@ -134,7 +134,7 @@ func firmwareInstallStatus(ctx context.Context, installVersion, component, taskI
status, vErr := elem.FirmwareInstallStatus(ctx, installVersion, component, taskID)
if vErr != nil {
err = multierror.Append(err, errors.WithMessagef(vErr, "provider: %v", elem.name))
err = multierror.Append(err, vErr)
metadata.FailedProviderDetail[elem.name] = err.Error()
continue

}
Expand Down Expand Up @@ -213,7 +213,7 @@ func firmwareInstallUploaded(ctx context.Context, component, uploadTaskID string
installTaskID, vErr = elem.FirmwareInstallUploaded(ctx, component, uploadTaskID)
if vErr != nil {
err = multierror.Append(err, errors.WithMessagef(vErr, "provider: %v", elem.name))
err = multierror.Append(err, vErr)
metadata.FailedProviderDetail[elem.name] = err.Error()
continue

}
Expand Down Expand Up @@ -310,7 +310,7 @@ func firmwareInstallSteps(ctx context.Context, component string, generic []firmw
steps, vErr := elem.FirmwareInstallSteps(ctx, component)
if vErr != nil {
err = multierror.Append(err, errors.WithMessagef(vErr, "provider: %v", elem.name))
err = multierror.Append(err, vErr)
metadata.FailedProviderDetail[elem.name] = err.Error()
continue

}
Expand Down Expand Up @@ -362,7 +362,7 @@ func FirmwareUploadFromInterfaces(ctx context.Context, component string, file *o
}

func firmwareUpload(ctx context.Context, component string, file *os.File, generic []firmwareUploaderProvider) (taskID string, metadata Metadata, err error) {
var metadataLocal Metadata
metadata = newMetadata()

for _, elem := range generic {
if elem.FirmwareUploader == nil {
Expand All @@ -374,20 +374,20 @@ func firmwareUpload(ctx context.Context, component string, file *os.File, generi

return taskID, metadata, err
default:
metadataLocal.ProvidersAttempted = append(metadataLocal.ProvidersAttempted, elem.name)
metadata.ProvidersAttempted = append(metadata.ProvidersAttempted, elem.name)
taskID, vErr := elem.FirmwareUpload(ctx, component, file)
if vErr != nil {
err = multierror.Append(err, errors.WithMessagef(vErr, "provider: %v", elem.name))
err = multierror.Append(err, vErr)
metadata.FailedProviderDetail[elem.name] = err.Error()
continue

}
metadataLocal.SuccessfulProvider = elem.name
return taskID, metadataLocal, nil
metadata.SuccessfulProvider = elem.name
return taskID, metadata, nil
}
}

return taskID, metadataLocal, multierror.Append(err, errors.New("failure in FirmwareUpload"))
return taskID, metadata, multierror.Append(err, errors.New("failure in FirmwareUpload"))
}

// FirmwareTaskVerifier defines an interface to check the status for firmware related tasks queued on the BMC.
Expand Down Expand Up @@ -416,8 +416,9 @@ type firmwareTaskVerifierProvider struct {
}

// firmwareTaskStatus returns the status of the firmware upload process.

func firmwareTaskStatus(ctx context.Context, kind bconsts.FirmwareInstallStep, component, taskID, installVersion string, generic []firmwareTaskVerifierProvider) (state constants.TaskState, status string, metadata Metadata, err error) {
var metadataLocal Metadata
metadata = newMetadata()

for _, elem := range generic {
if elem.FirmwareTaskVerifier == nil {
Expand All @@ -429,20 +430,20 @@ func firmwareTaskStatus(ctx context.Context, kind bconsts.FirmwareInstallStep, c

return state, status, metadata, err
default:
metadataLocal.ProvidersAttempted = append(metadataLocal.ProvidersAttempted, elem.name)
metadata.ProvidersAttempted = append(metadata.ProvidersAttempted, elem.name)
state, status, vErr := elem.FirmwareTaskStatus(ctx, kind, component, taskID, installVersion)
if vErr != nil {
err = multierror.Append(err, errors.WithMessagef(vErr, "provider: %v", elem.name))
err = multierror.Append(err, vErr)
metadata.FailedProviderDetail[elem.name] = err.Error()
continue

}
metadataLocal.SuccessfulProvider = elem.name
return state, status, metadataLocal, nil

metadata.SuccessfulProvider = elem.name
return state, status, metadata, nil
}
}

return state, status, metadataLocal, multierror.Append(err, errors.New("failure in FirmwareTaskStatus"))
return state, status, metadata, multierror.Append(err, errors.New("failure in FirmwareTaskStatus"))
}

// FirmwareTaskStatusFromInterfaces identifies implementations of the FirmwareTaskVerifier interface and passes the found implementations to the firmwareTaskStatus() wrapper.
Expand Down
8 changes: 4 additions & 4 deletions providers/redfish/bios.go → internal/redfishwrapper/bios.go
Original file line number Diff line number Diff line change
@@ -1,20 +1,20 @@
package redfish
package redfishwrapper

import (
"context"

bmclibErrs "github.com/bmc-toolbox/bmclib/v2/errors"
)

func (c *Conn) GetBiosConfiguration(ctx context.Context) (biosConfig map[string]string, err error) {
systems, err := c.redfishwrapper.Systems()
func (c *Client) GetBiosConfiguration(ctx context.Context) (biosConfig map[string]string, err error) {
systems, err := c.Systems()
if err != nil {
return nil, err
}

biosConfig = make(map[string]string)
for _, sys := range systems {
if !compatibleOdataID(sys.ODataID, systemsOdataIDs) {
if !c.compatibleOdataID(sys.ODataID, knownSystemsOdataIDs) {
continue
}

Expand Down
Loading
Loading