virtbuf/example/main.go

99 lines
2.0 KiB
Go
Raw Normal View History

2024-10-18 20:58:15 -05:00
package main
import (
"bufio"
"bytes"
"fmt"
"io/ioutil"
"log"
"os"
2024-10-18 20:58:15 -05:00
"google.golang.org/protobuf/proto"
pb "go.wit.com/lib/protobuf/virtbuf"
)
2024-10-18 20:58:15 -05:00
//
// saves entries in a config file
//
func main() {
TestWriteCluster()
2024-10-18 20:58:15 -05:00
in, err := ioutil.ReadFile("/tmp/testing4.protobuf")
if err != nil {
log.Fatalln("Error reading file:", err)
}
var aCluster pb.Cluster
if err := proto.Unmarshal(in, &aCluster); err != nil {
log.Fatalln("Failed to parse droplet:", err)
2024-10-18 20:58:15 -05:00
}
log.Println(aCluster.String())
// show the droplets to STDOUT
for _, d := range aCluster.Droplets {
fmt.Println("\tdroplet =", d.Hostname, "preffered host:", d.PreferredHypervisor)
}
// show the hypervisors to STDOUT
for _, h := range aCluster.Hypervisors {
fmt.Println("\thypervisor =", h.Hostname, h.GetMemoryPrintable())
}
json := aCluster.FormatJSON()
fmt.Println(json)
data, _ := aCluster.MarshalJSON()
fmt.Println(string(data))
text := aCluster.FormatTEXT()
fmt.Println(text)
2024-10-18 20:58:15 -05:00
}
func marshalWriteToFile(myWriter *bufio.Writer, c *pb.Cluster) {
buf, err := proto.Marshal(c)
2024-10-18 20:58:15 -05:00
if err != nil {
log.Fatal("marshaling error: ", err)
}
tmp, err := myWriter.Write(buf)
myWriter.Flush()
log.Println("bufio.Write() tmp, err = ", tmp, err)
buf, err = proto.Marshal(c)
2024-10-18 20:58:15 -05:00
tmp2, err := myWriter.Write(buf)
myWriter.Flush()
log.Println("bufio.Write() tmp2, err = ", tmp2, err)
}
func TestWriteCluster() {
2024-10-18 20:58:15 -05:00
buf := new(bytes.Buffer)
c := pb.CreateSampleCluster(7)
2024-10-18 20:58:15 -05:00
got := buf.String()
log.Println(got)
newfile, _ := os.Create("/tmp/testing4.protobuf")
myWriter := bufio.NewWriter(newfile)
marshalWriteToFile(myWriter, c)
2024-10-18 20:58:15 -05:00
// marshalUnmarshal()
2024-10-18 20:58:15 -05:00
}
func marshalUnmarshal() {
test := pb.CreateSampleCluster(7)
2024-10-18 20:58:15 -05:00
data, err := proto.Marshal(test)
if err != nil {
log.Fatal("marshaling error: ", err)
}
newTest := &pb.Cluster{}
2024-10-18 20:58:15 -05:00
err = proto.Unmarshal(data, newTest)
if err != nil {
log.Fatal("unmarshaling error: ", err)
} else {
log.Println("proto.Marshal() and proto.Unmarshal() worked")
}
}