2024-11-03 00:39:52 -05:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
2024-11-15 17:25:11 -06:00
|
|
|
"go.wit.com/lib/protobuf/zoopb"
|
2024-11-15 17:38:24 -06:00
|
|
|
"go.wit.com/log"
|
2024-11-03 00:39:52 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2024-11-15 22:36:55 -06:00
|
|
|
m := testMachine()
|
|
|
|
testPackages(m)
|
2024-11-22 14:33:06 -06:00
|
|
|
|
|
|
|
loop := m.Packages.SortByName()
|
|
|
|
for loop.Scan() {
|
|
|
|
p := loop.Package()
|
|
|
|
log.Info("installed package:", p.Name, p.Version, p.PkgName)
|
|
|
|
}
|
|
|
|
|
|
|
|
if m.IsInstalled("bash") {
|
|
|
|
log.Info("bash installed check worked")
|
|
|
|
} else {
|
|
|
|
log.Info("bash installed check failed")
|
|
|
|
panic("bash")
|
|
|
|
}
|
|
|
|
|
|
|
|
if m.IsInstalled("foo") {
|
|
|
|
log.Info("foo not-installed check failed")
|
|
|
|
panic("foo")
|
|
|
|
} else {
|
|
|
|
log.Info("foo not-installed check worked")
|
|
|
|
}
|
2024-11-15 22:32:27 -06:00
|
|
|
}
|
|
|
|
|
2024-11-15 22:36:55 -06:00
|
|
|
func testMachine() *zoopb.Machine {
|
|
|
|
var m *zoopb.Machine
|
|
|
|
m = new(zoopb.Machine)
|
|
|
|
m.Hostname = "zookeeper"
|
|
|
|
return m
|
|
|
|
}
|
|
|
|
|
|
|
|
func testPackages(m *zoopb.Machine) {
|
2024-11-22 14:33:06 -06:00
|
|
|
m.Packages = new(zoopb.Packages)
|
2024-11-15 17:25:11 -06:00
|
|
|
// r = zoopb.LoadJSON("go.wit.com/lib/protobuf/zoopb")
|
2024-11-03 00:39:52 -05:00
|
|
|
|
2024-11-15 17:38:24 -06:00
|
|
|
new1 := new(zoopb.Package)
|
|
|
|
new1.Name = "bash"
|
|
|
|
new1.Version = "5.2.21"
|
2024-11-22 14:33:06 -06:00
|
|
|
if m.Packages.Append(new1) {
|
2024-11-15 17:38:24 -06:00
|
|
|
log.Info("added", new1.Name, "ok")
|
|
|
|
} else {
|
|
|
|
log.Info("added", new1.Name, "failed")
|
|
|
|
}
|
|
|
|
|
|
|
|
new2 := new(zoopb.Package)
|
|
|
|
new2.Name = "go-clone"
|
|
|
|
new2.Version = "0.6.8" // good version of the macos
|
2024-11-22 14:33:06 -06:00
|
|
|
if m.Packages.Append(new2) {
|
2024-11-15 17:38:24 -06:00
|
|
|
log.Info("added", new2.Name, "ok")
|
|
|
|
} else {
|
|
|
|
log.Info("added", new2.Name, "failed")
|
|
|
|
}
|
|
|
|
|
2024-11-22 14:33:06 -06:00
|
|
|
if m.Packages.Append(new2) {
|
2024-11-15 17:38:24 -06:00
|
|
|
log.Info("added", new2.Name, "ok (this is bad)")
|
|
|
|
} else {
|
|
|
|
log.Info("added", new2.Name, "failed (but ok)")
|
|
|
|
}
|
2024-11-15 17:25:11 -06:00
|
|
|
|
2024-11-22 14:33:06 -06:00
|
|
|
fmt.Println("package count = ", m.Packages.Len())
|
2024-11-03 00:39:52 -05:00
|
|
|
}
|