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