forked from knative/serving
-
Notifications
You must be signed in to change notification settings - Fork 0
/
cleanup.go
70 lines (59 loc) · 1.66 KB
/
cleanup.go
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
62
63
64
65
66
67
68
69
70
/*
Copyright 2018 The Knative Authors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// cleanup allows you to define a cleanup function that will be executed
// if your test is interrupted.
package test
import (
"os"
"os/signal"
"sync"
)
func init() {
c := make(chan os.Signal, 1)
signal.Notify(c, os.Interrupt)
go cleanupOnInterrupt(c)
}
var cf struct {
o sync.Once
m sync.RWMutex
f []func()
}
// cleanupOnInterrupt registers a signal handler and will execute a stack of functions if an interrupt signal is caught
func cleanupOnInterrupt(c chan os.Signal) {
for range c {
cf.o.Do(func() {
cf.m.RLock()
defer cf.m.RUnlock()
for i := len(cf.f) - 1; i >= 0; i-- {
cf.f[i]()
}
os.Exit(1)
})
}
}
// CleanupOnInterrupt stores cleanup functions to execute if an interrupt signal is caught
func CleanupOnInterrupt(cleanup func()) {
cf.m.Lock()
defer cf.m.Unlock()
cf.f = append(cf.f, cleanup)
}
// TearDown will delete created names using clients.
func TearDown(clients *Clients, names ResourceNames) {
if clients != nil && clients.ServingClient != nil {
clients.ServingClient.Delete(
[]string{names.Route},
[]string{names.Config},
[]string{names.Service},
)
}
}