mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-03 20:17:36 +03:00
[dev.boringcrypto] crypto/hmac: merge up to 2a206c7 and skip test
TestNonUniqueHash will not work on boringcrypto because the hash.Hash that sha256 provides is noncomparable. Change-Id: Ie3dc2d5d775953c381674e22272cb3433daa1b31
This commit is contained in:
commit
1c169a2718
4 changed files with 21 additions and 25 deletions
|
@ -727,9 +727,12 @@ func (c *Config) ticketKeyFromBytes(b [32]byte) (key ticketKey) {
|
|||
// ticket, and the lifetime we set for tickets we send.
|
||||
const maxSessionTicketLifetime = 7 * 24 * time.Hour
|
||||
|
||||
// Clone returns a shallow clone of c. It is safe to clone a Config that is
|
||||
// Clone returns a shallow clone of c or nil if c is nil. It is safe to clone a Config that is
|
||||
// being used concurrently by a TLS client or server.
|
||||
func (c *Config) Clone() *Config {
|
||||
if c == nil {
|
||||
return nil
|
||||
}
|
||||
c.mutex.RLock()
|
||||
defer c.mutex.RUnlock()
|
||||
return &Config{
|
||||
|
|
17
conn.go
17
conn.go
|
@ -168,18 +168,18 @@ type halfConn struct {
|
|||
trafficSecret []byte // current TLS 1.3 traffic secret
|
||||
}
|
||||
|
||||
type permamentError struct {
|
||||
type permanentError struct {
|
||||
err net.Error
|
||||
}
|
||||
|
||||
func (e *permamentError) Error() string { return e.err.Error() }
|
||||
func (e *permamentError) Unwrap() error { return e.err }
|
||||
func (e *permamentError) Timeout() bool { return e.err.Timeout() }
|
||||
func (e *permamentError) Temporary() bool { return false }
|
||||
func (e *permanentError) Error() string { return e.err.Error() }
|
||||
func (e *permanentError) Unwrap() error { return e.err }
|
||||
func (e *permanentError) Timeout() bool { return e.err.Timeout() }
|
||||
func (e *permanentError) Temporary() bool { return false }
|
||||
|
||||
func (hc *halfConn) setErrorLocked(err error) error {
|
||||
if e, ok := err.(net.Error); ok {
|
||||
hc.err = &permamentError{err: e}
|
||||
hc.err = &permanentError{err: e}
|
||||
} else {
|
||||
hc.err = err
|
||||
}
|
||||
|
@ -1070,7 +1070,6 @@ func (c *Conn) readHandshake() (interface{}, error) {
|
|||
}
|
||||
|
||||
var (
|
||||
errClosed = errors.New("tls: use of closed connection")
|
||||
errShutdown = errors.New("tls: protocol is shutdown")
|
||||
)
|
||||
|
||||
|
@ -1080,7 +1079,7 @@ func (c *Conn) Write(b []byte) (int, error) {
|
|||
for {
|
||||
x := atomic.LoadInt32(&c.activeCall)
|
||||
if x&1 != 0 {
|
||||
return 0, errClosed
|
||||
return 0, net.ErrClosed
|
||||
}
|
||||
if atomic.CompareAndSwapInt32(&c.activeCall, x, x+2) {
|
||||
break
|
||||
|
@ -1285,7 +1284,7 @@ func (c *Conn) Close() error {
|
|||
for {
|
||||
x = atomic.LoadInt32(&c.activeCall)
|
||||
if x&1 != 0 {
|
||||
return errClosed
|
||||
return net.ErrClosed
|
||||
}
|
||||
if atomic.CompareAndSwapInt32(&c.activeCall, x, x|1) {
|
||||
break
|
||||
|
|
13
link_test.go
13
link_test.go
|
@ -41,19 +41,6 @@ func main() {}
|
|||
"type.crypto/tls.serverHandshakeState",
|
||||
},
|
||||
},
|
||||
{
|
||||
name: "only_conn",
|
||||
program: `package main
|
||||
import "crypto/tls"
|
||||
var c = new(tls.Conn)
|
||||
func main() {}
|
||||
`,
|
||||
want: []string{"tls.(*Conn)"},
|
||||
bad: []string{
|
||||
"type.crypto/tls.clientHandshakeState",
|
||||
"type.crypto/tls.serverHandshakeState",
|
||||
},
|
||||
},
|
||||
{
|
||||
name: "client_and_server",
|
||||
program: `package main
|
||||
|
|
11
tls_test.go
11
tls_test.go
|
@ -569,8 +569,8 @@ func TestConnCloseBreakingWrite(t *testing.T) {
|
|||
}
|
||||
|
||||
<-closeReturned
|
||||
if err := tconn.Close(); err != errClosed {
|
||||
t.Errorf("Close error = %v; want errClosed", err)
|
||||
if err := tconn.Close(); err != net.ErrClosed {
|
||||
t.Errorf("Close error = %v; want net.ErrClosed", err)
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -841,6 +841,13 @@ func TestCloneNonFuncFields(t *testing.T) {
|
|||
}
|
||||
}
|
||||
|
||||
func TestCloneNilConfig(t *testing.T) {
|
||||
var config *Config
|
||||
if cc := config.Clone(); cc != nil {
|
||||
t.Fatalf("Clone with nil should return nil, got: %+v", cc)
|
||||
}
|
||||
}
|
||||
|
||||
// changeImplConn is a net.Conn which can change its Write and Close
|
||||
// methods.
|
||||
type changeImplConn struct {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue