2019-03-14 11:13:15 -07:00
|
|
|
package simulation
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
// log writter
|
|
|
|
type LogWriter interface {
|
|
|
|
AddEntry(OperationEntry)
|
|
|
|
PrintLogs()
|
|
|
|
}
|
|
|
|
|
|
|
|
// LogWriter - return a dummy or standard log writer given the testingmode
|
|
|
|
func NewLogWriter(testingmode bool) LogWriter {
|
|
|
|
if !testingmode {
|
|
|
|
return &DummyLogWriter{}
|
|
|
|
}
|
|
|
|
return &StandardLogWriter{}
|
|
|
|
}
|
|
|
|
|
|
|
|
// log writter
|
|
|
|
type StandardLogWriter struct {
|
2019-07-05 16:25:56 -07:00
|
|
|
OpEntries []OperationEntry `json:"op_entries" yaml:"op_entries"`
|
2019-03-14 11:13:15 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// add an entry to the log writter
|
|
|
|
func (lw *StandardLogWriter) AddEntry(opEntry OperationEntry) {
|
|
|
|
lw.OpEntries = append(lw.OpEntries, opEntry)
|
|
|
|
}
|
|
|
|
|
|
|
|
// PrintLogs - print the logs to a simulation file
|
|
|
|
func (lw *StandardLogWriter) PrintLogs() {
|
|
|
|
f := createLogFile()
|
|
|
|
for i := 0; i < len(lw.OpEntries); i++ {
|
|
|
|
writeEntry := fmt.Sprintf("%s\n", (lw.OpEntries[i]).MustMarshal())
|
|
|
|
_, err := f.WriteString(writeEntry)
|
|
|
|
if err != nil {
|
|
|
|
panic("Failed to write logs to file")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func createLogFile() *os.File {
|
|
|
|
var f *os.File
|
|
|
|
fileName := fmt.Sprintf("%s.log", time.Now().Format("2006-01-02_15:04:05"))
|
|
|
|
|
2019-05-18 01:42:24 -07:00
|
|
|
folderPath := os.ExpandEnv("$HOME/.simapp/simulations")
|
2019-03-14 11:13:15 -07:00
|
|
|
filePath := path.Join(folderPath, fileName)
|
|
|
|
|
|
|
|
err := os.MkdirAll(folderPath, os.ModePerm)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
f, _ = os.Create(filePath)
|
|
|
|
fmt.Printf("Logs to writing to %s\n", filePath)
|
|
|
|
return f
|
|
|
|
}
|
|
|
|
|
|
|
|
//_____________________
|
|
|
|
// dummy log writter
|
|
|
|
type DummyLogWriter struct{}
|
|
|
|
|
|
|
|
// do nothing
|
|
|
|
func (lw *DummyLogWriter) AddEntry(_ OperationEntry) {}
|
|
|
|
|
|
|
|
// do nothing
|
|
|
|
func (lw *DummyLogWriter) PrintLogs() {}
|