本文整理匯總了Golang中github.com/toliaqat/photon-controller/cli/photon/mocks.NewTestServer函數的典型用法代碼示例。如果您正苦於以下問題:Golang NewTestServer函數的具體用法?Golang NewTestServer怎麽用?Golang NewTestServer使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了NewTestServer函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestShow
func TestShow(t *testing.T) {
authInfo := photon.AuthInfo{}
response, err := json.Marshal(authInfo)
if err != nil {
t.Error("Not expecting error serializing expected status")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"GET",
server.URL+"/auth",
mocks.CreateResponder(200, string(response[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
set := flag.NewFlagSet("test", 0)
cxt := cli.NewContext(nil, set, nil)
err = show(cxt)
if err != nil {
t.Error(err)
}
}
示例2: TestShowPhysicalNetwork
func TestShowPhysicalNetwork(t *testing.T) {
expectedStruct := photon.Subnet{
ID: "network_id",
Name: "network_name",
PortGroups: []string{"port", "group"},
IsDefault: false,
}
response, err := json.Marshal(expectedStruct)
if err != nil {
t.Error("Not expecting error serializing expected response")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"GET",
server.URL+"/subnets/"+expectedStruct.ID,
mocks.CreateResponder(200, string(response[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{expectedStruct.ID})
cxt := cli.NewContext(nil, set, nil)
err = showPhysicalNetwork(cxt, os.Stdout)
if err != nil {
t.Error("Error showing networks: " + err.Error())
}
}
示例3: TestShowAvailabilityZone
func TestShowAvailabilityZone(t *testing.T) {
expectedStruct := photon.AvailabilityZone{
ID: "availabilityzone_id",
Name: "availabilityzone_name",
}
response, err := json.Marshal(expectedStruct)
if err != nil {
t.Error("Not expecting error serializaing expected response")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"GET",
server.URL+"/availabilityzones/"+expectedStruct.ID,
mocks.CreateResponder(200, string(response[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{expectedStruct.ID})
cxt := cli.NewContext(nil, set, nil)
err = showAvailabilityZone(cxt, os.Stdout)
if err != nil {
t.Error("Not expecting show availabilityzone to fail: " + err.Error())
}
}
示例4: TestEnableClusterType
func TestEnableClusterType(t *testing.T) {
deploymentId := "deployment1"
queuedTask := &photon.Task{
Operation: "CONFIGURE_CLUSTER",
State: "QUEUED",
Entity: photon.Entity{ID: deploymentId},
}
completedTask := &photon.Task{
Operation: "CONFIGURE_CLUSTER",
State: "COMPLETED",
Entity: photon.Entity{ID: deploymentId},
}
response, err := json.Marshal(queuedTask)
if err != nil {
t.Error("Not expecting error during serializing expected queuedTask")
}
taskResponse, err := json.Marshal(completedTask)
if err != nil {
t.Error("Not expecting error during serializing expected completedTask")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"POST",
server.URL+"/deployments/"+deploymentId+"/enable_cluster_type",
mocks.CreateResponder(200, string(response[:])))
mocks.RegisterResponder(
"GET",
server.URL+"/tasks/"+queuedTask.ID,
mocks.CreateResponder(200, string(taskResponse[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
globalSet := flag.NewFlagSet("test", 0)
globalSet.Bool("non-interactive", true, "doc")
globalCtx := cli.NewContext(nil, globalSet, nil)
err = globalSet.Parse([]string{"--non-interactive"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{deploymentId})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
set.String("type", "SWARM", "Cluster type")
set.String("image-id", "abcd", "image id")
cxt := cli.NewContext(nil, set, globalCtx)
err = enableClusterType(cxt)
if err != nil {
t.Error(err)
t.Error("Not expecting deployment list hosts to fail")
}
}
示例5: TestAcquireFloatingIp
func TestAcquireFloatingIp(t *testing.T) {
queuedTask := &photon.Task{
Operation: "ACQUIRE_FLOATING_IP",
State: "QUEUED",
ID: "fake-vm-task-ID",
Entity: photon.Entity{ID: "fake_vm_ID"},
}
completedTask := &photon.Task{
Operation: "ACQUIRE_FLOATING_IP",
State: "COMPLETED",
ID: "fake-vm-task-ID",
Entity: photon.Entity{ID: "fake_vm_ID"},
}
response, err := json.Marshal(queuedTask)
if err != nil {
t.Error("Not expecting error serializing expected queuedTask")
}
taskResponse, err := json.Marshal(completedTask)
if err != nil {
t.Error("Not expecting error serializing expected completedTask")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"POST",
server.URL+"/vms/"+"fake_vm_ID"+"/acquire_floating_ip",
mocks.CreateResponder(200, string(response[:])))
mocks.RegisterResponder(
"GET",
server.URL+"/tasks/"+queuedTask.ID,
mocks.CreateResponder(200, string(taskResponse[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
globalSet := flag.NewFlagSet("test", 0)
globalSet.Bool("non-interactive", true, "doc")
globalCtx := cli.NewContext(nil, globalSet, nil)
err = globalSet.Parse([]string{"--non-interactive"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{"fake_vm_ID"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
set.String("network_id", "fake_network_id", "network id")
cxt := cli.NewContext(nil, set, globalCtx)
err = acquireFloatingIp(cxt, os.Stdout)
if err != nil {
t.Error("Not expecting error creating VM image: " + err.Error())
}
}
示例6: TestResizeCluster
func TestResizeCluster(t *testing.T) {
queuedTask := &photon.Task{
Operation: "RESIZE_CLUSTER",
State: "QUEUED",
ID: "fake_resize_cluster_task_id",
Entity: photon.Entity{ID: "fake_cluster_id"},
}
queuedTaskResponse, err := json.Marshal(queuedTask)
if err != nil {
t.Error("Not expecting error serializing expected queued task")
}
completedTask := &photon.Task{
Operation: "RESIZE_CLUSTER",
State: "COMPLETED",
ID: "fake_resize_cluster_task_id",
Entity: photon.Entity{ID: "fake_cluster_id"},
}
completedTaskResponse, err := json.Marshal(completedTask)
if err != nil {
t.Error("Not expecting error serializing expected completed task")
}
server := mocks.NewTestServer()
defer server.Close()
mocks.RegisterResponder(
"POST",
server.URL+"/clusters/fake_cluster_id/resize",
mocks.CreateResponder(200, string(queuedTaskResponse[:])))
mocks.RegisterResponder(
"GET",
server.URL+"/tasks/fake_resize_cluster_task_id",
mocks.CreateResponder(200, string(completedTaskResponse[:])))
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
globalSet := flag.NewFlagSet("test", 0)
globalSet.Bool("non-interactive", true, "doc")
globalCtx := cli.NewContext(nil, globalSet, nil)
err = globalSet.Parse([]string{"--non-interactive"})
if err != nil {
t.Error("Not expecting argument parsing to fail")
}
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{"fake_cluster_id", "50"})
if err != nil {
t.Error("Not expecting argument parsing to fail")
}
ctx := cli.NewContext(nil, set, globalCtx)
err = resizeCluster(ctx, os.Stdout)
if err != nil {
t.Error("Not expecting error resizing cluster: " + err.Error())
}
}
示例7: TestListDeploymentHosts
func TestListDeploymentHosts(t *testing.T) {
hostList := MockHostsPage{
Items: []photon.Host{
{
Username: "u",
Password: "p",
Address: "testIP",
Tags: []string{"CLOUD"},
ID: "host-test-id",
State: "COMPLETED",
},
},
NextPageLink: "/fake-next-page-link",
PreviousPageLink: "",
}
response, err := json.Marshal(hostList)
if err != nil {
t.Error("Not expecting error serializing host list")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"GET",
server.URL+"/deployments/1/hosts",
mocks.CreateResponder(200, string(response[:])))
hostList = MockHostsPage{
Items: []photon.Host{},
NextPageLink: "",
PreviousPageLink: "",
}
response, err = json.Marshal(hostList)
if err != nil {
t.Error("Not expecting error serializing expected taskLists")
}
mocks.RegisterResponder(
"GET",
server.URL+"/fake-next-page-link",
mocks.CreateResponder(200, string(response[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{"1"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
cxt := cli.NewContext(nil, set, nil)
err = listDeploymentHosts(cxt, os.Stdout)
if err != nil {
t.Error("Not expecting deployment list hosts to fail")
}
}
示例8: TestVMNetworks
func TestVMNetworks(t *testing.T) {
queuedTask := &photon.Task{
Operation: "GET_NETWORKS",
State: "COMPLETED",
ID: "fake-vm-task-ID",
Entity: photon.Entity{ID: "fake_vm_ID"},
}
taskResponse, err := json.Marshal(queuedTask)
if err != nil {
t.Error("Not expecting error serializaing expected queuedTask")
}
networkMap := make(map[string]interface{})
networkMap["network"] = "VMmgmtNetwork"
networkMap["macAddress"] = "00:0c:29:7a:b4:d5"
networkMap["ipAddress"] = "10.144.121.12"
networkMap["netmask"] = "255.255.252.0"
networkMap["isConnected"] = "true"
networkConnectionMap := make(map[string]interface{})
networkConnectionMap["networkConnections"] = []interface{}{networkMap}
completedTask := &photon.Task{
Operation: "GET_NETWORKS",
State: "COMPLETED",
ResourceProperties: networkConnectionMap,
}
response, err := json.Marshal(completedTask)
if err != nil {
t.Error("Not expecting error serializaing expected completedTask")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"GET",
server.URL+"/vms/"+"fake_vm_ID"+"/subnets",
mocks.CreateResponder(200, string(taskResponse[:])))
mocks.RegisterResponder(
"GET",
server.URL+"/tasks/"+queuedTask.ID,
mocks.CreateResponder(200, string(response[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{"fake_vm_ID"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
cxt := cli.NewContext(nil, set, nil)
err = listVMNetworks(cxt, os.Stdout)
if err != nil {
t.Error("Not expecting error getting vm networks: " + err.Error())
}
}
示例9: TestSetDeploymentSecurityGroups
func TestSetDeploymentSecurityGroups(t *testing.T) {
deploymentId := "deployment1"
queuedTask := &photon.Task{
Operation: "UPDATE_DEPLOYMENT_SECURITY_GROUPS",
State: "QUEUED",
Entity: photon.Entity{ID: deploymentId},
}
completedTask := &photon.Task{
Operation: "UPDATE_DEPLOYMENT_SECURITY_GROUPS",
State: "COMPLETED",
Entity: photon.Entity{ID: deploymentId},
}
response, err := json.Marshal(queuedTask)
if err != nil {
t.Error("Not expecting error during serializing expected queuedTask")
}
taskResponse, err := json.Marshal(completedTask)
if err != nil {
t.Error("Not expecting error during serializing expected completedTask")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"POST",
server.URL+"/deployments/"+deploymentId+"/set_security_groups",
mocks.CreateResponder(200, string(response[:])))
mocks.RegisterResponder(
"GET",
server.URL+"/tasks/"+queuedTask.ID,
mocks.CreateResponder(200, string(taskResponse[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
globalSet := flag.NewFlagSet("test", 0)
globalSet.Bool("non-interactive", true, "doc")
globalCtx := cli.NewContext(nil, globalSet, nil)
err = globalSet.Parse([]string{"--non-interactive"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{deploymentId, "tenant\admingroup"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
cxt := cli.NewContext(nil, set, globalCtx)
err = setDeploymentSecurityGroups(cxt)
if err != nil {
t.Error(err)
t.Error("Not expecting setDeploymentSecurityGroups to fail")
}
}
示例10: TestFlavorTasks
func TestFlavorTasks(t *testing.T) {
taskList := MockTasksPage{
Items: []photon.Task{
{
Operation: "CREATE_FLAVOR",
State: "COMPLETED",
ID: "1",
Entity: photon.Entity{ID: "fake-id", Kind: "flavor"},
},
},
NextPageLink: "/fake-next-page-link",
PreviousPageLink: "",
}
response, err := json.Marshal(taskList)
if err != nil {
t.Error("Not expecting error serializaing expected status")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"GET",
server.URL+"/flavors/fake-id/tasks",
mocks.CreateResponder(200, string(response[:])))
taskList = MockTasksPage{
Items: []photon.Task{},
NextPageLink: "",
PreviousPageLink: "",
}
response, err = json.Marshal(taskList)
if err != nil {
t.Error("Not expecting error serializing expected taskLists")
}
mocks.RegisterResponder(
"GET",
server.URL+"/fake-next-page-link",
mocks.CreateResponder(200, string(response[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{"fake-id"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
cxt := cli.NewContext(nil, set, nil)
err = getFlavorTasks(cxt, os.Stdout)
if err != nil {
t.Error("Not expecting error retrieving tenant tasks")
}
}
示例11: TestSetDefaultVirtualNetwork
func TestSetDefaultVirtualNetwork(t *testing.T) {
completedTask := &photon.Task{
Operation: "SET_DEFAULT_NETWORK",
State: "COMPLETED",
Entity: photon.Entity{ID: "id"},
}
taskresponse, err := json.Marshal(completedTask)
if err != nil {
t.Error("Not expecting error serializing expected completedTask")
}
info := &photon.Info{
NetworkType: SOFTWARE_DEFINED,
}
infoString, err := json.Marshal(info)
if err != nil {
t.Error("Not expecting error when serializing expected info")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"POST",
server.URL+"/subnets/"+completedTask.Entity.ID+"/set_default",
mocks.CreateResponder(200, string(taskresponse[:])))
mocks.RegisterResponder(
"GET",
server.URL+"/tasks/"+completedTask.ID,
mocks.CreateResponder(200, string(taskresponse[:])))
mocks.RegisterResponder(
"GET",
server.URL+"/info",
mocks.CreateResponder(200, string(infoString[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
globalSet := flag.NewFlagSet("test", 0)
globalSet.Bool("non-interactive", true, "doc")
globalCtx := cli.NewContext(nil, globalSet, nil)
err = globalSet.Parse([]string{"--non-interactive"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{completedTask.Entity.ID})
cxt := cli.NewContext(nil, set, globalCtx)
err = setDefaultNetwork(cxt, os.Stdout)
if err != nil {
t.Error("Not expecting set default network to fail", err)
}
}
示例12: TestCreateVirtualSubnet
func TestCreateVirtualSubnet(t *testing.T) {
queuedTask := &photon.Task{
Operation: "CREATE_NETWORK",
State: "QUEUED",
Entity: photon.Entity{ID: "network-ID"},
}
completedTask := &photon.Task{
Operation: "CREATE_NETWORK",
State: "COMPLETED",
Entity: photon.Entity{ID: "network-ID"},
}
response, err := json.Marshal(queuedTask)
if err != nil {
t.Error("Not expecting error serializing expected queuedTask")
}
taskresponse, err := json.Marshal(completedTask)
if err != nil {
t.Error("Not expecting error serializing expected completedTask")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"POST",
server.URL+"/projects/project_id/subnets",
mocks.CreateResponder(200, string(response[:])))
mocks.RegisterResponder(
"GET",
server.URL+"/tasks/"+queuedTask.ID,
mocks.CreateResponder(200, string(taskresponse[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
globalSet := flag.NewFlagSet("test", 0)
globalSet.Bool("non-interactive", true, "doc")
globalCtx := cli.NewContext(nil, globalSet, nil)
err = globalSet.Parse([]string{"--non-interactive"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
set := flag.NewFlagSet("test", 0)
set.String("name", "network_name", "network name")
set.String("routingType", "ROUTED", "routing type")
set.Int("size", 256, "network size")
set.Int("staticIpSize", 0, "reserved static ip size")
set.String("projectId", "project_id", "project ID")
cxt := cli.NewContext(nil, set, globalCtx)
err = createVirtualNetwork(cxt, os.Stdout)
if err != nil {
t.Error("Not expecting create network to fail", err)
}
}
示例13: TestClusterCertToFile
func TestClusterCertToFile(t *testing.T) {
cluster := &photon.Cluster{
Name: "fake_cluster_name",
State: "ERROR",
ID: "fake_cluster_id",
Type: "KUBERNETES",
WorkerCount: 50,
ExtendedProperties: map[string]string{
photon.ExtendedPropertyRegistryCACert: "-----BEGIN CERTIFICATE-----\nMIIFmzCCA4OgAwIBAgIJAIAZmLcInJMeMA0GCSqGSIb3DQEBCwUAMGQxCzAJBgNV\n-----END CERTIFICATE-----",
},
}
clusterResponse, err := json.Marshal(cluster)
if err != nil {
t.Error("Not expecting error serializing expected cluster")
}
server = mocks.NewTestServer()
defer server.Close()
mocks.RegisterResponder(
"GET",
server.URL+"/clusters/"+cluster.ID,
mocks.CreateResponder(200, string(clusterResponse[:])))
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
commandFlags := flag.NewFlagSet("command-flags", flag.ContinueOnError)
err = commandFlags.Parse([]string{"fake_cluster_id", "test.cert"})
if err != nil {
t.Error(err)
}
ctx := cli.NewContext(nil, commandFlags, nil)
err = certToFile(ctx)
if err != nil {
t.Error("Not expecting error for cluster trigger maintenance: " + err.Error())
}
content, err := readCACert("test.cert")
if err != nil {
t.Error("ReadCACert function failed" + err.Error())
}
expected := "-----BEGIN CERTIFICATE-----\nMIIFmzCCA4OgAwIBAgIJAIAZmLcInJMeMA0GCSqGSIb3DQEBCwUAMGQxCzAJBgNV\n-----END CERTIFICATE-----"
if strings.Compare(content, expected) != 0 {
t.Error("expected CACert :" + expected + " actual CACert read:" + content)
}
err = os.Remove("test.cert")
if err != nil {
t.Error("Error deleting test.cert file")
}
}
示例14: TestGetVMMksTicket
func TestGetVMMksTicket(t *testing.T) {
completedTask := &photon.Task{
Operation: "GET_MKS_TICKET",
State: "COMPLETED",
ID: "fake-vm-task-ID",
Entity: photon.Entity{ID: "fake_vm_ID"},
}
response, err := json.Marshal(completedTask)
if err != nil {
t.Error("Not expecting error serializaing expected completedTask")
}
mksMap := make(map[string]interface{})
mksMap["ticket"] = "ticket-id"
mksTask := &photon.Task{
State: "COMPLETED",
ID: "fake-vm-task-ID",
Entity: photon.Entity{ID: "fake_vm_ID"},
ResourceProperties: mksMap,
}
mksresponse, err := json.Marshal(mksTask)
if err != nil {
t.Error("Not expecting error serializaing expected completedTask")
}
server := mocks.NewTestServer()
mocks.RegisterResponder(
"GET",
server.URL+"/vms/"+"fake_vm_ID"+"/mks_ticket",
mocks.CreateResponder(200, string(response[:])))
mocks.RegisterResponder(
"GET",
server.URL+"/tasks/"+completedTask.ID,
mocks.CreateResponder(200, string(mksresponse[:])))
defer server.Close()
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
set := flag.NewFlagSet("test", 0)
err = set.Parse([]string{"fake_vm_ID"})
if err != nil {
t.Error("Not expecting arguments parsing to fail")
}
cxt := cli.NewContext(nil, set, nil)
err = getVMMksTicket(cxt, os.Stdout)
if err != nil {
t.Error("Not expecting error getting vm mks ticket: " + err.Error())
}
}
示例15: TestTargetInfo
func TestTargetInfo(t *testing.T) {
server := mocks.NewTestServer()
defer server.Close()
// We first test that with exactly one deployment, we work as expected.
// This is the expected case in a real installation
err := mockInfo(t, server)
if err != nil {
t.Error("Failed to mock info: " + err.Error())
}
mocks.Activate(true)
httpClient := &http.Client{Transport: mocks.DefaultMockTransport}
client.Esxclient = photon.NewTestClient(server.URL, nil, httpClient)
globalFlags := flag.NewFlagSet("global-flags", flag.ContinueOnError)
globalFlags.String("output", "json", "output")
err = globalFlags.Parse([]string{"--output=json"})
if err != nil {
t.Error(err)
}
globalCtx := cli.NewContext(nil, globalFlags, nil)
commandFlags := flag.NewFlagSet("command-flags", flag.ContinueOnError)
err = commandFlags.Parse([]string{})
if err != nil {
t.Error(err)
}
cxt := cli.NewContext(nil, commandFlags, globalCtx)
var output bytes.Buffer
err = showInfo(cxt, &output)
if err != nil {
t.Error("showInfo ailed unexpectedly: " + err.Error())
}
// Verify we have the fields we expect
err = checkRegExp(`\"baseVersion\":\s*\".*\"`, output)
if err != nil {
t.Errorf("Show info produce a JSON field named 'baseVersion': %s", err)
}
err = checkRegExp(`\"fullVersion\":\s*\".*\"`, output)
if err != nil {
t.Errorf("Show info produce a JSON field named 'fullVersion': %s", err)
}
err = checkRegExp(`\"gitCommitHash\":\s*\".*\"`, output)
if err != nil {
t.Errorf("Show info produce a JSON field named 'gitCommitHash': %s", err)
}
err = checkRegExp(`\"networkType\":\s*\".*\"`, output)
if err != nil {
t.Errorf("Show info produce a JSON field named 'networkType': %s", err)
}
}