選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。
 
 
 

136 行
3.2 KiB

  1. // Copyright 2012 The Go Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style
  3. // license that can be found in the LICENSE file.
  4. // +build windows
  5. package svc_test
  6. import (
  7. "fmt"
  8. "io/ioutil"
  9. "math/rand"
  10. "os"
  11. "os/exec"
  12. "path/filepath"
  13. "strings"
  14. "testing"
  15. "time"
  16. "golang.org/x/sys/windows/svc"
  17. "golang.org/x/sys/windows/svc/mgr"
  18. )
  19. func getState(t *testing.T, s *mgr.Service) svc.State {
  20. status, err := s.Query()
  21. if err != nil {
  22. t.Fatalf("Query(%s) failed: %s", s.Name, err)
  23. }
  24. return status.State
  25. }
  26. func testState(t *testing.T, s *mgr.Service, want svc.State) {
  27. have := getState(t, s)
  28. if have != want {
  29. t.Fatalf("%s state is=%d want=%d", s.Name, have, want)
  30. }
  31. }
  32. func waitState(t *testing.T, s *mgr.Service, want svc.State) {
  33. for i := 0; ; i++ {
  34. have := getState(t, s)
  35. if have == want {
  36. return
  37. }
  38. if i > 10 {
  39. t.Fatalf("%s state is=%d, waiting timeout", s.Name, have)
  40. }
  41. time.Sleep(300 * time.Millisecond)
  42. }
  43. }
  44. func TestExample(t *testing.T) {
  45. if testing.Short() {
  46. t.Skip("skipping test in short mode - it modifies system services")
  47. }
  48. const name = "myservice"
  49. m, err := mgr.Connect()
  50. if err != nil {
  51. t.Fatalf("SCM connection failed: %s", err)
  52. }
  53. defer m.Disconnect()
  54. dir, err := ioutil.TempDir("", "svc")
  55. if err != nil {
  56. t.Fatalf("failed to create temp directory: %v", err)
  57. }
  58. defer os.RemoveAll(dir)
  59. exepath := filepath.Join(dir, "a.exe")
  60. o, err := exec.Command("go", "build", "-o", exepath, "golang.org/x/sys/windows/svc/example").CombinedOutput()
  61. if err != nil {
  62. t.Fatalf("failed to build service program: %v\n%v", err, string(o))
  63. }
  64. s, err := m.OpenService(name)
  65. if err == nil {
  66. err = s.Delete()
  67. if err != nil {
  68. s.Close()
  69. t.Fatalf("Delete failed: %s", err)
  70. }
  71. s.Close()
  72. }
  73. s, err = m.CreateService(name, exepath, mgr.Config{DisplayName: "my service"}, "is", "auto-started")
  74. if err != nil {
  75. t.Fatalf("CreateService(%s) failed: %v", name, err)
  76. }
  77. defer s.Close()
  78. args := []string{"is", "manual-started", fmt.Sprintf("%d", rand.Int())}
  79. testState(t, s, svc.Stopped)
  80. err = s.Start(args...)
  81. if err != nil {
  82. t.Fatalf("Start(%s) failed: %s", s.Name, err)
  83. }
  84. waitState(t, s, svc.Running)
  85. time.Sleep(1 * time.Second)
  86. // testing deadlock from issues 4.
  87. _, err = s.Control(svc.Interrogate)
  88. if err != nil {
  89. t.Fatalf("Control(%s) failed: %s", s.Name, err)
  90. }
  91. _, err = s.Control(svc.Interrogate)
  92. if err != nil {
  93. t.Fatalf("Control(%s) failed: %s", s.Name, err)
  94. }
  95. time.Sleep(1 * time.Second)
  96. _, err = s.Control(svc.Stop)
  97. if err != nil {
  98. t.Fatalf("Control(%s) failed: %s", s.Name, err)
  99. }
  100. waitState(t, s, svc.Stopped)
  101. err = s.Delete()
  102. if err != nil {
  103. t.Fatalf("Delete failed: %s", err)
  104. }
  105. cmd := `Get-Eventlog -LogName Application -Newest 100` +
  106. ` | Where Source -eq "myservice"` +
  107. ` | Select -first 10` +
  108. ` | Format-table -HideTableHeaders -property ReplacementStrings`
  109. out, err := exec.Command("powershell", "-Command", cmd).CombinedOutput()
  110. if err != nil {
  111. t.Fatalf("powershell failed: %v\n%v", err, string(out))
  112. }
  113. if want := strings.Join(append([]string{name}, args...), "-"); !strings.Contains(string(out), want) {
  114. t.Errorf("%q string does not contain %q", string(out), want)
  115. }
  116. }