aboutsummaryrefslogtreecommitdiff
path: root/java
diff options
context:
space:
mode:
authorGrace Zhao <gracezrx@google.com>2022-11-08 14:18:08 -0800
committerGrace Zhao <gracezrx@google.com>2022-11-08 14:21:44 -0800
commitb4eb22c99d452f7841e34101ed54d41a97d5d91f (patch)
treee019bca95666f928314f514eed890a67912b45fb /java
parent87ae5c9150df62e0eafa0d5935670765c88c3940 (diff)
parent0cdc7152cbee44a55b800ef1ac4cb4ee609c0389 (diff)
downloadicing-b4eb22c99d452f7841e34101ed54d41a97d5d91f.tar.gz
Merge remote-tracking branch 'aosp/upstream-master' into androidx-main
* aosp/upstream-master: Fix g3 sync for merge to androidx-main Sync from upstream. Descriptions: ====================================================================== Fix the bug in PostingListAccessor found by the Icing Monkey test ====================================================================== Add the logic to handle fatal errors from IcingDynamicTrie to avoid crashing ====================================================================== Clear out the dead code IcingDynamicTrie::Compact ====================================================================== [MemoryMappedFile][RemapV2][1/x] Add factory method for MemoryMappedFile ====================================================================== [MemoryMappedFile][RemapV2][2/x] Create GrowAndRemapIfNecessary and change factory method ====================================================================== [MemoryMappedFile][RemapV2][3/x] Migrate FileBackedVector to use GrowAndRemapIfNecessary ====================================================================== Add JNI latency for query latency stats breakdown ====================================================================== Bug: 247671531 Bug: 247929909 Bug: 253282365 Change-Id: I8545e1e7d5dd5714a898ea29e4b51b1b4010ead7
Diffstat (limited to 'java')
-rw-r--r--java/src/com/google/android/icing/IcingSearchEngine.java7
-rw-r--r--java/tests/instrumentation/src/com/google/android/icing/IcingSearchEngineTest.java32
2 files changed, 21 insertions, 18 deletions
diff --git a/java/src/com/google/android/icing/IcingSearchEngine.java b/java/src/com/google/android/icing/IcingSearchEngine.java
index b54b344..81223f2 100644
--- a/java/src/com/google/android/icing/IcingSearchEngine.java
+++ b/java/src/com/google/android/icing/IcingSearchEngine.java
@@ -306,6 +306,13 @@ public class IcingSearchEngine implements Closeable {
@NonNull ResultSpecProto resultSpec) {
throwIfClosed();
+ // Note that on Android System.currentTimeMillis() is the standard "wall" clock and can be set
+ // by the user or the phone network so the time may jump backwards or forwards unpredictably.
+ // This could lead to inaccurate final JNI latency calculations or unexpected negative numbers
+ // in the case where the phone time is changed while sending data across JNI layers.
+ // However these occurrences should be very rare, so we will keep usage of
+ // System.currentTimeMillis() due to the lack of better time functions that can provide a
+ // consistent timestamp across all platforms.
long javaToNativeStartTimestampMs = System.currentTimeMillis();
byte[] searchResultBytes =
nativeSearch(
diff --git a/java/tests/instrumentation/src/com/google/android/icing/IcingSearchEngineTest.java b/java/tests/instrumentation/src/com/google/android/icing/IcingSearchEngineTest.java
index 573ccfe..1ed2d9a 100644
--- a/java/tests/instrumentation/src/com/google/android/icing/IcingSearchEngineTest.java
+++ b/java/tests/instrumentation/src/com/google/android/icing/IcingSearchEngineTest.java
@@ -215,15 +215,13 @@ public final class IcingSearchEngineTest {
assertThat(searchResultProto.getResultsCount()).isEqualTo(1);
assertThat(searchResultProto.getResults(0).getDocument()).isEqualTo(emailDocument);
- // TODO(b/236412954): Enable these JNI latency tests once cl/469819190 is synced to Jetpack
- // Test that JNI latency has been set properly
- // assertThat(searchResultProto.getQueryStats().hasNativeToJavaJniLatencyMs()).isTrue();
- // assertThat(searchResultProto.getQueryStats().hasNativeToJavaStartTimestampMs()).isTrue();
- // assertThat(searchResultProto.getQueryStats().hasJavaToNativeJniLatencyMs()).isTrue();
- // assertThat(searchResultProto.getQueryStats().getNativeToJavaJniLatencyMs()).isAtLeast(0);
- // assertThat(searchResultProto.getQueryStats().getNativeToJavaStartTimestampMs())
- // .isGreaterThan(0);
- // assertThat(searchResultProto.getQueryStats().getJavaToNativeJniLatencyMs()).isAtLeast(0);
+ assertThat(searchResultProto.getQueryStats().hasNativeToJavaStartTimestampMs()).isTrue();
+ assertThat(searchResultProto.getQueryStats().hasNativeToJavaJniLatencyMs()).isTrue();
+ assertThat(searchResultProto.getQueryStats().hasJavaToNativeJniLatencyMs()).isTrue();
+ assertThat(searchResultProto.getQueryStats().getNativeToJavaStartTimestampMs())
+ .isGreaterThan(0);
+ assertThat(searchResultProto.getQueryStats().getNativeToJavaJniLatencyMs()).isAtLeast(0);
+ assertThat(searchResultProto.getQueryStats().getJavaToNativeJniLatencyMs()).isAtLeast(0);
}
@Test
@@ -266,15 +264,13 @@ public final class IcingSearchEngineTest {
DocumentProto resultDocument = searchResultProto.getResults(0).getDocument();
assertThat(resultDocument).isEqualTo(documents.remove(resultDocument.getUri()));
- // TODO(b/236412954): Enable these JNI latency tests once cl/469819190 is synced to Jetpack
- // Test that JNI latency has been set
- // assertThat(searchResultProto.getQueryStats().hasNativeToJavaJniLatencyMs()).isTrue();
- // assertThat(searchResultProto.getQueryStats().hasNativeToJavaStartTimestampMs()).isTrue();
- // assertThat(searchResultProto.getQueryStats().hasJavaToNativeJniLatencyMs()).isTrue();
- // assertThat(searchResultProto.getQueryStats().getNativeToJavaJniLatencyMs()).isAtLeast(0);
- // assertThat(searchResultProto.getQueryStats().getNativeToJavaStartTimestampMs())
- // .isGreaterThan(0);
- // assertThat(searchResultProto.getQueryStats().getJavaToNativeJniLatencyMs()).isAtLeast(0);
+ assertThat(searchResultProto.getQueryStats().hasNativeToJavaStartTimestampMs()).isTrue();
+ assertThat(searchResultProto.getQueryStats().hasNativeToJavaJniLatencyMs()).isTrue();
+ assertThat(searchResultProto.getQueryStats().hasJavaToNativeJniLatencyMs()).isTrue();
+ assertThat(searchResultProto.getQueryStats().getNativeToJavaStartTimestampMs())
+ .isGreaterThan(0);
+ assertThat(searchResultProto.getQueryStats().getNativeToJavaJniLatencyMs()).isAtLeast(0);
+ assertThat(searchResultProto.getQueryStats().getJavaToNativeJniLatencyMs()).isAtLeast(0);
// fetch rest pages
for (int i = 1; i < 5; i++) {