develop/pass fix retry (#43)

fix: pair retry

It should be possible to do second pairing right away.
This commit is contained in:
Krzysztof Dryś 2024-04-18 09:02:32 +02:00 committed by GitHub
parent d1176fde8b
commit 1478cc5faf
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
7 changed files with 60 additions and 8 deletions

View File

@ -2,6 +2,7 @@ package connection
import ( import (
"bytes" "bytes"
"sync"
"time" "time"
"github.com/gorilla/websocket" "github.com/gorilla/websocket"
@ -52,11 +53,16 @@ func startProxy(wsConn *websocket.Conn, send *safeChannel, read chan []byte) {
conn: wsConn, conn: wsConn,
} }
wg := sync.WaitGroup{}
wg.Add(2)
go recovery.DoNotPanic(func() { go recovery.DoNotPanic(func() {
defer wg.Done()
proxy.writePump() proxy.writePump()
}) })
go recovery.DoNotPanic(func() { go recovery.DoNotPanic(func() {
defer wg.Done()
proxy.readPump() proxy.readPump()
}) })
@ -69,6 +75,8 @@ func startProxy(wsConn *websocket.Conn, send *safeChannel, read chan []byte) {
proxy.conn.Close() proxy.conn.Close()
}) })
wg.Wait()
} }
// readPump pumps messages from the websocket proxy to send. // readPump pumps messages from the websocket proxy to send.

View File

@ -33,6 +33,14 @@ func (pp *proxyPool) deleteExpiresPairs() {
} }
} }
func (pp *proxyPool) deleteProxyPair(id string) {
pp.mu.Lock()
defer pp.mu.Unlock()
// Channels inside proxyPair are closed in proxy.readPump and proxy.writePump.
delete(pp.proxies, id)
}
type proxyPair struct { type proxyPair struct {
toMobileDataCh *safeChannel toMobileDataCh *safeChannel
toExtensionDataCh *safeChannel toExtensionDataCh *safeChannel

View File

@ -40,6 +40,8 @@ func (p *ProxyServer) ServeExtensionProxyToMobileWS(w http.ResponseWriter, r *ht
proxyPair := p.proxyPool.getOrCreateProxyPair(id) proxyPair := p.proxyPool.getOrCreateProxyPair(id)
startProxy(conn, proxyPair.toMobileDataCh, proxyPair.toExtensionDataCh.channel) startProxy(conn, proxyPair.toMobileDataCh, proxyPair.toExtensionDataCh.channel)
p.proxyPool.deleteProxyPair(id)
return nil return nil
} }
@ -54,5 +56,6 @@ func (p *ProxyServer) ServeMobileProxyToExtensionWS(w http.ResponseWriter, r *ht
startProxy(conn, proxyPair.toExtensionDataCh, proxyPair.toMobileDataCh.channel) startProxy(conn, proxyPair.toExtensionDataCh, proxyPair.toMobileDataCh.channel)
p.proxyPool.deleteProxyPair(id)
return nil return nil
} }

View File

@ -57,12 +57,7 @@ func configureBrowserExtension() (ConfigureBrowserExtensionResponse, error) {
} }
// confirmMobile confirms pairing and returns mobile proxy token. // confirmMobile confirms pairing and returns mobile proxy token.
func confirmMobile(connectionToken, fcm string) (string, error) { func confirmMobile(connectionToken, deviceID, fcm string) (string, error) {
deviceID := uuid.NewString()
if deviceIDFromEnv := os.Getenv("TEST_DEVICE_ID"); deviceIDFromEnv != "" {
deviceID = deviceIDFromEnv
}
req := struct { req := struct {
DeviceID string `json:"device_id"` DeviceID string `json:"device_id"`
FCMToken string `json:"fcm_token"` FCMToken string `json:"fcm_token"`

15
tests/pass/lib.go Normal file
View File

@ -0,0 +1,15 @@
package pass
import (
"os"
"github.com/google/uuid"
)
func getDeviceID() string {
deviceID := uuid.NewString()
if deviceIDFromEnv := os.Getenv("TEST_DEVICE_ID"); deviceIDFromEnv != "" {
deviceID = deviceIDFromEnv
}
return deviceID
}

View File

@ -22,6 +22,28 @@ func TestPairHappyFlow(t *testing.T) {
t.Fatalf("Failed to configure browser extension: %v", err) t.Fatalf("Failed to configure browser extension: %v", err)
} }
deviceID := getDeviceID()
testPairing(t, deviceID, resp)
}
func TestPairMultipleTimes(t *testing.T) {
resp, err := configureBrowserExtension()
if err != nil {
t.Fatalf("Failed to configure browser extension: %v", err)
}
deviceID := getDeviceID()
for i := 0; i < 10; i++ {
testPairing(t, deviceID, resp)
if t.Failed() {
break
}
}
}
func testPairing(t *testing.T, deviceID string, resp ConfigureBrowserExtensionResponse) {
t.Helper()
browserExtensionDone := make(chan struct{}) browserExtensionDone := make(chan struct{})
mobileDone := make(chan struct{}) mobileDone := make(chan struct{})
@ -51,7 +73,7 @@ func TestPairHappyFlow(t *testing.T) {
go func() { go func() {
defer close(mobileDone) defer close(mobileDone)
mobileProxyToken, err := confirmMobile(resp.ConnectionToken, uuid.NewString()) mobileProxyToken, err := confirmMobile(resp.ConnectionToken, deviceID, uuid.NewString())
if err != nil { if err != nil {
t.Errorf("Mobile: confirm failed: %v", err) t.Errorf("Mobile: confirm failed: %v", err)
return return

View File

@ -16,6 +16,7 @@ func TestSyncHappyFlow(t *testing.T) {
mobileParingDone := make(chan struct{}) mobileParingDone := make(chan struct{})
fcm := uuid.NewString() fcm := uuid.NewString()
deviceID := getDeviceID()
go func() { go func() {
defer close(browserExtensionDone) defer close(browserExtensionDone)
@ -44,7 +45,7 @@ func TestSyncHappyFlow(t *testing.T) {
go func() { go func() {
defer close(mobileParingDone) defer close(mobileParingDone)
_, err := confirmMobile(resp.ConnectionToken, fcm) _, err := confirmMobile(resp.ConnectionToken, deviceID, fcm)
if err != nil { if err != nil {
t.Errorf("Mobile: confirm failed: %v", err) t.Errorf("Mobile: confirm failed: %v", err)
return return