blob: 4db9262f7fe364e26eeaec1c36b48358948c2b52 [file] [log] [blame]
/*
* Copyright (C) 2016 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 android.os;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertTrue;
import android.perftests.utils.BenchmarkState;
import android.perftests.utils.PerfStatusReporter;
import androidx.test.filters.LargeTest;
import androidx.test.runner.AndroidJUnit4;
import org.junit.After;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;
@RunWith(AndroidJUnit4.class)
@LargeTest
public class ParcelPerfTest {
@Rule
public PerfStatusReporter mPerfStatusReporter = new PerfStatusReporter();
private Parcel mParcel;
@Before
public void setUp() {
mParcel = Parcel.obtain();
mParcel.setDataPosition(0);
mParcel.setDataCapacity(8);
}
@After
public void tearDown() {
mParcel.recycle();
mParcel = null;
}
@Test
public void timeSetDataPosition() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
while (state.keepRunning()) {
mParcel.setDataPosition(0);
}
}
@Test
public void timeGetDataPosition() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
while (state.keepRunning()) {
mParcel.dataPosition();
}
}
@Test
public void timeSetDataSize() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
while (state.keepRunning()) {
mParcel.setDataSize(0);
}
}
@Test
public void timeGetDataSize() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
while (state.keepRunning()) {
mParcel.dataSize();
}
}
@Test
public void timeSetDataCapacity() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
while (state.keepRunning()) {
mParcel.setDataCapacity(0);
}
}
@Test
public void timeGetDataCapacity() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
while (state.keepRunning()) {
mParcel.dataCapacity();
}
}
@Test
public void timeWriteByte() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
final byte val = 0xF;
while (state.keepRunning()) {
mParcel.setDataPosition(0);
mParcel.writeByte(val);
}
}
@Test
public void timeReadByte() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
while (state.keepRunning()) {
mParcel.setDataPosition(0);
mParcel.readByte();
}
}
@Test
public void timeWriteInt() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
final int val = 0xF;
while (state.keepRunning()) {
mParcel.setDataPosition(0);
mParcel.writeInt(val);
}
}
@Test
public void timeReadInt() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
while (state.keepRunning()) {
mParcel.setDataPosition(0);
mParcel.readInt();
}
}
@Test
public void timeWriteLong() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
final long val = 0xF;
while (state.keepRunning()) {
mParcel.setDataPosition(0);
mParcel.writeLong(val);
}
}
@Test
public void timeReadLong() {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
while (state.keepRunning()) {
mParcel.setDataPosition(0);
mParcel.readLong();
}
}
@Test
public void timeObtainRecycle() {
// Use up the pooled instances.
// A lot bigger than the actual size but in case someone increased it.
final int POOL_SIZE = 100;
for (int i = 0; i < POOL_SIZE; i++) {
Parcel.obtain();
}
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
while (state.keepRunning()) {
Parcel.obtain().recycle();
}
}
@Test
public void timeWriteException() {
timeWriteException(false);
}
@Test
public void timeWriteExceptionWithStackTraceParceling() {
timeWriteException(true);
}
@Test
public void timeReadException() {
timeReadException(false);
}
@Test
public void timeReadExceptionWithStackTraceParceling() {
timeReadException(true);
}
private void timeWriteException(boolean enableParceling) {
if (enableParceling) {
Parcel.setStackTraceParceling(true);
}
try {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
Parcel p = Parcel.obtain();
SecurityException e = new SecurityException("TestMessage");
while (state.keepRunning()) {
p.setDataPosition(0);
p.writeException(e);
}
} finally {
if (enableParceling) {
Parcel.setStackTraceParceling(false);
}
}
}
private void timeReadException(boolean enableParceling) {
if (enableParceling) {
Parcel.setStackTraceParceling(true);
}
try {
final BenchmarkState state = mPerfStatusReporter.getBenchmarkState();
Parcel p = Parcel.obtain();
String msg = "TestMessage";
p.writeException(new SecurityException(msg));
p.setDataPosition(0);
// First verify that remote cause is set (if parceling is enabled)
try {
p.readException();
} catch (SecurityException e) {
assertEquals(e.getMessage(), msg);
if (enableParceling) {
assertTrue(e.getCause() instanceof RemoteException);
} else {
assertNull(e.getCause());
}
}
while (state.keepRunning()) {
p.setDataPosition(0);
try {
p.readException();
} catch (SecurityException expected) {
}
}
} finally {
if (enableParceling) {
Parcel.setStackTraceParceling(false);
}
}
}
}