mirror of
https://github.com/ProtonMail/proton-bridge.git
synced 2025-12-29 13:06:44 +00:00
refactor: better confirmer result locking
This commit is contained in:
@ -66,7 +66,7 @@ func TestConfirmerTimeout(t *testing.T) {
|
||||
assert.Error(t, err)
|
||||
}
|
||||
|
||||
func TestConfirmerMultipleRequestCalls(t *testing.T) {
|
||||
func TestConfirmerMultipleResultCalls(t *testing.T) {
|
||||
c := New()
|
||||
|
||||
req := c.NewRequest(1 * time.Second)
|
||||
@ -83,6 +83,25 @@ func TestConfirmerMultipleRequestCalls(t *testing.T) {
|
||||
assert.Error(t, errAgain)
|
||||
}
|
||||
|
||||
func TestConfirmerMultipleSimultaneousResultCalls(t *testing.T) {
|
||||
c := New()
|
||||
|
||||
req := c.NewRequest(1 * time.Second)
|
||||
|
||||
go func() {
|
||||
time.Sleep(1 * time.Second)
|
||||
assert.NoError(t, c.SetResult(req.ID(), true))
|
||||
}()
|
||||
|
||||
// We just check that nothing panics. We can't know which Result() will get the result though.
|
||||
|
||||
go func() { _, _ = req.Result() }()
|
||||
go func() { _, _ = req.Result() }()
|
||||
go func() { _, _ = req.Result() }()
|
||||
|
||||
_, _ = req.Result()
|
||||
}
|
||||
|
||||
func TestConfirmerMultipleSetResultCalls(t *testing.T) {
|
||||
c := New()
|
||||
|
||||
|
||||
Reference in New Issue
Block a user