e2e-aci.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. package main
  2. import (
  3. "context"
  4. "log"
  5. "strings"
  6. "github.com/Azure/azure-sdk-for-go/profiles/2019-03-01/resources/mgmt/resources"
  7. "github.com/Azure/go-autorest/autorest/to"
  8. . "github.com/onsi/gomega"
  9. "github.com/docker/api/azure"
  10. . "github.com/docker/api/tests/framework"
  11. )
  12. const (
  13. resourceGroupName = "resourceGroupTest"
  14. location = "westeurope"
  15. contextName = "acitest"
  16. testContainerName = "testcontainername"
  17. )
  18. func main() {
  19. SetupTest()
  20. It("ensures context command includes azure-login and aci-create", func() {
  21. output := NewDockerCommand("context", "create", "--help").ExecOrDie()
  22. Expect(output).To(ContainSubstring("docker context create CONTEXT BACKEND [OPTIONS] [flags]"))
  23. Expect(output).To(ContainSubstring("--aci-location"))
  24. Expect(output).To(ContainSubstring("--aci-subscription-id"))
  25. Expect(output).To(ContainSubstring("--aci-resource-group"))
  26. })
  27. It("should be initialized with default context", func() {
  28. _, err := NewCommand("docker", "context", "rm", "-f", contextName).Exec()
  29. if err == nil {
  30. log.Println("Cleaning existing test context")
  31. }
  32. NewCommand("docker", "context", "use", "default").ExecOrDie()
  33. output := NewCommand("docker", "context", "ls").ExecOrDie()
  34. Expect(output).To(Not(ContainSubstring(contextName)))
  35. Expect(output).To(ContainSubstring("default *"))
  36. })
  37. It("creates a new aci context for tests", func() {
  38. setupTestResourceGroup(resourceGroupName)
  39. subscriptionID, err := azure.GetSubscriptionID(context.TODO())
  40. Expect(err).To(BeNil())
  41. NewDockerCommand("context", "create", contextName, "aci", "--aci-subscription-id", subscriptionID, "--aci-resource-group", resourceGroupName, "--aci-location", location).ExecOrDie()
  42. // Expect(output).To(ContainSubstring("ACI context acitest created"))
  43. })
  44. defer deleteResourceGroup(resourceGroupName)
  45. It("uses the aci context", func() {
  46. currentContext := NewCommand("docker", "context", "use", contextName).ExecOrDie()
  47. Expect(currentContext).To(ContainSubstring(contextName))
  48. output := NewCommand("docker", "context", "ls").ExecOrDie()
  49. Expect(output).To(ContainSubstring("acitest *"))
  50. })
  51. It("ensures no container is running initially", func() {
  52. output := NewDockerCommand("ps").ExecOrDie()
  53. Expect(len(Lines(output))).To(Equal(1))
  54. })
  55. It("runs nginx on port 80", func() {
  56. output := NewDockerCommand("run", "nginx", "-p", "80:80", "--name", testContainerName).ExecOrDie()
  57. Expect(output).To(Equal(testContainerName + "\n"))
  58. output = NewDockerCommand("ps").ExecOrDie()
  59. lines := Lines(output)
  60. Expect(len(lines)).To(Equal(2))
  61. containerFields := Columns(lines[1])
  62. Expect(containerFields[1]).To(Equal("nginx"))
  63. Expect(containerFields[2]).To(Equal("Running"))
  64. exposedIP := containerFields[3]
  65. Expect(exposedIP).To(ContainSubstring(":80->80/tcp"))
  66. url := strings.ReplaceAll(exposedIP, "->80/tcp", "")
  67. output = NewCommand("curl", url).ExecOrDie()
  68. Expect(output).To(ContainSubstring("Welcome to nginx!"))
  69. })
  70. It("removes container nginx", func() {
  71. output := NewDockerCommand("rm", testContainerName).ExecOrDie()
  72. Expect(Lines(output)[0]).To(Equal(testContainerName))
  73. })
  74. It("deploys a compose app", func() {
  75. NewDockerCommand("compose", "up", "-f", "./tests/composefiles/aci-demo/aci_demo_port.yaml", "--name", "acidemo").ExecOrDie()
  76. // Expect(output).To(ContainSubstring("Successfully deployed"))
  77. output := NewDockerCommand("ps").ExecOrDie()
  78. Lines := Lines(output)
  79. Expect(len(Lines)).To(Equal(4))
  80. webChecked := false
  81. for _, line := range Lines[1:] {
  82. Expect(line).To(ContainSubstring("Running"))
  83. if strings.Contains(line, "acidemo_web") {
  84. webChecked = true
  85. containerFields := Columns(line)
  86. exposedIP := containerFields[3]
  87. Expect(exposedIP).To(ContainSubstring(":80->80/tcp"))
  88. url := strings.ReplaceAll(exposedIP, "->80/tcp", "")
  89. output = NewCommand("curl", url).ExecOrDie()
  90. Expect(output).To(ContainSubstring("Docker Compose demo"))
  91. output = NewCommand("curl", url+"/words/noun").ExecOrDie()
  92. Expect(output).To(ContainSubstring("\"word\":"))
  93. }
  94. }
  95. Expect(webChecked).To(BeTrue())
  96. })
  97. It("get logs from web service", func() {
  98. output := NewDockerCommand("logs", "acidemo_web").ExecOrDie()
  99. Expect(output).To(ContainSubstring("Listening on port 80"))
  100. })
  101. It("shutdown compose app", func() {
  102. NewDockerCommand("compose", "down", "-f", "./tests/composefiles/aci-demo/aci_demo_port.yaml", "--name", "acidemo").ExecOrDie()
  103. })
  104. It("switches back to default context", func() {
  105. output := NewCommand("docker", "context", "use", "default").ExecOrDie()
  106. Expect(output).To(ContainSubstring("default"))
  107. })
  108. It("deletes test context", func() {
  109. output := NewCommand("docker", "context", "rm", contextName).ExecOrDie()
  110. Expect(output).To(ContainSubstring(contextName))
  111. })
  112. }
  113. func setupTestResourceGroup(groupName string) {
  114. log.Println("Creating resource group " + resourceGroupName)
  115. ctx := context.TODO()
  116. subscriptionID, err := azure.GetSubscriptionID(ctx)
  117. Expect(err).To(BeNil())
  118. gc := azure.GetGroupsClient(subscriptionID)
  119. _, err = gc.CreateOrUpdate(ctx, groupName, resources.Group{
  120. Location: to.StringPtr(location),
  121. })
  122. Expect(err).To(BeNil())
  123. }
  124. func deleteResourceGroup(groupName string) {
  125. log.Println("Deleting resource group " + resourceGroupName)
  126. ctx := context.TODO()
  127. subscriptionID, err := azure.GetSubscriptionID(ctx)
  128. Expect(err).To(BeNil())
  129. gc := azure.GetGroupsClient(subscriptionID)
  130. _, err = gc.Delete(ctx, groupName)
  131. Expect(err).To(BeNil())
  132. }