summaryrefslogtreecommitdiff
path: root/akono/src/androidTest/java/akono/InstrumentedAkonoTests.kt
diff options
context:
space:
mode:
Diffstat (limited to 'akono/src/androidTest/java/akono/InstrumentedAkonoTests.kt')
-rw-r--r--akono/src/androidTest/java/akono/InstrumentedAkonoTests.kt85
1 files changed, 85 insertions, 0 deletions
diff --git a/akono/src/androidTest/java/akono/InstrumentedAkonoTests.kt b/akono/src/androidTest/java/akono/InstrumentedAkonoTests.kt
new file mode 100644
index 00000000..beda5119
--- /dev/null
+++ b/akono/src/androidTest/java/akono/InstrumentedAkonoTests.kt
@@ -0,0 +1,85 @@
+package akono.test;
+
+import androidx.test.ext.junit.runners.AndroidJUnit4
+import org.junit.runner.RunWith
+import org.junit.Test
+import androidx.test.filters.LargeTest
+import org.junit.Assert.assertEquals
+import akono.AkonoJni
+import akono.ModuleResult
+import android.util.Log
+import java.util.concurrent.LinkedBlockingDeque
+
+
+class SyncMessageHandler : AkonoJni.MessageHandler {
+ private val messageQueue = LinkedBlockingDeque<String>()
+ override fun handleMessage(message: String) {
+ messageQueue.put(message)
+ }
+
+ fun waitForMessage(): String {
+ return messageQueue.take()
+ }
+}
+
+
+class StaticModuleLoadHandler : AkonoJni.LoadModuleHandler {
+ private val modules: MutableMap<String, String> = HashMap()
+
+ override fun loadModule(name: String, paths: Array<String>): ModuleResult? {
+ val code = modules.get(name) ?: return null
+ if (modules.containsKey(name)) {
+ return ModuleResult("/vmodroot/$name.js", code)
+ }
+ return null
+ }
+
+ fun registerModule(name: String, source: String) {
+ modules[name] = source
+ }
+}
+
+
+// @RunWith is required only if you use a mix of JUnit3 and JUnit4.
+@RunWith(AndroidJUnit4::class)
+@LargeTest
+public class InstrumentedAkonoTestOne {
+ @Test
+ fun myJsTest() {
+ val ajni: AkonoJni = AkonoJni()
+ assertEquals("2", ajni.evalSimpleJs("1+1"))
+ assertEquals("36", ajni.evalSimpleJs("6*6"))
+ assertEquals("42", ajni.evalSimpleJs("(()=>{let x = 42; return x;})()"))
+ assertEquals("undefined", ajni.evalSimpleJs("const myVal = 42"))
+ assertEquals("43", ajni.evalSimpleJs("myVal + 1"))
+
+ val myHandler = SyncMessageHandler()
+ ajni.setMessageHandler(myHandler)
+ ajni.evalNodeCode("console.log('hi from the test case')")
+ // Tell the message handler to just ping back messages to us
+ ajni.evalNodeCode("global.__akono_onMessage = (x) => { global.__akono_sendMessage(x); }")
+ val sentMessage = "Hello AKONO!!"
+ ajni.sendMessage(sentMessage)
+ val receivedMessage = myHandler.waitForMessage()
+ assertEquals(sentMessage, receivedMessage)
+ Log.i("myapp", "test case received message: $receivedMessage")
+
+ val myModHandler = StaticModuleLoadHandler()
+
+ ajni.setLoadModuleHandler(myModHandler)
+
+ myModHandler.registerModule("a", """
+ |console.log('I am module a');
+ |exports.foo = () => { global.__akono_sendMessage('hello42'); };
+ """.trimMargin())
+
+ ajni.evalNodeCode("a = require('a');")
+ ajni.evalNodeCode("a.foo()")
+
+ val msg2 = myHandler.waitForMessage()
+
+ assertEquals("hello42", msg2)
+
+ ajni.waitStopped()
+ }
+}