本文整理匯總了Golang中launchpad/net/gwacl.NewDispatcherResponse函數的典型用法代碼示例。如果您正苦於以下問題:Golang NewDispatcherResponse函數的具體用法?Golang NewDispatcherResponse怎麽用?Golang NewDispatcherResponse使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了NewDispatcherResponse函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestAttemptCreateServiceCreatesService
func (*environSuite) TestAttemptCreateServiceCreatesService(c *C) {
prefix := "myservice"
affinityGroup := "affinity-group"
location := "location"
responses := []gwacl.DispatcherResponse{
gwacl.NewDispatcherResponse(makeAvailabilityResponse(c), http.StatusOK, nil),
gwacl.NewDispatcherResponse(nil, http.StatusOK, nil),
}
requests := gwacl.PatchManagementAPIResponses(responses)
azure, err := gwacl.NewManagementAPI("subscription", "", "West US")
c.Assert(err, IsNil)
service, err := attemptCreateService(azure, prefix, affinityGroup, location)
c.Assert(err, IsNil)
c.Assert(*requests, HasLen, 2)
body := parseCreateServiceRequest(c, (*requests)[1])
c.Check(body.ServiceName, Equals, service.ServiceName)
c.Check(body.AffinityGroup, Equals, affinityGroup)
c.Check(service.ServiceName, Matches, prefix+".*")
c.Check(service.Location, Equals, location)
label, err := base64.StdEncoding.DecodeString(service.Label)
c.Assert(err, IsNil)
c.Check(string(label), Equals, service.ServiceName)
}
示例2: preparePortChangeConversation
func preparePortChangeConversation(
c *C, service *gwacl.HostedServiceDescriptor,
deployments ...gwacl.Deployment) []gwacl.DispatcherResponse {
// Construct the series of responses to expected requests.
responses := []gwacl.DispatcherResponse{
// First, GetHostedServiceProperties
gwacl.NewDispatcherResponse(
serialize(c, &gwacl.HostedService{
Deployments: deployments,
HostedServiceDescriptor: *service,
XMLNS: gwacl.XMLNS,
}),
http.StatusOK, nil),
}
for _, deployment := range deployments {
for _, role := range deployment.RoleList {
// GetRole returns a PersistentVMRole.
persistentRole := &gwacl.PersistentVMRole{
XMLNS: gwacl.XMLNS,
RoleName: role.RoleName,
ConfigurationSets: role.ConfigurationSets,
}
responses = append(responses, gwacl.NewDispatcherResponse(
serialize(c, persistentRole), http.StatusOK, nil))
// UpdateRole expects a 200 response, that's all.
responses = append(responses,
gwacl.NewDispatcherResponse(nil, http.StatusOK, nil))
}
}
return responses
}
示例3: TestDestroyVirtualNetwork
func (*EnvironSuite) TestDestroyVirtualNetwork(c *C) {
env := makeEnviron(c)
// Prepare a configuration with a single virtual network.
existingConfig := &gwacl.NetworkConfiguration{
XMLNS: gwacl.XMLNS_NC,
VirtualNetworkSites: &[]gwacl.VirtualNetworkSite{
{Name: env.getVirtualNetworkName()},
},
}
body, err := existingConfig.Serialize()
c.Assert(err, IsNil)
responses := []gwacl.DispatcherResponse{
// Return existing configuration.
gwacl.NewDispatcherResponse([]byte(body), http.StatusOK, nil),
// Accept upload of new configuration.
gwacl.NewDispatcherResponse(nil, http.StatusOK, nil),
}
requests := gwacl.PatchManagementAPIResponses(responses)
env.deleteVirtualNetwork()
c.Assert(*requests, HasLen, 2)
// One request to get the existing network configuration.
getRequest := (*requests)[0]
c.Check(getRequest.Method, Equals, "GET")
// One request to update the network configuration.
putRequest := (*requests)[1]
c.Check(putRequest.Method, Equals, "PUT")
newConfig := gwacl.NetworkConfiguration{}
err = xml.Unmarshal(putRequest.Payload, &newConfig)
c.Assert(err, IsNil)
// The new configuration has no VirtualNetworkSites.
c.Check(newConfig.VirtualNetworkSites, IsNil)
}
示例4: buildDestroyAzureServiceResponses
// buildDestroyAzureServiceResponses returns a slice containing the responses that a fake Azure server
// can use to simulate the deletion of the given list of services.
func buildDestroyAzureServiceResponses(c *C, services []*gwacl.HostedService) []gwacl.DispatcherResponse {
responses := []gwacl.DispatcherResponse{}
for _, service := range services {
// When destroying a hosted service, gwacl first issues a Get request
// to fetch the properties of the services. Then it destroys all the
// deployments found in this service (none in this case, we make sure
// the service does not contain deployments to keep the testing simple)
// And it finally deletes the service itself.
if len(service.Deployments) != 0 {
panic("buildDestroyAzureServiceResponses does not support services with deployments!")
}
serviceXML, err := service.Serialize()
c.Assert(err, IsNil)
serviceGetResponse := gwacl.NewDispatcherResponse(
[]byte(serviceXML),
http.StatusOK,
nil,
)
responses = append(responses, serviceGetResponse)
serviceDeleteResponse := gwacl.NewDispatcherResponse(
nil,
http.StatusOK,
nil,
)
responses = append(responses, serviceDeleteResponse)
}
return responses
}
示例5: TestAttemptCreateServicePropagatesOtherFailure
func (*environSuite) TestAttemptCreateServicePropagatesOtherFailure(c *C) {
responses := []gwacl.DispatcherResponse{
gwacl.NewDispatcherResponse(makeAvailabilityResponse(c), http.StatusOK, nil),
gwacl.NewDispatcherResponse(nil, http.StatusNotFound, nil),
}
gwacl.PatchManagementAPIResponses(responses)
azure, err := gwacl.NewManagementAPI("subscription", "", "West US")
c.Assert(err, IsNil)
_, err = attemptCreateService(azure, "service", "affinity-group", "location")
c.Assert(err, NotNil)
c.Check(err, ErrorMatches, ".*Not Found.*")
}
示例6: preparePortChangeConversation
func preparePortChangeConversation(c *gc.C, role *gwacl.Role) []gwacl.DispatcherResponse {
persistentRole := &gwacl.PersistentVMRole{
XMLNS: gwacl.XMLNS,
RoleName: role.RoleName,
ConfigurationSets: role.ConfigurationSets,
}
return []gwacl.DispatcherResponse{
// GetRole returns a PersistentVMRole.
gwacl.NewDispatcherResponse(serialize(c, persistentRole), http.StatusOK, nil),
// UpdateRole expects a 200 response, that's all.
gwacl.NewDispatcherResponse(nil, http.StatusOK, nil),
}
}
示例7: getVnetAndAffinityGroupCleanupResponses
// getVnetAndAffinityGroupCleanupResponses returns the responses
// (gwacl.DispatcherResponse) that a fake http server should return
// when gwacl's RemoveVirtualNetworkSite() and DeleteAffinityGroup()
// are called.
func getVnetAndAffinityGroupCleanupResponses(c *C) []gwacl.DispatcherResponse {
existingConfig := &gwacl.NetworkConfiguration{
XMLNS: gwacl.XMLNS_NC,
VirtualNetworkSites: nil,
}
body, err := existingConfig.Serialize()
c.Assert(err, IsNil)
cleanupResponses := []gwacl.DispatcherResponse{
// Return empty net configuration.
gwacl.NewDispatcherResponse([]byte(body), http.StatusOK, nil),
// Accept deletion of affinity group.
gwacl.NewDispatcherResponse(nil, http.StatusOK, nil),
}
return cleanupResponses
}
示例8: TestStopInstancesWhenStoppingMachinesFails
func (*environSuite) TestStopInstancesWhenStoppingMachinesFails(c *C) {
cleanup := setServiceDeletionConcurrency(3)
defer cleanup()
responses := []gwacl.DispatcherResponse{
gwacl.NewDispatcherResponse(nil, http.StatusConflict, nil),
}
service1Name := "service1"
_, service1Desc := makeAzureService(service1Name)
service2Name := "service2"
service2, service2Desc := makeAzureService(service2Name)
services := []*gwacl.HostedService{service2}
destroyResponses := buildDestroyAzureServiceResponses(c, services)
responses = append(responses, destroyResponses...)
requests := gwacl.PatchManagementAPIResponses(responses)
env := makeEnviron(c)
instances := convertToInstances(
[]gwacl.HostedServiceDescriptor{*service1Desc, *service2Desc}, env)
err := env.StopInstances(instances)
c.Check(err, ErrorMatches, ".*Conflict.*")
c.Check(len(*requests), Equals, 3)
assertOneRequestMatches(c, *requests, "GET", ".*"+service1Name+".")
assertOneRequestMatches(c, *requests, "GET", ".*"+service2Name+".")
// Only one of the services was deleted.
assertOneRequestMatches(c, *requests, "DELETE", ".*")
}
示例9: TestListVolumes
func (s *azureVolumeSuite) TestListVolumes(c *gc.C) {
vs := s.volumeSource(c, nil)
type disks struct {
Disks []gwacl.Disk `xml:"Disk"`
}
listDisksResponse, err := xml.Marshal(&disks{Disks: []gwacl.Disk{{
MediaLink: mediaLinkPrefix + "volume-1.vhd",
LogicalSizeInGB: 22,
}, {
MediaLink: mediaLinkPrefix + "volume-0.vhd",
LogicalSizeInGB: 11,
}, {
MediaLink: "someOtherJunk.vhd",
LogicalSizeInGB: 33,
}}})
c.Assert(err, jc.ErrorIsNil)
gwacl.PatchManagementAPIResponses([]gwacl.DispatcherResponse{
gwacl.NewDispatcherResponse(listDisksResponse, http.StatusOK, nil),
})
volIds, err := vs.ListVolumes()
c.Assert(err, jc.ErrorIsNil)
c.Assert(volIds, jc.SameContents, []string{"volume-0.vhd", "volume-1.vhd"})
}
示例10: TestAttachVolumesNotAttached
func (s *azureVolumeSuite) TestAttachVolumesNotAttached(c *gc.C) {
vs := s.volumeSource(c, nil)
machine := names.NewMachineTag("0")
volume := names.NewVolumeTag("0")
env := makeEnviron(c)
prefix := env.getEnvPrefix()
service := makeDeployment(env, prefix+"service")
roleName := service.Deployments[0].RoleList[0].RoleName
inst, err := env.getInstance(service, roleName)
c.Assert(err, jc.ErrorIsNil)
getRoleResponse, err := xml.Marshal(&gwacl.PersistentVMRole{})
c.Assert(err, jc.ErrorIsNil)
gwacl.PatchManagementAPIResponses([]gwacl.DispatcherResponse{
gwacl.NewDispatcherResponse(getRoleResponse, http.StatusOK, nil),
})
results, err := vs.AttachVolumes([]storage.VolumeAttachmentParams{{
Volume: volume,
VolumeId: "volume-0.vhd",
AttachmentParams: storage.AttachmentParams{
Machine: machine,
InstanceId: inst.Id(),
},
}})
c.Assert(err, jc.ErrorIsNil)
c.Assert(results, gc.HasLen, 1)
c.Assert(results[0].Error, gc.ErrorMatches, "attaching volumes not supported")
}
示例11: prepareDeploymentInfoResponse
func prepareDeploymentInfoResponse(
c *gc.C, dep gwacl.Deployment) []gwacl.DispatcherResponse {
return []gwacl.DispatcherResponse{
gwacl.NewDispatcherResponse(
serialize(c, &dep), http.StatusOK, nil),
}
}
示例12: TestNewHostedServiceRetriesIfNotUnique
func (*environSuite) TestNewHostedServiceRetriesIfNotUnique(c *C) {
errorBody := makeNonAvailabilityResponse(c)
okBody := makeAvailabilityResponse(c)
// In this scenario, the first two names that we try are already
// taken. The third one is unique though, so we succeed.
responses := []gwacl.DispatcherResponse{
gwacl.NewDispatcherResponse(errorBody, http.StatusOK, nil),
gwacl.NewDispatcherResponse(errorBody, http.StatusOK, nil),
gwacl.NewDispatcherResponse(okBody, http.StatusOK, nil),
gwacl.NewDispatcherResponse(nil, http.StatusOK, nil),
}
requests := gwacl.PatchManagementAPIResponses(responses)
azure, err := gwacl.NewManagementAPI("subscription", "", "West US")
c.Assert(err, IsNil)
service, err := newHostedService(azure, "service", "affinity-group", "location")
c.Check(err, IsNil)
c.Assert(*requests, HasLen, 4)
// How many names have been attempted, and how often?
// There is a minute chance that this tries the same name twice, and
// then this test will fail. If that happens, try seeding the
// randomizer with some fixed seed that doens't produce the problem.
attemptedNames := make(map[string]int)
for _, request := range *requests {
// Exit the loop if we hit the request to create the service, it comes
// after the check calls.
if request.Method == "POST" {
break
}
// Name is the last part of the URL from the GET requests that check
// availability.
_, name := path.Split(strings.TrimRight(request.URL, "/"))
attemptedNames[name] += 1
}
// The three attempts we just made all had different service names.
c.Check(attemptedNames, HasLen, 3)
// Once newHostedService succeeds, we get a hosted service with the
// last requested name.
c.Check(
service.ServiceName,
Equals,
parseCreateServiceRequest(c, (*requests)[3]).ServiceName)
}
示例13: TestDestroyDeletesVirtualNetworkAndAffinityGroup
func (*environSuite) TestDestroyDeletesVirtualNetworkAndAffinityGroup(c *C) {
env := makeEnviron(c)
cleanup := setDummyStorage(c, env)
defer cleanup()
services := []gwacl.HostedServiceDescriptor{}
responses := getAzureServiceListResponse(c, services)
// Prepare a configuration with a single virtual network.
existingConfig := &gwacl.NetworkConfiguration{
XMLNS: gwacl.XMLNS_NC,
VirtualNetworkSites: &[]gwacl.VirtualNetworkSite{
{Name: env.getVirtualNetworkName()},
},
}
body, err := existingConfig.Serialize()
c.Assert(err, IsNil)
cleanupResponses := []gwacl.DispatcherResponse{
// Return existing configuration.
gwacl.NewDispatcherResponse([]byte(body), http.StatusOK, nil),
// Accept upload of new configuration.
gwacl.NewDispatcherResponse(nil, http.StatusOK, nil),
// Accept deletion of affinity group.
gwacl.NewDispatcherResponse(nil, http.StatusOK, nil),
}
responses = append(responses, cleanupResponses...)
requests := gwacl.PatchManagementAPIResponses(responses)
instances := convertToInstances([]gwacl.HostedServiceDescriptor{}, env)
err = env.Destroy(instances)
c.Check(err, IsNil)
c.Assert(*requests, HasLen, 4)
// One request to get the network configuration.
getRequest := (*requests)[1]
c.Check(getRequest.Method, Equals, "GET")
c.Check(strings.HasSuffix(getRequest.URL, "services/networking/media"), Equals, true)
// One request to upload the new version of the network configuration.
putRequest := (*requests)[2]
c.Check(putRequest.Method, Equals, "PUT")
c.Check(strings.HasSuffix(putRequest.URL, "services/networking/media"), Equals, true)
// One request to delete the Affinity Group.
agRequest := (*requests)[3]
c.Check(strings.Contains(agRequest.URL, env.getAffinityGroupName()), IsTrue)
c.Check(agRequest.Method, Equals, "DELETE")
}
示例14: getAzureServiceResponses
// getAzureServiceResponses returns the slice of responses
// (gwacl.DispatcherResponse) which correspond to the API requests used to
// get the properties of a Service.
func getAzureServiceResponses(c *C, service gwacl.HostedService) []gwacl.DispatcherResponse {
serviceXML, err := service.Serialize()
c.Assert(err, IsNil)
responses := []gwacl.DispatcherResponse{gwacl.NewDispatcherResponse(
[]byte(serviceXML),
http.StatusOK,
nil,
)}
return responses
}
示例15: getAzureServiceListResponse
func getAzureServiceListResponse(c *C, services []gwacl.HostedServiceDescriptor) []gwacl.DispatcherResponse {
list := gwacl.HostedServiceDescriptorList{HostedServices: services}
listXML, err := list.Serialize()
c.Assert(err, IsNil)
responses := []gwacl.DispatcherResponse{gwacl.NewDispatcherResponse(
[]byte(listXML),
http.StatusOK,
nil,
)}
return responses
}