| package stacktemplates |
| |
| import ( |
| "fmt" |
| "net/http" |
| "testing" |
| |
| th "github.com/rackspace/gophercloud/testhelper" |
| fake "github.com/rackspace/gophercloud/testhelper/client" |
| ) |
| |
| // GetExpected represents the expected object from a Get request. |
| var GetExpected = &Template{ |
| Description: "Simple template to test heat commands", |
| HeatTemplateVersion: "2013-05-23", |
| Parameters: map[string]interface{}{ |
| "flavor": map[string]interface{}{ |
| "default": "m1.tiny", |
| "type": "string", |
| }, |
| }, |
| Resources: map[string]interface{}{ |
| "hello_world": map[string]interface{}{ |
| "type": "OS::Nova::Server", |
| "properties": map[string]interface{}{ |
| "key_name": "heat_key", |
| "flavor": map[string]interface{}{ |
| "get_param": "flavor", |
| }, |
| "image": "ad091b52-742f-469e-8f3c-fd81cadf0743", |
| "user_data": "#!/bin/bash -xv\necho \"hello world\" > /root/hello-world.txt\n", |
| }, |
| }, |
| }, |
| } |
| |
| // GetOutput represents the response body from a Get request. |
| const GetOutput = ` |
| { |
| "heat_template_version": "2013-05-23", |
| "description": "Simple template to test heat commands", |
| "parameters": { |
| "flavor": { |
| "default": "m1.tiny", |
| "type": "string" |
| } |
| }, |
| "resources": { |
| "hello_world": { |
| "type": "OS::Nova::Server", |
| "properties": { |
| "key_name": "heat_key", |
| "flavor": { |
| "get_param": "flavor" |
| }, |
| "image": "ad091b52-742f-469e-8f3c-fd81cadf0743", |
| "user_data": "#!/bin/bash -xv\necho \"hello world\" > /root/hello-world.txt\n" |
| } |
| } |
| } |
| }` |
| |
| // HandleGetSuccessfully creates an HTTP handler at `/stacks/postman_stack/16ef0584-4458-41eb-87c8-0dc8d5f66c87/template` |
| // on the test handler mux that responds with a `Get` response. |
| func HandleGetSuccessfully(t *testing.T, output string) { |
| th.Mux.HandleFunc("/stacks/postman_stack/16ef0584-4458-41eb-87c8-0dc8d5f66c87/template", func(w http.ResponseWriter, r *http.Request) { |
| th.TestMethod(t, r, "GET") |
| th.TestHeader(t, r, "X-Auth-Token", fake.TokenID) |
| th.TestHeader(t, r, "Accept", "application/json") |
| |
| w.Header().Set("Content-Type", "application/json") |
| w.WriteHeader(http.StatusOK) |
| fmt.Fprintf(w, output) |
| }) |
| } |
| |
| // ValidateExpected represents the expected object from a Validate request. |
| var ValidateExpected = &ValidatedTemplate{ |
| Description: "Simple template to test heat commands", |
| Parameters: map[string]interface{}{ |
| "flavor": map[string]interface{}{ |
| "Default": "m1.tiny", |
| "Type": "String", |
| "NoEcho": "false", |
| "Description": "", |
| "Label": "flavor", |
| }, |
| }, |
| } |
| |
| // ValidateOutput represents the response body from a Validate request. |
| const ValidateOutput = ` |
| { |
| "Description": "Simple template to test heat commands", |
| "Parameters": { |
| "flavor": { |
| "Default": "m1.tiny", |
| "Type": "String", |
| "NoEcho": "false", |
| "Description": "", |
| "Label": "flavor" |
| } |
| } |
| }` |
| |
| // HandleValidateSuccessfully creates an HTTP handler at `/validate` |
| // on the test handler mux that responds with a `Validate` response. |
| func HandleValidateSuccessfully(t *testing.T, output string) { |
| th.Mux.HandleFunc("/validate", func(w http.ResponseWriter, r *http.Request) { |
| th.TestMethod(t, r, "POST") |
| th.TestHeader(t, r, "X-Auth-Token", fake.TokenID) |
| th.TestHeader(t, r, "Accept", "application/json") |
| |
| w.Header().Set("Content-Type", "application/json") |
| w.WriteHeader(http.StatusOK) |
| fmt.Fprintf(w, output) |
| }) |
| } |