mirror of
				https://github.com/optim-enterprises-bv/vault.git
				synced 2025-11-01 02:57:59 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			57 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package http
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"net"
 | |
| 	"net/http"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/hashicorp/vault/vault"
 | |
| )
 | |
| 
 | |
| func TestListener(t *testing.T) (net.Listener, string) {
 | |
| 	fail := func(format string, args ...interface{}) {
 | |
| 		panic(fmt.Sprintf(format, args...))
 | |
| 	}
 | |
| 	if t != nil {
 | |
| 		fail = t.Fatalf
 | |
| 	}
 | |
| 
 | |
| 	ln, err := net.Listen("tcp", "127.0.0.1:0")
 | |
| 	if err != nil {
 | |
| 		fail("err: %s", err)
 | |
| 	}
 | |
| 	addr := "http://" + ln.Addr().String()
 | |
| 	return ln, addr
 | |
| }
 | |
| 
 | |
| func TestServerWithListener(t *testing.T, ln net.Listener, addr string, core *vault.Core) {
 | |
| 	// Create a muxer to handle our requests so that we can authenticate
 | |
| 	// for tests.
 | |
| 	mux := http.NewServeMux()
 | |
| 	mux.Handle("/_test/auth", http.HandlerFunc(testHandleAuth))
 | |
| 	mux.Handle("/", Handler(core))
 | |
| 
 | |
| 	server := &http.Server{
 | |
| 		Addr:    ln.Addr().String(),
 | |
| 		Handler: mux,
 | |
| 	}
 | |
| 	go server.Serve(ln)
 | |
| }
 | |
| 
 | |
| func TestServer(t *testing.T, core *vault.Core) (net.Listener, string) {
 | |
| 	ln, addr := TestListener(t)
 | |
| 	TestServerWithListener(t, ln, addr, core)
 | |
| 	return ln, addr
 | |
| }
 | |
| 
 | |
| func TestServerAuth(t *testing.T, addr string, token string) {
 | |
| 	if _, err := http.Get(addr + "/_test/auth?token=" + token); err != nil {
 | |
| 		t.Fatalf("error authenticating: %s", err)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func testHandleAuth(w http.ResponseWriter, req *http.Request) {
 | |
| 	respondOk(w, nil)
 | |
| }
 | 
