Bug: webrtc:13662 Change-Id: I7ae28a61ea8f7e578d8aef8e3104f8564f3dd7b6 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/256621 Auto-Submit: Xavier Lepaul <xalep@webrtc.org> Reviewed-by: Linus Nilsson <lnilsson@webrtc.org> Commit-Queue: Xavier Lepaul <xalep@webrtc.org> Cr-Commit-Position: refs/heads/main@{#36318}
84 lines
2.3 KiB
Java
84 lines
2.3 KiB
Java
/*
|
|
* Copyright 2020 The WebRTC Project Authors. All rights reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
package org.webrtc;
|
|
|
|
import static com.google.common.truth.Truth.assertThat;
|
|
import static org.mockito.Mockito.never;
|
|
import static org.mockito.Mockito.verify;
|
|
|
|
import androidx.test.runner.AndroidJUnit4;
|
|
import org.junit.Before;
|
|
import org.junit.Test;
|
|
import org.junit.runner.RunWith;
|
|
import org.mockito.Mock;
|
|
import org.mockito.MockitoAnnotations;
|
|
import org.robolectric.annotation.Config;
|
|
|
|
@RunWith(AndroidJUnit4.class)
|
|
@Config(manifest = Config.NONE)
|
|
public class RefCountDelegateTest {
|
|
@Mock Runnable mockReleaseCallback;
|
|
private RefCountDelegate refCountDelegate;
|
|
|
|
@Before
|
|
public void setUp() {
|
|
MockitoAnnotations.initMocks(this);
|
|
|
|
refCountDelegate = new RefCountDelegate(mockReleaseCallback);
|
|
}
|
|
|
|
@Test
|
|
public void testReleaseRunsReleaseCallback() {
|
|
refCountDelegate.release();
|
|
verify(mockReleaseCallback).run();
|
|
}
|
|
|
|
@Test
|
|
public void testRetainIncreasesRefCount() {
|
|
refCountDelegate.retain();
|
|
|
|
refCountDelegate.release();
|
|
verify(mockReleaseCallback, never()).run();
|
|
|
|
refCountDelegate.release();
|
|
verify(mockReleaseCallback).run();
|
|
}
|
|
|
|
@Test(expected = IllegalStateException.class)
|
|
public void testReleaseAfterFreeThrowsIllegalStateException() {
|
|
refCountDelegate.release();
|
|
refCountDelegate.release();
|
|
}
|
|
|
|
@Test(expected = IllegalStateException.class)
|
|
public void testRetainAfterFreeThrowsIllegalStateException() {
|
|
refCountDelegate.release();
|
|
refCountDelegate.retain();
|
|
}
|
|
|
|
@Test
|
|
public void testSafeRetainBeforeFreeReturnsTrueAndIncreasesRefCount() {
|
|
assertThat(refCountDelegate.safeRetain()).isTrue();
|
|
|
|
refCountDelegate.release();
|
|
verify(mockReleaseCallback, never()).run();
|
|
|
|
refCountDelegate.release();
|
|
verify(mockReleaseCallback).run();
|
|
}
|
|
|
|
@Test
|
|
public void testSafeRetainAfterFreeReturnsFalse() {
|
|
refCountDelegate.release();
|
|
assertThat(refCountDelegate.safeRetain()).isFalse();
|
|
}
|
|
}
|