forked from alphagov/cdn-acceptance-tests
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain_test.go
125 lines (109 loc) · 3.32 KB
/
main_test.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
package main
import (
"crypto/tls"
"flag"
"fmt"
"log"
"net/http"
"os"
"time"
)
var (
backendCert = flag.String("backendCert", "", "Override self-signed cert for backend TLS")
backendKey = flag.String("backendKey", "", "Override self-signed cert, must be provided with -backendCert")
backupPort1 = flag.Int("backupPort1", 8081, "Backup1 port to listen on for requests")
backupPort2 = flag.Int("backupPort2", 8082, "Backup2 port to listen on for requests")
edgeHost = flag.String("edgeHost", "", "Hostname of edge")
originPort = flag.Int("originPort", 8080, "Origin port to listen on for requests")
skipFailover = flag.Bool("skipFailover", false, "Skip failover tests and only setup the origin backend")
skipVerifyTLS = flag.Bool("skipVerifyTLS", false, "Skip TLS cert verification if set")
usage = flag.Bool("usage", false, "Print usage")
vendor = flag.String("vendor", "", "Name of vendor; run tests specific to vendor")
// This only works with tests that use RoundTripCheckError(), that either
// are either failing or run with the -v flag.
debugResp = flag.Bool("debugResp", false, "Log responses for debugging")
)
var (
vendorFastly = false
vendorCloudflare = false
)
// These consts and vars are available to all tests.
const notImplementedForVendor = "Test not yet implemented for your selected vendor or no vendor specified"
const notSupportedByVendor = "Feature not supported by your selected vendor"
const requestSlowThreshold = time.Second
const requestTimeout = time.Second * 5
var (
client *http.Transport
originServer *CDNBackendServer
backupServer1 *CDNBackendServer
backupServer2 *CDNBackendServer
backendsByPriority []*CDNBackendServer
)
// Setup clients and servers.
func init() {
flag.Parse()
if *usage {
flag.Usage()
os.Exit(0)
}
if *edgeHost == "" {
fmt.Printf("ERROR: -edgeHost must be set to the CDN edge hostname we wish to test against\n\n")
flag.Usage()
os.Exit(1)
}
switch *vendor {
case "cloudflare":
vendorCloudflare = true
case "fastly":
vendorFastly = true
case "":
log.Fatalln("No vendor specified; must be either 'cloudflare' or 'fastly'")
default:
log.Fatalf("Vendor %q unrecognised; aborting", *vendor)
}
tlsOptions := &tls.Config{}
if *skipVerifyTLS {
tlsOptions.InsecureSkipVerify = true
}
client = &http.Transport{
ResponseHeaderTimeout: requestTimeout,
TLSClientConfig: tlsOptions,
Dial: NewCachedDial(*edgeHost),
}
var backendCerts []tls.Certificate
if *backendCert != "" || *backendKey != "" {
var err error
backendCerts = make([]tls.Certificate, 1)
backendCerts[0], err = tls.LoadX509KeyPair(*backendCert, *backendKey)
if err != nil {
log.Fatal(err)
}
}
originServer = &CDNBackendServer{
Name: "origin",
Port: *originPort,
TLSCerts: backendCerts,
}
backendsByPriority = []*CDNBackendServer{
originServer,
}
if !*skipFailover {
backupServer1 = &CDNBackendServer{
Name: "backup1",
Port: *backupPort1,
TLSCerts: backendCerts,
}
backupServer2 = &CDNBackendServer{
Name: "backup2",
Port: *backupPort2,
TLSCerts: backendCerts,
}
backendsByPriority = append(
backendsByPriority,
backupServer1,
backupServer2,
)
}
log.Println("Confirming that CDN is healthy")
ResetBackends(backendsByPriority)
}