blob: 0f042b2c2d82c93d445c583eaf1fc804caafc561 [file] [log] [blame]
jrperritt3d966162016-06-06 14:08:54 -05001package testing
Rickard von Essenc3d49b72016-02-16 20:59:18 +01002
3import (
4 "crypto/rsa"
5 "encoding/json"
6 "fmt"
7 "testing"
8
jrperritt2f93a632016-04-13 15:41:20 -05009 "github.com/gophercloud/gophercloud"
Krzysztof Szukiełojć24a29ce2017-05-07 14:24:02 +020010 "gerrit.mcp.mirantis.net/debian/gophercloud.git/openstack/compute/v2/servers"
11 th "gerrit.mcp.mirantis.net/debian/gophercloud.git/testhelper"
12 "gerrit.mcp.mirantis.net/debian/gophercloud.git/testhelper/client"
Rickard von Essenc3d49b72016-02-16 20:59:18 +010013 "golang.org/x/crypto/ssh"
14)
15
16// Fail - No password in JSON.
17func TestExtractPassword_no_pwd_data(t *testing.T) {
18
19 var dejson interface{}
20 err := json.Unmarshal([]byte(`{ "Crappy data": ".-.-." }`), &dejson)
21 if err != nil {
22 t.Fatalf("%s", err)
23 }
jrperritt3d966162016-06-06 14:08:54 -050024 resp := servers.GetPasswordResult{gophercloud.Result{Body: dejson}}
Rickard von Essenc3d49b72016-02-16 20:59:18 +010025
26 pwd, err := resp.ExtractPassword(nil)
27 th.AssertEquals(t, pwd, "")
28}
29
30// Ok - return encrypted password when no private key is given.
31func TestExtractPassword_encrypted_pwd(t *testing.T) {
32
33 var dejson interface{}
34 sejson := []byte(`{"password":"PP8EnwPO9DhEc8+O/6CKAkPF379mKsUsfFY6yyw0734XXvKsSdV9KbiHQ2hrBvzeZxtGMrlFaikVunCRizyLLWLMuOi4hoH+qy9F9sQid61gQIGkxwDAt85d/7Eau2/KzorFnZhgxArl7IiqJ67X6xjKkR3zur+Yp3V/mtVIehpPYIaAvPbcp2t4mQXl1I9J8yrQfEZOctLL1L4heDEVXnxvNihVLK6pivlVggp6SZCtjj9cduZGrYGsxsOCso1dqJQr7GCojfwvuLOoG0OYwEGuWVTZppxWxi/q1QgeHFhGKA5QUXlz7pS71oqpjYsTeViuHnfvlqb5TVYZpQ1haw=="}`)
35
36 err := json.Unmarshal(sejson, &dejson)
37 fmt.Printf("%v\n", dejson)
38 if err != nil {
39 t.Fatalf("%s", err)
40 }
jrperritt3d966162016-06-06 14:08:54 -050041 resp := servers.GetPasswordResult{gophercloud.Result{Body: dejson}}
Rickard von Essenc3d49b72016-02-16 20:59:18 +010042
43 pwd, err := resp.ExtractPassword(nil)
44 th.AssertNoErr(t, err)
45 th.AssertEquals(t, "PP8EnwPO9DhEc8+O/6CKAkPF379mKsUsfFY6yyw0734XXvKsSdV9KbiHQ2hrBvzeZxtGMrlFaikVunCRizyLLWLMuOi4hoH+qy9F9sQid61gQIGkxwDAt85d/7Eau2/KzorFnZhgxArl7IiqJ67X6xjKkR3zur+Yp3V/mtVIehpPYIaAvPbcp2t4mQXl1I9J8yrQfEZOctLL1L4heDEVXnxvNihVLK6pivlVggp6SZCtjj9cduZGrYGsxsOCso1dqJQr7GCojfwvuLOoG0OYwEGuWVTZppxWxi/q1QgeHFhGKA5QUXlz7pS71oqpjYsTeViuHnfvlqb5TVYZpQ1haw==", pwd)
46}
47
48// Ok - return decrypted password when private key is given.
49// Decrytion can be verified by:
50// echo "<enc_pwd>" | base64 -D | openssl rsautl -decrypt -inkey <privateKey.pem>
51func TestExtractPassword_decrypted_pwd(t *testing.T) {
52
53 privateKey, err := ssh.ParseRawPrivateKey([]byte(`
54-----BEGIN RSA PRIVATE KEY-----
55MIIEpQIBAAKCAQEAo1ODZgwMVdTJYim9UYuYhowoPMhGEuV5IRZjcJ315r7RBSC+
56yEiBb1V+jhf+P8fzAyU35lkBzZGDr7E3jxSesbOuYT8cItQS4ErUnI1LGuqvMxwv
57X3GMyE/HmOcaiODF1XZN3Ur5pMJdVknnmczgUsW0hT98Udrh3MQn9WSuh/6LRy6+
58x1QsKHOCLFPnkhWa3LKyxmpQq/Gvhz+6NLe+gt8MFullA5mKQxBJ/K6laVHeaMlw
59JG3GCX0EZhRlvzoV8koIBKZtbKFolFr8ZtxBm3R5LvnyrtOvp22sa+xeItUT5kG1
60ZnbGNdK87oYW+VigEUfzT/+8R1i6E2QIXoeZiQIDAQABAoIBAQCVZ70IqbbTAW8j
61RAlyQh/J3Qal65LmkFJJKUDX8TfT1/Q/G6BKeMEmxm+Zrmsfj1pHI1HKftt+YEG1
62g4jOc09kQXkgbmnfll6aHPn3J+1vdwXD3GGdjrL5PrnYrngAhJWU2r8J0x8hT8ew
63OrUJZXhDX6XuSpAAFRmOKUZgXbSmo4X+LZX76ACnarselJt5FL724ECvpWJ7xxC4
64FMzvp4RqMmNFvv/Uq9lE/EmoSk4dviYyIZZ16DbDNyc9k/sGqCAMktCEwZ3EQm//
65S5bkNhgP6oUXjluWy53aPRgykEylgDWo5SSdSEyKnw/fciU0xdprA9JrBGIcTyHS
66/k2kgD4xAoGBANTkJ88Q0YrxX3fZNZVqcn00XKTxPGmxN5LRs7eV743q30AxK5Db
67QU8iwaAA1IKUWV5DLhgUTNsDCOPUPue4aOSBD3/sj+WEmvIhj7afDL5didkYHsqf
68fDnhFHq7y/3i57d428C7BwwR79pGWVyi7vH3pfu9A1iwl1aNOae+zvbVAoGBAMRm
69AmwQ9fJ3Qc44jysFK/yliLRGdShjkMMah5G3JlrelwfPtwPwEL2EHHhJB/C1acMs
70n6Q6RaoF6WNSZUY65ksQg7aPOYf2X0FTFwQJvwDJ4qlWjmq7w+tQ0AoGJG+dVUmQ
71zHZ/Y+HokSXzz9c4oevk4v/rMgAQ00WHrTdtIhnlAoGBALIJJ72D7CkNGHCq5qPQ
72xHQukPejgolFGhufYXM7YX3GmPMe67cVlTVv9Isxhoa5N0+cUPT0LR3PGOUm/4Bb
73eOT3hZXOqLwhvE6XgI8Rzd95bClwgXekDoh80dqeKMdmta961BQGlKskaPiacmsF
74G1yhZV70P9Mwwy8vpbLB4GUNAoGAbTwbjsWkNfa0qCF3J8NZoszjCvnBQfSW2J1R
751+8ZKyNwt0yFi3Ajr3TibNiZzPzp1T9lj29FvfpJxA9Y+sXZvthxmcFxizix5GB1
76ha5yCNtA8VSOI7lJkAFDpL+j1lyYyjD6N9JE2KqEyKoh6J+8F7sXsqW7CqRRDfQX
77mKNfey0CgYEAxcEoNoADN2hRl7qY9rbQfVvQb3RkoQkdHhl9gpLFCcV32IP8R4xg
7809NbQK5OmgcIuZhLVNzTmUHJbabEGeXqIFIV0DsqECAt3WzbDyKQO23VJysFD46c
79KSde3I0ybDz7iS2EtceKB7m4C0slYd+oBkm4efuF00rCOKDwpFq45m0=
80-----END RSA PRIVATE KEY-----
81`))
82 if err != nil {
83 t.Fatalf("Error parsing private key: %s\n", err)
84 }
85
86 var dejson interface{}
87 sejson := []byte(`{"password":"PP8EnwPO9DhEc8+O/6CKAkPF379mKsUsfFY6yyw0734XXvKsSdV9KbiHQ2hrBvzeZxtGMrlFaikVunCRizyLLWLMuOi4hoH+qy9F9sQid61gQIGkxwDAt85d/7Eau2/KzorFnZhgxArl7IiqJ67X6xjKkR3zur+Yp3V/mtVIehpPYIaAvPbcp2t4mQXl1I9J8yrQfEZOctLL1L4heDEVXnxvNihVLK6pivlVggp6SZCtjj9cduZGrYGsxsOCso1dqJQr7GCojfwvuLOoG0OYwEGuWVTZppxWxi/q1QgeHFhGKA5QUXlz7pS71oqpjYsTeViuHnfvlqb5TVYZpQ1haw=="}`)
88
89 err = json.Unmarshal(sejson, &dejson)
90 fmt.Printf("%v\n", dejson)
91 if err != nil {
92 t.Fatalf("%s", err)
93 }
jrperritt3d966162016-06-06 14:08:54 -050094 resp := servers.GetPasswordResult{gophercloud.Result{Body: dejson}}
Rickard von Essenc3d49b72016-02-16 20:59:18 +010095
96 pwd, err := resp.ExtractPassword(privateKey.(*rsa.PrivateKey))
97 th.AssertNoErr(t, err)
98 th.AssertEquals(t, "ruZKK0tqxRfYm5t7lSJq", pwd)
99}
jrperritt9b7b9e62016-07-11 22:30:50 -0500100
101func TestListAddressesAllPages(t *testing.T) {
102 th.SetupHTTP()
103 defer th.TeardownHTTP()
104 HandleAddressListSuccessfully(t)
105
106 allPages, err := servers.ListAddresses(client.ServiceClient(), "asdfasdfasdf").AllPages()
107 th.AssertNoErr(t, err)
108 _, err = servers.ExtractAddresses(allPages)
109 th.AssertNoErr(t, err)
110}