summaryrefslogtreecommitdiffhomepage
path: root/onevent/hook/hook_test.go
blob: a67abf0f70d339faa00117ad13319bfa30a003a5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
package hook

import (
	"os"
	"path/filepath"
	"strconv"
	"testing"
	"time"

	"github.com/google/uuid"
	"github.com/mholt/caddy"
)

func TestHook(t *testing.T) {
	tempDirPath := os.TempDir()

	testDir := filepath.Join(tempDirPath, "temp_dir_for_testing_command")
	defer func() {
		// clean up after non-blocking startup function quits
		time.Sleep(500 * time.Millisecond)
		os.RemoveAll(testDir)
	}()
	osSensitiveTestDir := filepath.FromSlash(testDir)
	os.RemoveAll(osSensitiveTestDir) // start with a clean slate

	tests := []struct {
		name            string
		event           caddy.EventName
		command         string
		args            []string
		shouldErr       bool
		shouldRemoveErr bool
	}{
		{name: "blocking", event: caddy.InstanceStartupEvent, command: "mkdir", args: []string{osSensitiveTestDir}, shouldErr: false, shouldRemoveErr: false},
		{name: "nonBlocking", event: caddy.ShutdownEvent, command: "mkdir", args: []string{osSensitiveTestDir, "&"}, shouldErr: false, shouldRemoveErr: true},
		{name: "nonBlocking2", event: caddy.ShutdownEvent, command: "echo", args: []string{"&"}, shouldErr: false, shouldRemoveErr: true},
		{name: "nonExistent", event: caddy.CertRenewEvent, command: strconv.Itoa(int(time.Now().UnixNano())), shouldErr: true, shouldRemoveErr: true},
	}

	for _, test := range tests {
		t.Run(test.name, func(t *testing.T) {
			cfg := new(Config)
			cfg.ID = uuid.New().String()
			cfg.Event = test.event
			cfg.Command = test.command
			cfg.Args = test.args

			err := cfg.Hook(test.event, nil)
			if err == nil && test.shouldErr {
				t.Error("Test didn't error, but it should have")
			} else if err != nil && !test.shouldErr {
				t.Errorf("Test errored, but it shouldn't have; got '%v'", err)
			}

			err = os.Remove(osSensitiveTestDir)
			if err != nil && !test.shouldRemoveErr {
				t.Errorf("Test received an error of:\n%v", err)
			}
		})
	}
}