| 239 | } |
| 240 | |
| 241 | func TestNewHTTPClientCert(t *testing.T) { |
| 242 | server := httptest.NewUnstartedServer( |
| 243 | http.HandlerFunc( |
| 244 | func(w http.ResponseWriter, _ *http.Request) { |
| 245 | w.Header().Set("Content-Type", `text/plain; version=0.0.4`) |
| 246 | w.Write([]byte{}) |
| 247 | }, |
| 248 | ), |
| 249 | ) |
| 250 | tlsConfig := newTLSConfig("server", t) |
| 251 | tlsConfig.ClientAuth = tls.RequireAndVerifyClientCert |
| 252 | tlsConfig.ClientCAs = tlsConfig.RootCAs |
| 253 | server.TLS = tlsConfig |
| 254 | server.StartTLS() |
| 255 | defer server.Close() |
| 256 | |
| 257 | cfg := config_util.HTTPClientConfig{ |
| 258 | TLSConfig: config_util.TLSConfig{ |
| 259 | CAFile: caCertPath, |
| 260 | CertFile: "testdata/client.cer", |
| 261 | KeyFile: "testdata/client.key", |
| 262 | }, |
| 263 | } |
| 264 | c, err := config_util.NewClientFromConfig(cfg, "test") |
| 265 | require.NoError(t, err) |
| 266 | _, err = c.Get(server.URL) |
| 267 | require.NoError(t, err) |
| 268 | } |
| 269 | |
| 270 | func TestNewHTTPWithServerName(t *testing.T) { |
| 271 | server := httptest.NewUnstartedServer( |