mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-05 05:07:36 +03:00
Merge pull request #2814 from VinozzZ/master
client: Add DialEarlyContext and DialAddrEarlyContext API
This commit is contained in:
commit
0701ac8059
2 changed files with 45 additions and 2 deletions
28
client.go
28
client.go
|
@ -68,7 +68,18 @@ func DialAddrEarly(
|
||||||
tlsConf *tls.Config,
|
tlsConf *tls.Config,
|
||||||
config *Config,
|
config *Config,
|
||||||
) (EarlySession, error) {
|
) (EarlySession, error) {
|
||||||
sess, err := dialAddrContext(context.Background(), addr, tlsConf, config, true)
|
return DialAddrEarlyContext(context.Background(), addr, tlsConf, config)
|
||||||
|
}
|
||||||
|
|
||||||
|
// DialAddrEarlyContext establishes a new 0-RTT QUIC connection to a server using provided context.
|
||||||
|
// See DialAddrEarly for details
|
||||||
|
func DialAddrEarlyContext(
|
||||||
|
ctx context.Context,
|
||||||
|
addr string,
|
||||||
|
tlsConf *tls.Config,
|
||||||
|
config *Config,
|
||||||
|
) (EarlySession, error) {
|
||||||
|
sess, err := dialAddrContext(ctx, addr, tlsConf, config, true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -134,7 +145,20 @@ func DialEarly(
|
||||||
tlsConf *tls.Config,
|
tlsConf *tls.Config,
|
||||||
config *Config,
|
config *Config,
|
||||||
) (EarlySession, error) {
|
) (EarlySession, error) {
|
||||||
return dialContext(context.Background(), pconn, remoteAddr, host, tlsConf, config, true, false)
|
return DialEarlyContext(context.Background(), pconn, remoteAddr, host, tlsConf, config)
|
||||||
|
}
|
||||||
|
|
||||||
|
// DialEarlyContext establishes a new 0-RTT QUIC connection to a server using a net.PacketConn using the provided context.
|
||||||
|
// See DialEarly for details.
|
||||||
|
func DialEarlyContext(
|
||||||
|
ctx context.Context,
|
||||||
|
pconn net.PacketConn,
|
||||||
|
remoteAddr net.Addr,
|
||||||
|
host string,
|
||||||
|
tlsConf *tls.Config,
|
||||||
|
config *Config,
|
||||||
|
) (EarlySession, error) {
|
||||||
|
return dialContext(ctx, pconn, remoteAddr, host, tlsConf, config, true, false)
|
||||||
}
|
}
|
||||||
|
|
||||||
// DialContext establishes a new QUIC connection to a server using a net.PacketConn using the provided context.
|
// DialContext establishes a new QUIC connection to a server using a net.PacketConn using the provided context.
|
||||||
|
|
|
@ -94,6 +94,25 @@ var _ = Describe("Timeout tests", func() {
|
||||||
Expect(err).To(MatchError(context.DeadlineExceeded))
|
Expect(err).To(MatchError(context.DeadlineExceeded))
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("returns the context error when the context expires with 0RTT enabled", func() {
|
||||||
|
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Millisecond)
|
||||||
|
defer cancel()
|
||||||
|
errChan := make(chan error)
|
||||||
|
go func() {
|
||||||
|
_, err := quic.DialAddrEarlyContext(
|
||||||
|
ctx,
|
||||||
|
"localhost:12345",
|
||||||
|
getTLSClientConfig(),
|
||||||
|
getQuicConfig(nil),
|
||||||
|
)
|
||||||
|
errChan <- err
|
||||||
|
}()
|
||||||
|
var err error
|
||||||
|
Eventually(errChan).Should(Receive(&err))
|
||||||
|
// This is not a net.Error timeout error
|
||||||
|
Expect(err).To(MatchError(context.DeadlineExceeded))
|
||||||
|
})
|
||||||
|
|
||||||
It("returns net.Error timeout errors when an idle timeout occurs", func() {
|
It("returns net.Error timeout errors when an idle timeout occurs", func() {
|
||||||
const idleTimeout = 100 * time.Millisecond
|
const idleTimeout = 100 * time.Millisecond
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue