Restructured with helper functions for readiness check

loop_loop_execution
Paulo Truta 2021-02-12 18:42:22 +01:00
parent 34a21094ee
commit 5a4ef2de41
1 changed files with 37 additions and 7 deletions

View File

@ -2,13 +2,13 @@ package main
import ( import (
"flag" "flag"
"fmt"
"log" "log"
"os" "os"
"os/signal" "os/signal"
"time" "time"
//"syscall"
"github.com/edgebox-iot/sysctl/internal/diagnostics" "github.com/edgebox-iot/sysctl/internal/diagnostics"
"fmt"
) )
func main() { func main() {
@ -48,11 +48,8 @@ func main() {
for { for {
log.Printf("Executing instruction %s", *name) log.Printf("Executing instruction %s", *name)
systemIterator()
// wait random number of milliseconds
Nsecs := 1000
log.Printf("Next instruction executed in %dms", Nsecs)
time.Sleep(time.Millisecond * time.Duration(Nsecs))
} }
} }
@ -68,3 +65,36 @@ func printVersion() {
diagnostics.Version, diagnostics.Commit, diagnostics.BuildDate, diagnostics.Version, diagnostics.Commit, diagnostics.BuildDate,
) )
} }
// IsSystemReady : Checks hability of the service to execute commands (Only after "edgebox --build" is ran at least once via SSH, or if built for distribution)
func isSystemReady() bool {
_, err := os.Stat("/home/system/components/ws")
return !os.IsNotExist(err)
}
// IsDatabaseReady : Checks is it can successfully connect to the task queue db
func isDatabaseReady() bool {
return false
}
// getNextInstruction : Retrieves next instruction from the database
func getNextInstruction() string {
return "Test Instruction Command"
}
func executeInstruction(string) string {
}
func systemIterator() {
if !isSystemReady() {
// Wait about 60 seconds before trying again.
log.Printf("System not ready. Next try will be executed in 60 seconds")
time.Sleep(time.Millisecond * time.Duration(60000))
} else {
// Wait about 1 second before resumming operations.
log.Printf("Next instruction will be executed 1 second")
time.Sleep(time.Millisecond * time.Duration(1000))
}
}