2fas-server/e2e-tests/browser_extension/browser_extension_2fa_test.go

106 lines
4.2 KiB
Go
Raw Permalink Normal View History

2022-12-31 10:22:38 +01:00
package tests
import (
"encoding/json"
"testing"
2022-12-31 10:22:38 +01:00
"github.com/stretchr/testify/assert"
2023-04-11 23:18:47 +02:00
"github.com/stretchr/testify/suite"
2024-03-16 15:41:30 +01:00
"github.com/twofas/2fas-server/e2e-tests"
2022-12-31 10:22:38 +01:00
)
2023-04-11 23:18:47 +02:00
func TestTwoFactorAuthTestSuite(t *testing.T) {
suite.Run(t, new(TwoFactorAuthTestSuite))
}
type TwoFactorAuthTestSuite struct {
suite.Suite
}
func (s *TwoFactorAuthTestSuite) SetupTest() {
2024-03-16 15:41:30 +01:00
e2e_tests.RemoveAllMobileDevices(s.T())
e2e_tests.RemoveAllBrowserExtensions(s.T())
e2e_tests.RemoveAllBrowserExtensionsDevices(s.T())
2023-04-11 23:18:47 +02:00
}
func (s *TwoFactorAuthTestSuite) TestBrowserExtensionAuthFullFlow() {
2024-03-16 15:41:30 +01:00
device, devicePubKey := e2e_tests.CreateDevice(s.T(), "SM-955F", "some-token")
browserExtension := e2e_tests.CreateBrowserExtension(s.T(), "go-ext")
2022-12-31 10:22:38 +01:00
2024-03-16 15:41:30 +01:00
websocketTestListener := e2e_tests.NewWebsocketTestListener("browser_extensions/" + browserExtension.Id)
2022-12-31 10:22:38 +01:00
websocketConnection := websocketTestListener.StartListening()
defer websocketConnection.Close()
2024-03-16 15:41:30 +01:00
e2e_tests.PairDeviceWithBrowserExtension(s.T(), devicePubKey, browserExtension, device)
2022-12-31 10:22:38 +01:00
2023-04-11 23:18:47 +02:00
assertDeviceHasPairedExtension(s.T(), device, browserExtension)
assertBrowserExtensionHasPairedDevice(s.T(), browserExtension, device)
2022-12-31 10:22:38 +01:00
expectedPairingSuccessWebsocket := createPairingSuccessWebsocketMessage(browserExtension, device, devicePubKey)
2023-04-11 23:18:47 +02:00
websocketTestListener.AssertMessageHasBeenReceived(s.T(), expectedPairingSuccessWebsocket)
2022-12-31 10:22:38 +01:00
2024-03-16 15:41:30 +01:00
tokenRequest := e2e_tests.Request2FaToken(s.T(), "facebook.com", browserExtension.Id)
2022-12-31 10:22:38 +01:00
2024-03-16 15:41:30 +01:00
extensionTokenRequestWebsocketListener := e2e_tests.NewWebsocketTestListener("browser_extensions/" + browserExtension.Id + "/2fa_requests/" + tokenRequest.Id)
2022-12-31 10:22:38 +01:00
extensionTokenRequestWebsocketConnection := extensionTokenRequestWebsocketListener.StartListening()
defer extensionTokenRequestWebsocketConnection.Close()
2024-03-16 15:41:30 +01:00
e2e_tests.Send2FaTokenToExtension(s.T(), browserExtension.Id, device.Id, tokenRequest.Id, "2fa-token")
2022-12-31 10:22:38 +01:00
expected2FaTokenWebsocket := createBrowserExtensionReceived2FaTokenMessage(browserExtension.Id, device.Id, tokenRequest.Id)
2023-04-11 23:18:47 +02:00
extensionTokenRequestWebsocketListener.AssertMessageHasBeenReceived(s.T(), expected2FaTokenWebsocket)
2022-12-31 10:22:38 +01:00
}
func createBrowserExtensionReceived2FaTokenMessage(extensionId, deviceId, requestId string) string {
expected2FaTokenWebsocketMessageRaw := struct {
Event string `json:"event"`
ExtensionId string `json:"extension_id"`
DeviceId string `json:"device_id"`
TokenRequestId string `json:"token_request_id"`
Token string `json:"token"`
}{
Event: "browser_extensions.device.2fa_response",
ExtensionId: extensionId,
DeviceId: deviceId,
TokenRequestId: requestId,
Token: "2fa-token",
}
message, _ := json.Marshal(expected2FaTokenWebsocketMessageRaw)
return string(message)
}
2024-03-16 15:41:30 +01:00
func createPairingSuccessWebsocketMessage(browserExtension *e2e_tests.BrowserExtensionResponse, device *e2e_tests.DeviceResponse, devicePubKey string) string {
2022-12-31 10:22:38 +01:00
expectedPairingWebsocketMessageRaw := &struct {
Event string `json:"event"`
BrowserExtensionId string `json:"browser_extension_id"`
DeviceId string `json:"device_id"`
DevicePublicKey string `json:"device_public_key"`
}{
Event: "browser_extensions.pairing.success",
BrowserExtensionId: browserExtension.Id,
DeviceId: device.Id,
DevicePublicKey: devicePubKey,
}
message, _ := json.Marshal(expectedPairingWebsocketMessageRaw)
return string(message)
}
2024-03-16 15:41:30 +01:00
func assertBrowserExtensionHasPairedDevice(t *testing.T, browserExtension *e2e_tests.BrowserExtensionResponse, device *e2e_tests.DeviceResponse) {
var browserExtensionDevices []*e2e_tests.DeviceResponse
e2e_tests.DoAPISuccessGet(t, "browser_extensions/"+browserExtension.Id+"/devices", &browserExtensionDevices)
2022-12-31 10:22:38 +01:00
assert.Len(t, browserExtensionDevices, 1)
assert.Equal(t, device.Id, browserExtensionDevices[0].Id)
}
2024-03-16 15:41:30 +01:00
func assertDeviceHasPairedExtension(t *testing.T, device *e2e_tests.DeviceResponse, browserExtension *e2e_tests.BrowserExtensionResponse) {
var deviceBrowserExtensions []*e2e_tests.BrowserExtensionResponse
e2e_tests.DoAPISuccessGet(t, "mobile/devices/"+device.Id+"/browser_extensions", &deviceBrowserExtensions)
2022-12-31 10:22:38 +01:00
assert.Len(t, deviceBrowserExtensions, 1)
assert.Equal(t, browserExtension.Id, deviceBrowserExtensions[0].Id)
}