Skip to content

Commit

Permalink
refactor: simplify code with waitFor function for locally stored events
Browse files Browse the repository at this point in the history
  • Loading branch information
wzieba committed Oct 29, 2023
1 parent 8e62ff5 commit bafd5ac
Showing 1 changed file with 15 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ import okhttp3.mockwebserver.MockResponse
import okhttp3.mockwebserver.MockWebServer
import okhttp3.mockwebserver.RecordedRequest
import org.assertj.core.api.Assertions.assertThat
import org.assertj.core.api.Assertions.fail
import org.junit.Test
import org.junit.runner.RunWith

Expand Down Expand Up @@ -65,16 +64,9 @@ class FunctionalTests {
val requestPayload = server.takeRequest().toMap()
assertThat(requestPayload["events"]).hasSize(51)

runBlocking {
withTimeoutOrNull(500.milliseconds) {
while (true) {
yield()
if (locallyStoredEvents.size == 0) {
break
}
}
} ?: fail("Local storage file is not empty!")
}
// Wait a moment to give SDK time to delete the content of local storage file
waitFor { locallyStoredEvents.isEmpty() }
assertThat(locallyStoredEvents).isEmpty()
}
}

Expand All @@ -86,7 +78,7 @@ class FunctionalTests {
}

@JsonIgnoreProperties(ignoreUnknown = true)
data class Event (
data class Event(
@JsonProperty("idsite") var idsite: String,
)

Expand Down Expand Up @@ -115,4 +107,15 @@ class FunctionalTests {
}

class SampleActivity : Activity()

private fun waitFor(condition: () -> Boolean) = runBlocking {
withTimeoutOrNull(500.milliseconds) {
while (true) {
yield()
if (condition()) {
break
}
}
}
}
}

0 comments on commit bafd5ac

Please sign in to comment.