1 /* 2 * Copyright 2016-2018 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license. 3 */ 4 5 package kotlinx.coroutines.slf4j 6 7 import kotlinx.coroutines.* 8 import org.junit.* 9 import org.junit.Test 10 import org.slf4j.* 11 import kotlin.coroutines.* 12 import kotlin.test.* 13 14 class MDCContextTest : TestBase() { 15 @Before setUpnull16 fun setUp() { 17 MDC.clear() 18 } 19 20 @After tearDownnull21 fun tearDown() { 22 MDC.clear() 23 } 24 25 @Test <lambda>null26 fun testContextIsNotPassedByDefaultBetweenCoroutines() = runTest { 27 expect(1) 28 MDC.put("myKey", "myValue") 29 // Standalone launch 30 GlobalScope.launch { 31 assertNull(MDC.get("myKey")) 32 expect(2) 33 }.join() 34 finish(3) 35 } 36 37 @Test <lambda>null38 fun testContextCanBePassedBetweenCoroutines() = runTest { 39 expect(1) 40 MDC.put("myKey", "myValue") 41 // Scoped launch with MDCContext element 42 launch(MDCContext()) { 43 assertEquals("myValue", MDC.get("myKey")) 44 expect(2) 45 }.join() 46 47 finish(3) 48 } 49 50 @Test <lambda>null51 fun testContextInheritance() = runTest { 52 expect(1) 53 MDC.put("myKey", "myValue") 54 withContext(MDCContext()) { 55 MDC.put("myKey", "myValue2") 56 // Scoped launch with inherited MDContext element 57 launch(Dispatchers.Default) { 58 assertEquals("myValue", MDC.get("myKey")) 59 expect(2) 60 }.join() 61 62 finish(3) 63 } 64 assertEquals("myValue", MDC.get("myKey")) 65 } 66 67 @Test testContextPassedWhileOnMainThreadnull68 fun testContextPassedWhileOnMainThread() { 69 MDC.put("myKey", "myValue") 70 // No MDCContext element 71 runBlocking { 72 assertEquals("myValue", MDC.get("myKey")) 73 } 74 } 75 76 @Test testContextCanBePassedWhileOnMainThreadnull77 fun testContextCanBePassedWhileOnMainThread() { 78 MDC.put("myKey", "myValue") 79 runBlocking(MDCContext()) { 80 assertEquals("myValue", MDC.get("myKey")) 81 } 82 } 83 84 @Test testContextNeededWithOtherContextnull85 fun testContextNeededWithOtherContext() { 86 MDC.put("myKey", "myValue") 87 runBlocking(MDCContext()) { 88 assertEquals("myValue", MDC.get("myKey")) 89 } 90 } 91 92 @Test testContextMayBeEmptynull93 fun testContextMayBeEmpty() { 94 runBlocking(MDCContext()) { 95 assertNull(MDC.get("myKey")) 96 } 97 } 98 99 @Test <lambda>null100 fun testContextWithContext() = runTest { 101 MDC.put("myKey", "myValue") 102 val mainDispatcher = kotlin.coroutines.coroutineContext[ContinuationInterceptor]!! 103 withContext(Dispatchers.Default + MDCContext()) { 104 assertEquals("myValue", MDC.get("myKey")) 105 withContext(mainDispatcher) { 106 assertEquals("myValue", MDC.get("myKey")) 107 } 108 } 109 } 110 }