-
Notifications
You must be signed in to change notification settings - Fork 31
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: haoqing0110 <qhao@redhat.com>
- Loading branch information
1 parent
11539e4
commit 467b5e5
Showing
18 changed files
with
354 additions
and
146 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,85 @@ | ||
package framework | ||
|
||
import ( | ||
"errors" | ||
"strings" | ||
) | ||
|
||
// Code is the Status code/type which is returned from plugins. | ||
type Code int | ||
|
||
// These are predefined codes used in a Status. | ||
const ( | ||
// Success means that plugin ran correctly and found placement schedulable. | ||
// NOTE: A nil status is also considered as "Success". | ||
Success Code = iota | ||
// Warning means that plugin ran correctly and found placement schedulable, but with some failures to notice. | ||
Warning | ||
// Error is used for internal plugin errors etc. | ||
Error | ||
// Misconfigured is used for internal plugin configuration errors, unexpected input, etc. | ||
Misconfigured | ||
// Skip is used when a plugin chooses to skip running. | ||
Skip | ||
) | ||
|
||
type Status struct { | ||
code Code | ||
// reasons contains the message about status. | ||
reasons []string | ||
// Err contains the error message. | ||
err error | ||
// plugin is an optional field that records the plugin name. | ||
plugin string | ||
} | ||
|
||
// Code returns code of the Status. | ||
func (s *Status) Code() Code { | ||
if s == nil { | ||
return Success | ||
} | ||
return s.code | ||
} | ||
|
||
// Message returns a concatenated message on reasons of the Status. | ||
func (s *Status) Message() string { | ||
if s == nil { | ||
return "" | ||
} | ||
return strings.Join(s.reasons, ", ") | ||
} | ||
|
||
// AppendReason appends given reason to the Status. | ||
func (s *Status) AppendReason(reason string) { | ||
s.reasons = append(s.reasons, reason) | ||
} | ||
|
||
// AsError returns nil if the status is a success; otherwise returns an "error" object | ||
// with a concatenated message on reasons of the Status. | ||
func (s *Status) AsError() error { | ||
if s.Code() == Success { | ||
return nil | ||
} | ||
if s.err != nil { | ||
return s.err | ||
} | ||
return errors.New(s.Message()) | ||
} | ||
|
||
// FailedPlugin returns the failed plugin name. | ||
func (s *Status) Plugin() string { | ||
return s.plugin | ||
} | ||
|
||
// NewStatus makes a Status out of the given arguments and returns its pointer. | ||
func NewStatus(plugin string, code Code, reasons ...string) *Status { | ||
s := &Status{ | ||
code: code, | ||
reasons: reasons, | ||
plugin: plugin, | ||
} | ||
if code == Error { | ||
s.err = errors.New(s.Message()) | ||
} | ||
return s | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.