-
Notifications
You must be signed in to change notification settings - Fork 7
/
FlutterInternalInterfaceImplTest.kt
112 lines (100 loc) · 3.25 KB
/
FlutterInternalInterfaceImplTest.kt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
package io.embrace.android.embracesdk
import io.embrace.android.embracesdk.fakes.FakeMetadataService
import io.embrace.android.embracesdk.logging.InternalEmbraceLogger
import io.mockk.every
import io.mockk.mockk
import io.mockk.verify
import org.junit.Assert.assertEquals
import org.junit.Before
import org.junit.Test
internal class FlutterInternalInterfaceImplTest {
private lateinit var impl: FlutterInternalInterfaceImpl
private lateinit var embrace: EmbraceImpl
private lateinit var logger: InternalEmbraceLogger
private lateinit var metadataService: FakeMetadataService
@Before
fun setUp() {
embrace = mockk(relaxed = true)
metadataService = FakeMetadataService()
logger = mockk(relaxed = true)
impl = FlutterInternalInterfaceImpl(embrace, mockk(), metadataService, logger)
}
@Test
fun testSetFlutterSdkVersion() {
every { embrace.isStarted } returns true
impl.setEmbraceFlutterSdkVersion("2.12")
assertEquals("2.12", metadataService.fakeFlutterSdkVersion)
}
@Test
fun testSetFlutterSdkVersionNotStarted() {
every { embrace.isStarted } returns false
impl.setEmbraceFlutterSdkVersion("2.12")
verify(exactly = 1) {
logger.logSDKNotInitialized(any())
}
}
@Test
fun testSetFlutterSdkVersionNull() {
every { embrace.isStarted } returns true
impl.setEmbraceFlutterSdkVersion(null)
assertEquals("fakeFlutterSdkVersion", metadataService.fakeFlutterSdkVersion)
}
@Test
fun testSetDartSdkVersion() {
every { embrace.isStarted } returns true
impl.setDartVersion("2.12")
assertEquals("2.12", metadataService.fakeDartVersion)
}
@Test
fun testSetDartVersionNotStarted() {
every { embrace.isStarted } returns false
impl.setDartVersion("2.12")
verify(exactly = 1) {
logger.logSDKNotInitialized(any())
}
}
@Test
fun testSetDartVersionNull() {
every { embrace.isStarted } returns true
impl.setDartVersion(null)
assertEquals("fakeDartVersion", metadataService.fakeDartVersion)
}
@Test
fun testLogUnhandledDartException() {
every { embrace.isStarted } returns true
impl.logUnhandledDartException("stack", "exception name", "message", "ctx", "lib")
verify(exactly = 1) {
embrace.logMessage(
EventType.ERROR_LOG,
"Dart error",
null,
null,
"stack",
LogExceptionType.UNHANDLED,
"ctx",
"lib",
"exception name",
"message"
)
}
}
@Test
fun testLogHandledDartException() {
every { embrace.isStarted } returns true
impl.logHandledDartException("stack", "exception name", "message", "ctx", "lib")
verify(exactly = 1) {
embrace.logMessage(
EventType.ERROR_LOG,
"Dart error",
null,
null,
"stack",
LogExceptionType.HANDLED,
"ctx",
"lib",
"exception name",
"message"
)
}
}
}