From 6eed99a6467f80e609946d35f577e25986770753 Mon Sep 17 00:00:00 2001 From: Andrey Date: Tue, 29 Nov 2022 10:25:15 -0500 Subject: [PATCH] ETB JNI test progress Coffee is important! --- .../java/com/rusefi/native_/EngineLogic.java | 4 ++-- .../java/com/rusefi/native_/JniUnitTest.java | 23 ++++++++----------- .../native/com_rusefi_native__EngineLogic.h | 4 ++-- unit_tests/native/native_impl.cpp | 10 ++++++-- 4 files changed, 22 insertions(+), 19 deletions(-) diff --git a/java_console/io/src/main/java/com/rusefi/native_/EngineLogic.java b/java_console/io/src/main/java/com/rusefi/native_/EngineLogic.java index 639419638e..bd1b8e4751 100644 --- a/java_console/io/src/main/java/com/rusefi/native_/EngineLogic.java +++ b/java_console/io/src/main/java/com/rusefi/native_/EngineLogic.java @@ -7,10 +7,10 @@ package com.rusefi.native_; * See native_impl.cpp */ public class EngineLogic { - public native String getVersion(); + public static native String getVersion(); // huh? I am having trouble making this method static? - public native void resetTest(); + public static native void resetTest(); public native void setSensor(String sensorTypeName, double value); diff --git a/java_console/io/src/test/java/com/rusefi/native_/JniUnitTest.java b/java_console/io/src/test/java/com/rusefi/native_/JniUnitTest.java index c9e41e09f5..063fc83add 100644 --- a/java_console/io/src/test/java/com/rusefi/native_/JniUnitTest.java +++ b/java_console/io/src/test/java/com/rusefi/native_/JniUnitTest.java @@ -18,17 +18,16 @@ import static junit.framework.Assert.*; public class JniUnitTest { @Before public void reset() { -// new EngineLogic().resetTest(); + JniSandbox.loadLibrary(); + EngineLogic.resetTest(); } @Test public void run() { - JniSandbox.loadLibrary(); - - EngineLogic engineLogic = new EngineLogic(); - String version = engineLogic.getVersion(); + String version = EngineLogic.getVersion(); assertTrue("Got " + version, version.contains("Hello")); + EngineLogic engineLogic = new EngineLogic(); engineLogic.invokePeriodicCallback(); assertEquals(TS_FILE_VERSION, (int) getValue(engineLogic.getOutputs(), Sensor.FIRMWARE_VERSION)); @@ -54,8 +53,6 @@ public class JniUnitTest { @Test public void testEtbStuff() { - JniSandbox.loadLibrary(); - EngineLogic engineLogic = new EngineLogic(); engineLogic.setSensor(SensorType.Tps1Primary.name(), 30); @@ -71,12 +68,12 @@ public class JniUnitTest { engineLogic.setConfiguration(new byte[]{3}, Fields.THROTTLEPEDALPOSITIONADCCHANNEL.getTotalOffset(), 1); engineLogic.setConfiguration(new byte[]{3}, Fields.THROTTLEPEDALPOSITIONSECONDADCCHANNEL.getTotalOffset(), 1); -// engineLogic.initTps(); -// engineLogic.burnRequest(); -// System.out.println("engineLogic.invokeEtbCycle"); -// engineLogic.invokeEtbCycle(); -// -// assertEquals(120.36, getValue(engineLogic.getOutputs(), Sensor.etb1DutyCycle)); + engineLogic.initTps(); + engineLogic.burnRequest(); + System.out.println("engineLogic.invokeEtbCycle"); + engineLogic.invokeEtbCycle(); + + assertEquals(120.36, getValue(engineLogic.getOutputs(), Sensor.etb1DutyCycle)); } private double getField(EngineLogic engineLogic, Field field) { diff --git a/unit_tests/native/com_rusefi_native__EngineLogic.h b/unit_tests/native/com_rusefi_native__EngineLogic.h index f6b1603b12..414966856f 100644 --- a/unit_tests/native/com_rusefi_native__EngineLogic.h +++ b/unit_tests/native/com_rusefi_native__EngineLogic.h @@ -13,7 +13,7 @@ extern "C" { * Signature: ()Ljava/lang/String; */ JNIEXPORT jstring JNICALL Java_com_rusefi_native_1_EngineLogic_getVersion - (JNIEnv *, jobject); + (JNIEnv *, jclass); /* * Class: com_rusefi_native__EngineLogic @@ -21,7 +21,7 @@ JNIEXPORT jstring JNICALL Java_com_rusefi_native_1_EngineLogic_getVersion * Signature: ()V */ JNIEXPORT void JNICALL Java_com_rusefi_native_1_EngineLogic_resetTest - (JNIEnv *, jobject); + (JNIEnv *, jclass); /* * Class: com_rusefi_native__EngineLogic diff --git a/unit_tests/native/native_impl.cpp b/unit_tests/native/native_impl.cpp index 43a8f3dc15..cf9f23d0a3 100644 --- a/unit_tests/native/native_impl.cpp +++ b/unit_tests/native/native_impl.cpp @@ -25,12 +25,12 @@ static EngineTestHelper* getEth() { } JNIEXPORT void JNICALL Java_com_rusefi_native_1_EngineLogic_resetTest - (JNIEnv *, jobject) { + (JNIEnv *, jclass) { printf("[native] resetTest\n"); ethPtr = nullptr; } -JNIEXPORT jstring JNICALL Java_com_rusefi_native_1_EngineLogic_getVersion(JNIEnv * env, jobject) { +JNIEXPORT jstring JNICALL Java_com_rusefi_native_1_EngineLogic_getVersion(JNIEnv * env, jclass) { const char msg[60] = "Hello from unit tests"; const char* fileName = msg; jstring result = env->NewStringUTF(msg); @@ -116,6 +116,12 @@ JNIEXPORT void JNICALL Java_com_rusefi_native_1_EngineLogic_initTps initTps(); } +JNIEXPORT void JNICALL Java_com_rusefi_native_1_EngineLogic_initTps2 + (JNIEnv *, jobject) { + printf("[native] initTps2\n"); +} + + JNIEXPORT jbyteArray JNICALL Java_com_rusefi_native_1_EngineLogic_getOutputs(JNIEnv * env, jobject instance) { jbyteArray retVal = env->NewByteArray(TS_TOTAL_OUTPUT_SIZE); jbyte *buf = env->GetByteArrayElements(retVal, NULL);