pull/1/head
Jason Kulatunga 4 years ago committed by GitHub
commit 996437b412
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -21,7 +21,7 @@ type BaseCollector struct {
logger *logrus.Entry logger *logrus.Entry
} }
func (c *BaseCollector) detectStorageDevices() ([]models.Device, error) { func (c *BaseCollector) DetectStorageDevices() ([]models.Device, error) {
block, err := ghw.Block() block, err := ghw.Block()
if err != nil { if err != nil {
@ -113,7 +113,7 @@ func (c *BaseCollector) postJson(url string, body interface{}, target interface{
return json.NewDecoder(r.Body).Decode(target) return json.NewDecoder(r.Body).Decode(target)
} }
func (c *BaseCollector) execCmd(cmdName string, cmdArgs []string, workingDir string, environ []string) (string, error) { func (c *BaseCollector) ExecCmd(cmdName string, cmdArgs []string, workingDir string, environ []string) (string, error) {
cmd := exec.Command(cmdName, cmdArgs...) cmd := exec.Command(cmdName, cmdArgs...)
var stdBuffer bytes.Buffer var stdBuffer bytes.Buffer

@ -0,0 +1,67 @@
package collector_test
import (
"github.com/analogj/scrutiny/collector/pkg/collector"
"github.com/stretchr/testify/require"
"os/exec"
"testing"
)
func TestExecCmd(t *testing.T) {
t.Parallel()
//setup
bc := collector.BaseCollector{}
//test
result, err := bc.ExecCmd("echo", []string{"hello world"}, "", nil)
//assert
require.NoError(t, err)
require.Equal(t, "hello world\n", result)
}
func TestExecCmd_Date(t *testing.T) {
t.Parallel()
//setup
bc := collector.BaseCollector{}
//test
_, err := bc.ExecCmd("date", []string{}, "", nil)
//assert
require.NoError(t, err)
}
//
//func TestExecCmd_Error(t *testing.T) {
// t.Parallel()
//
// //setup
// bc := collector.BaseCollector {}
//
// //test
// _, err := bc.ExecCmd("smartctl", []string{"-a", "/dev/doesnotexist"}, "", nil)
//
// //assert
// exitError, castOk := err.(*exec.ExitError);
// require.True(t, castOk)
// require.Equal(t, 1, exitError.ExitCode())
//
//}
//
func TestExecCmd_InvalidCommand(t *testing.T) {
t.Parallel()
//setup
bc := collector.BaseCollector{}
//test
_, err := bc.ExecCmd("invalid_binary", []string{}, "", nil)
//assert
_, castOk := err.(*exec.ExitError)
require.False(t, castOk)
}

@ -43,7 +43,7 @@ func (mc *MetricsCollector) Run() error {
apiEndpoint.Path = "/api/devices/register" apiEndpoint.Path = "/api/devices/register"
deviceRespWrapper := new(models.DeviceWrapper) deviceRespWrapper := new(models.DeviceWrapper)
detectedStorageDevices, err := mc.detectStorageDevices() detectedStorageDevices, err := mc.DetectStorageDevices()
if err != nil { if err != nil {
return err return err
} }
@ -92,14 +92,18 @@ func (mc *MetricsCollector) Collect(wg *sync.WaitGroup, deviceWWN string, device
defer wg.Done() defer wg.Done()
mc.logger.Infof("Collecting smartctl results for %s\n", deviceName) mc.logger.Infof("Collecting smartctl results for %s\n", deviceName)
result, err := mc.execCmd("smartctl", []string{"-a", "-j", fmt.Sprintf("/dev/%s", deviceName)}, "", nil) result, err := mc.ExecCmd("smartctl", []string{"-a", "-j", fmt.Sprintf("/dev/%s", deviceName)}, "", nil)
resultBytes := []byte(result) resultBytes := []byte(result)
if err != nil { if err != nil {
mc.logger.Errorf("error while retrieving data from smartctl %s\n", deviceName) if exitError, ok := err.(*exec.ExitError); ok {
// smartctl command exited with an error, we should still push the data to the API server
mc.logger.Errorf("smartctl returned an error code (%d) while processing %s\n", exitError.ExitCode(), deviceName)
mc.Publish(deviceWWN, resultBytes)
} else {
mc.logger.Errorf("error while attempting to execute smartctl: %s\n", deviceName)
mc.logger.Errorf("ERROR MESSAGE: %v", err) mc.logger.Errorf("ERROR MESSAGE: %v", err)
mc.logger.Errorf("RESULT: %v", result) mc.logger.Errorf("IGNORING RESULT: %v", result)
// TODO: error while retrieving data from smartctl. }
// TODO: we should pass this data on to scrutiny API for recording.
return return
} else { } else {
//successful run, pass the results directly to webapp backend for parsing and processing. //successful run, pass the results directly to webapp backend for parsing and processing.

@ -6,7 +6,7 @@ engine_cmd_compile:
- 'chmod +x scrutiny-web-linux-amd64' - 'chmod +x scrutiny-web-linux-amd64'
- 'GOOS=linux GOARCH=amd64 go build -ldflags "-X main.goos=linux -X main.goarch=amd64" -o scrutiny-collector-metrics-linux-amd64 -tags "static" collector/cmd/collector-metrics/collector-metrics.go' - 'GOOS=linux GOARCH=amd64 go build -ldflags "-X main.goos=linux -X main.goarch=amd64" -o scrutiny-collector-metrics-linux-amd64 -tags "static" collector/cmd/collector-metrics/collector-metrics.go'
- 'chmod +x scrutiny-collector-metrics-linux-amd64' - 'chmod +x scrutiny-collector-metrics-linux-amd64'
engine_version_metadata_path: 'collector/pkg/version/version.go' engine_version_metadata_path: 'webapp/backend/pkg/version/version.go'
engine_cmd_test: 'go test -v -tags "static" $(go list ./... | grep -v /vendor/)' engine_cmd_test: 'go test -v -tags "static" $(go list ./... | grep -v /vendor/)'
engine_golang_package_path: 'github.com/analogj/scrutiny' engine_golang_package_path: 'github.com/analogj/scrutiny'
scm_enable_branch_cleanup: true scm_enable_branch_cleanup: true

@ -2,4 +2,4 @@ package version
// VERSION is the app-global version string, which will be replaced with a // VERSION is the app-global version string, which will be replaced with a
// new value during packaging // new value during packaging
const VERSION = "0.1.2" const VERSION = "0.1.3"

Loading…
Cancel
Save