mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-04 12:47:36 +03:00
properly close the UDP proxy used in the integration tests
This commit is contained in:
parent
6322412eb8
commit
b1095d0661
2 changed files with 44 additions and 0 deletions
|
@ -137,6 +137,13 @@ func NewQuicProxy(local string, version protocol.VersionNumber, opts *Opts) (*Qu
|
||||||
|
|
||||||
// Close stops the UDP Proxy
|
// Close stops the UDP Proxy
|
||||||
func (p *QuicProxy) Close() error {
|
func (p *QuicProxy) Close() error {
|
||||||
|
p.mutex.Lock()
|
||||||
|
defer p.mutex.Unlock()
|
||||||
|
for _, c := range p.clientDict {
|
||||||
|
if err := c.ServerConn.Close(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
return p.conn.Close()
|
return p.conn.Close()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,9 @@ package quicproxy
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"net"
|
"net"
|
||||||
|
"runtime/pprof"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
"strings"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -47,9 +49,16 @@ var _ = Describe("QUIC Proxy", func() {
|
||||||
})
|
})
|
||||||
|
|
||||||
It("stops the UDPProxy", func() {
|
It("stops the UDPProxy", func() {
|
||||||
|
isProxyRunning := func() bool {
|
||||||
|
var b bytes.Buffer
|
||||||
|
pprof.Lookup("goroutine").WriteTo(&b, 1)
|
||||||
|
return strings.Contains(b.String(), "proxy.(*QuicProxy).runProxy")
|
||||||
|
}
|
||||||
|
|
||||||
proxy, err := NewQuicProxy("localhost:0", protocol.VersionWhatever, nil)
|
proxy, err := NewQuicProxy("localhost:0", protocol.VersionWhatever, nil)
|
||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
port := proxy.LocalPort()
|
port := proxy.LocalPort()
|
||||||
|
Expect(isProxyRunning()).To(BeTrue())
|
||||||
err = proxy.Close()
|
err = proxy.Close()
|
||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
|
||||||
|
@ -65,6 +74,34 @@ var _ = Describe("QUIC Proxy", func() {
|
||||||
ln.Close()
|
ln.Close()
|
||||||
return nil
|
return nil
|
||||||
}).ShouldNot(HaveOccurred())
|
}).ShouldNot(HaveOccurred())
|
||||||
|
Eventually(isProxyRunning).Should(BeFalse())
|
||||||
|
})
|
||||||
|
|
||||||
|
It("stops listening for proxied connections", func() {
|
||||||
|
isConnRunning := func() bool {
|
||||||
|
var b bytes.Buffer
|
||||||
|
pprof.Lookup("goroutine").WriteTo(&b, 1)
|
||||||
|
return strings.Contains(b.String(), "proxy.(*QuicProxy).runConnection")
|
||||||
|
}
|
||||||
|
|
||||||
|
serverAddr, err := net.ResolveUDPAddr("udp", "localhost:0")
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
serverConn, err := net.ListenUDP("udp", serverAddr)
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
defer serverConn.Close()
|
||||||
|
|
||||||
|
proxy, err := NewQuicProxy("localhost:0", protocol.VersionWhatever, &Opts{RemoteAddr: serverConn.LocalAddr().String()})
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
Expect(isConnRunning()).To(BeFalse())
|
||||||
|
|
||||||
|
// check that the proxy port is not in use anymore
|
||||||
|
conn, err := net.DialUDP("udp", nil, proxy.LocalAddr().(*net.UDPAddr))
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
_, err = conn.Write(makePacket(1, []byte("foobar")))
|
||||||
|
Expect(err).ToNot(HaveOccurred())
|
||||||
|
Eventually(isConnRunning).Should(BeTrue())
|
||||||
|
Expect(proxy.Close()).To(Succeed())
|
||||||
|
Eventually(isConnRunning).Should(BeFalse())
|
||||||
})
|
})
|
||||||
|
|
||||||
It("has the correct LocalAddr and LocalPort", func() {
|
It("has the correct LocalAddr and LocalPort", func() {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue