forked from go-chef/chef
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathnode.go
More file actions
99 lines (83 loc) · 2.43 KB
/
node.go
File metadata and controls
99 lines (83 loc) · 2.43 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
package testapi
import (
"fmt"
"os"
"github.com/go-chef/chef"
)
// node exercise the chef api
func Node() {
// Use the default test org
client := Client()
// List initial nodes
nodeList, err := client.Nodes.List()
if err != nil {
fmt.Fprintln(os.Stderr, "Couldn't list nodes: ", err)
}
fmt.Println("List initial nodes", nodeList)
// Define a Node object
node1 := chef.NewNode("node1")
node1.RunList = []string{"pwn"}
node1.AutomaticAttributes = map[string]interface{}{
"attr": "value",
}
fmt.Printf("Define node1 %+v\n", node1)
// Delete node1 ignoring errors :)
err = client.Nodes.Delete(node1.Name)
// Create
nodeResult, err := client.Nodes.Post(node1)
if err != nil {
fmt.Fprintln(os.Stderr, "Couldn't create node node1. ", err)
}
fmt.Println("Added node1", nodeResult)
// List nodes
nodeList, err = client.Nodes.List()
if err != nil {
fmt.Fprintln(os.Stderr, "Couldn't list nodes: ", err)
}
fmt.Println("List nodes after adding node1", nodeList)
// Create a second time
nodeResult, err = client.Nodes.Post(node1)
if err != nil {
fmt.Fprintln(os.Stderr, "Couldn't recreate node node1. ", err)
}
cerr, err := chef.ChefError(err)
if cerr != nil {
fmt.Fprintln(os.Stderr, "Couldn't recreate node node1. ", cerr.StatusCode())
}
fmt.Println("Added node1", nodeResult)
// Read node1 information
serverNode, err := client.Nodes.Get("node1")
if err != nil {
fmt.Fprintln(os.Stderr, "Couldn't get node: ", err)
}
fmt.Printf("Get node1 %+v\n", serverNode)
// Check node1 exits
err = client.Nodes.Head("node1")
fmt.Println("Head node node1:", err)
// Check nothere exits
err = client.Nodes.Head("nothere")
fmt.Println("Head node nothere:", err)
// update node
node1.RunList = append(node1.RunList, "recipe[works]")
node1.AutomaticAttributes = map[string]interface{}{}
updateNode, err := client.Nodes.Put(node1)
if err != nil {
fmt.Fprintln(os.Stderr, "Couldn't update node: ", err)
}
fmt.Println("Update node1", updateNode)
// Info after update
serverNode, err = client.Nodes.Get("node1")
if err != nil {
fmt.Fprintln(os.Stderr, "Couldn't get node: ", err)
}
fmt.Printf("Get node1 after update %+v\n", serverNode)
// Delete node ignoring errors :)
err = client.Nodes.Delete(node1.Name)
fmt.Println("Delete node1", err)
// List nodes
nodeList, err = client.Nodes.List()
if err != nil {
fmt.Fprintln(os.Stderr, "Couldn't list nodes: ", err)
}
fmt.Println("List nodes after cleanup", nodeList)
}