Back to Repositories

Testing EventMessage Parcelable Implementation in SmartTube

This test suite validates the serialization and deserialization functionality of EventMessage objects in ExoPlayer’s metadata handling system. It ensures proper Parcelable implementation for Android’s inter-process communication.

Test Coverage Overview

The test suite focuses on verifying the Parcelable implementation of EventMessage class.

Key areas covered include:
  • Object serialization to Parcel
  • Object reconstruction from Parcel
  • Equality comparison between original and reconstructed objects

Implementation Analysis

The testing approach uses JUnit4 with AndroidJUnit4 runner for Android-specific testing capabilities. The implementation leverages the Truth assertion library for more readable test assertions and uses Android’s Parcel system for object serialization testing.

The test demonstrates a clear pattern of write-read-verify for Parcelable objects.

Technical Details

Testing tools and configuration:
  • JUnit4 testing framework
  • AndroidJUnit4 test runner
  • Google Truth assertion library
  • Android Parcel system
  • Custom EventMessage implementation with Parcelable interface

Best Practices Demonstrated

The test exhibits several quality testing practices:

  • Clear test method naming that describes the test purpose
  • Proper test isolation and setup
  • Use of modern assertion library for readable verifications
  • Comprehensive object state verification
  • Efficient test data management

yuliskov/smarttube

exoplayer-amzn-2.10.6/library/core/src/test/java/com/google/android/exoplayer2/metadata/emsg/EventMessageTest.java

            
/*
 * Copyright (C) 2017 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.google.android.exoplayer2.metadata.emsg;

import static com.google.common.truth.Truth.assertThat;

import android.os.Parcel;
import androidx.test.ext.junit.runners.AndroidJUnit4;
import org.junit.Test;
import org.junit.runner.RunWith;

/** Test for {@link EventMessage}. */
@RunWith(AndroidJUnit4.class)
public final class EventMessageTest {

  @Test
  public void testEventMessageParcelable() {
    EventMessage eventMessage =
        new EventMessage("urn:test", "123", 3000, 1000403, new byte[] {0, 1, 2, 3, 4});
    // Write to parcel.
    Parcel parcel = Parcel.obtain();
    eventMessage.writeToParcel(parcel, 0);
    // Create from parcel.
    parcel.setDataPosition(0);
    EventMessage fromParcelEventMessage = EventMessage.CREATOR.createFromParcel(parcel);
    // Assert equals.
    assertThat(fromParcelEventMessage).isEqualTo(eventMessage);
  }

}