2019-12-19 18:27:36 -08:00
|
|
|
/*
|
|
|
|
|
* Copyright (C) 2020 The Android Open Source Project
|
|
|
|
|
*
|
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
|
*
|
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
*
|
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
|
* limitations under the License.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
package com.android.launcher3.testing;
|
|
|
|
|
|
|
|
|
|
import android.util.Log;
|
2021-08-11 12:54:47 -07:00
|
|
|
import android.view.InputEvent;
|
2021-08-06 15:49:02 -07:00
|
|
|
import android.view.KeyEvent;
|
2020-01-22 18:00:37 -08:00
|
|
|
import android.view.MotionEvent;
|
2019-12-19 18:27:36 -08:00
|
|
|
|
|
|
|
|
import com.android.launcher3.Utilities;
|
2022-07-26 13:54:31 -07:00
|
|
|
import com.android.launcher3.testing.shared.TestProtocol;
|
2019-12-19 18:27:36 -08:00
|
|
|
|
2020-06-19 15:00:00 -07:00
|
|
|
import java.util.function.BiConsumer;
|
|
|
|
|
|
2019-12-19 18:27:36 -08:00
|
|
|
public final class TestLogging {
|
2023-08-29 12:04:26 -07:00
|
|
|
private static final String TAPL_EVENTS_TAG = "TaplEvents";
|
|
|
|
|
private static final String LAUNCHER_EVENTS_TAG = "LauncherEvents";
|
2020-06-19 15:00:00 -07:00
|
|
|
private static BiConsumer<String, String> sEventConsumer;
|
2021-08-06 15:49:02 -07:00
|
|
|
public static boolean sHadEventsNotFromTest;
|
2020-06-19 15:00:00 -07:00
|
|
|
|
2023-08-29 12:04:26 -07:00
|
|
|
private static void recordEventSlow(String sequence, String event, boolean reportToTapl) {
|
|
|
|
|
Log.d(reportToTapl ? TAPL_EVENTS_TAG : LAUNCHER_EVENTS_TAG,
|
|
|
|
|
sequence + " / " + event);
|
2020-06-19 15:00:00 -07:00
|
|
|
final BiConsumer<String, String> eventConsumer = sEventConsumer;
|
2023-08-29 12:04:26 -07:00
|
|
|
if (reportToTapl && eventConsumer != null) {
|
2020-06-19 15:00:00 -07:00
|
|
|
eventConsumer.accept(sequence, event);
|
|
|
|
|
}
|
2020-01-22 18:00:37 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void recordEvent(String sequence, String event) {
|
2023-03-02 19:45:23 +00:00
|
|
|
if (Utilities.isRunningInTestHarness()) {
|
2023-08-29 12:04:26 -07:00
|
|
|
recordEventSlow(sequence, event, true);
|
2020-01-22 18:00:37 -08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void recordEvent(String sequence, String message, Object parameter) {
|
2023-03-02 19:45:23 +00:00
|
|
|
if (Utilities.isRunningInTestHarness()) {
|
2023-08-29 12:04:26 -07:00
|
|
|
recordEventSlow(sequence, message + ": " + parameter, true);
|
2020-01-22 18:00:37 -08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-11 12:54:47 -07:00
|
|
|
private static void registerEventNotFromTest(InputEvent event) {
|
|
|
|
|
if (!sHadEventsNotFromTest && event.getDeviceId() != -1) {
|
|
|
|
|
sHadEventsNotFromTest = true;
|
|
|
|
|
Log.d(TestProtocol.PERMANENT_DIAG_TAG, "First event not from test: " + event);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-06 15:49:02 -07:00
|
|
|
public static void recordKeyEvent(String sequence, String message, KeyEvent event) {
|
2023-03-02 19:45:23 +00:00
|
|
|
if (Utilities.isRunningInTestHarness()) {
|
2023-08-29 12:04:26 -07:00
|
|
|
recordEventSlow(sequence, message + ": " + event, true);
|
2021-08-11 12:54:47 -07:00
|
|
|
registerEventNotFromTest(event);
|
2021-08-06 15:49:02 -07:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-01-22 18:00:37 -08:00
|
|
|
public static void recordMotionEvent(String sequence, String message, MotionEvent event) {
|
2023-08-29 12:04:26 -07:00
|
|
|
final int action = event.getAction();
|
|
|
|
|
if (Utilities.isRunningInTestHarness() && action != MotionEvent.ACTION_MOVE) {
|
2023-08-30 15:55:50 -07:00
|
|
|
// "Expecting" in TAPL motion events was thought to be producing considerable noise in
|
|
|
|
|
// tests due to failed checks for expected events. So we are not sending them to TAPL.
|
2023-08-29 12:04:26 -07:00
|
|
|
// Other events, such as EVENT_PILFER_POINTERS produce less noise and are thought to
|
|
|
|
|
// be more useful.
|
2023-08-30 15:55:50 -07:00
|
|
|
// That's why we pass false as the value for the 'reportToTapl' parameter.
|
|
|
|
|
recordEventSlow(sequence, message + ": " + event, false);
|
2021-08-11 12:54:47 -07:00
|
|
|
registerEventNotFromTest(event);
|
2019-12-19 18:27:36 -08:00
|
|
|
}
|
|
|
|
|
}
|
2020-06-19 15:00:00 -07:00
|
|
|
|
|
|
|
|
static void setEventConsumer(BiConsumer<String, String> consumer) {
|
|
|
|
|
sEventConsumer = consumer;
|
|
|
|
|
}
|
2019-12-19 18:27:36 -08:00
|
|
|
}
|