All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.callstats.sdk.CallStatsTest Maven / Gradle / Ivy

There is a newer version: 5.4.0
Show newest version
package io.callstats.sdk;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import java.util.Random;
import org.junit.Before;
import org.junit.Ignore;
import org.junit.Test;
import org.mockito.Mockito;
import org.powermock.api.mockito.PowerMockito;
import com.google.gson.Gson;
import io.callstats.sdk.data.BridgeStatusInfo;
import io.callstats.sdk.data.BridgeStatusInfoBuilder;
import io.callstats.sdk.data.CallStatsStreamType;
import io.callstats.sdk.data.ConferenceInfo;
import io.callstats.sdk.data.ConferenceStats;
import io.callstats.sdk.data.ConferenceStatsBuilder;
import io.callstats.sdk.data.ServerInfo;
import io.callstats.sdk.listeners.CallStatsInitListener;
import io.callstats.sdk.listeners.CallStatsStartConferenceListener;

/**
 * The Class CallStatsTest.
 *
 * @author Karthik Budigere
 */
public class CallStatsTest {

  /** The callstatslib. */
  CallStats callstatslib;

  /** The listener. */
  CallStatsInitListener listener;

  /** The endpoint info. */
  ServerInfo serverInfo;

  /** The app id. */
  public static int appId = 1234567;

  /** The app secret. */
  public static String appSecret = "app_secret";

  public static String bridgeId = "winteriscoming";

  /**
   * Sets the up.
   */
  @Before
  public void setUp() {
    serverInfo = new ServerInfo();
    serverInfo.setName("winter");
    serverInfo.setOs("LINUX");
    serverInfo.setVer("4.4");
    System.out.println("Setup completed");
    callstatslib = PowerMockito.spy(new CallStats());
    listener = Mockito.mock(CallStatsInitListener.class);
  }

  /**
   * Initialize test.
   */
  @Test
  public void initializeTest() {

    callstatslib.initialize(appId, appSecret, "jit.si.345", serverInfo, listener);
    try {
      Thread.sleep(5000);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
    String msg = "SDK authentication successful";
    Mockito.verify(listener).onInitialized(msg);
  }

  /**
   * Initialize with invalid app id test.
   */
  @Ignore
  public void initializeWithInvalidAppIdTest() {
    CallStatsErrors error = CallStatsErrors.HTTP_ERROR;
    String errMsg = "SDK Authentication Error";

    callstatslib.initialize(appId + 1, appSecret, "jit.si.345", serverInfo, listener);

    try {
      Thread.sleep(2000);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
    Mockito.verify(listener).onError(error, errMsg);
  }

  /**
   * Initialize with null args test.
   */
  @Ignore
  public void initializeWithNullArgsTest() {
    Throwable e = null;

    try {

      callstatslib.initialize(0, appSecret, "jit.si.345", serverInfo, listener);

    } catch (Throwable e1) {
      e = e1;
    }
    assertTrue(e instanceof IllegalArgumentException);

    try {

      callstatslib.initialize(appId, appSecret, null, serverInfo, listener);

    } catch (Throwable e1) {
      e = e1;
    }
    assertTrue(e instanceof IllegalArgumentException);

    try {

      callstatslib.initialize(appId, "", "jit.si.345", serverInfo, listener);

    } catch (Throwable e1) {
      e = e1;
    }
    assertTrue(e instanceof IllegalArgumentException);

    try {
      callstatslib.initialize(appId, appSecret, "", serverInfo, listener);

    } catch (Throwable e1) {
      e = e1;
    }
    assertTrue(e instanceof IllegalArgumentException);
  }

  /**
   * Initialize test with send call stats event.
   *
   */
  @Test
  public void initializeTestWithSendCallStatsEvent() {
    callstatslib.initialize(appId, appSecret, "jit.si.346", serverInfo, listener);
    Random randomGenerator = new Random();
    try {
      Thread.sleep(2000);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
    String msg = "SDK authentication successful";
    Mockito.verify(listener).onInitialized(msg);

    for (int i = 0; i < 2; i++) {
      BridgeStatusInfoBuilder bridgeStatusInfoBuilder = new BridgeStatusInfoBuilder();
      BridgeStatusInfo bridgeStatusInfo = bridgeStatusInfoBuilder
          .cpuUsage(randomGenerator.nextInt(100)).threadCount(randomGenerator.nextInt(1000))
          .memoryUsage(randomGenerator.nextInt(5000))
          .intervalRtpFractionLoss(randomGenerator.nextFloat())
          .avgIntervalJitter(randomGenerator.nextFloat())
          .avgIntervalRtt(randomGenerator.nextFloat()).conferenceCount(randomGenerator.nextInt(100))
          .participantsCount(randomGenerator.nextInt(5000))
          .videoFabricCount(randomGenerator.nextInt(1000))
          .audioFabricCount(randomGenerator.nextInt(1000))
          .intervalDownloadBitRate(randomGenerator.nextInt(100))
          .intervalUploadBitRate(randomGenerator.nextInt(100))
          .totalLoss(randomGenerator.nextInt(100)).intervalSentBytes(randomGenerator.nextInt(10000))
          .intervalReceivedBytes(randomGenerator.nextInt(10000)).build();
      callstatslib.sendCallStatsBridgeStatusUpdate(bridgeStatusInfo);
    }
    try {
      Thread.sleep(15000);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
  }

  /**
   * Starts stats build test.
   */
  @Test
  public void statsBuildTest() {
    String res =
        "{\"type\":\"inbound\",\"ssrc\":\"34567898\",\"packetsSent\":34556,\"bytesSent\":23456,\"rtt\":34,\"avsync\":3.2}";
    ConferenceStats conferenceStats =
        new ConferenceStatsBuilder().bytesSent(23456).packetsSent(34556).ssrc("34567898")
            .confID("confID").localUserID("2345").remoteUserID("1234")
            .statsType(CallStatsStreamType.INBOUND).rtt(34).avsync(3.2).ucID("ucid").build();
    Gson gson = new Gson();
    String statsString = gson.toJson(conferenceStats);
    assertEquals(res, statsString);
  }

  @Test
  public void initializeTestWihSendCallStatsConferenceStartEvent() {
    callstatslib.initialize(appId, appSecret, "jit.si.346", serverInfo, listener);
    try {
      Thread.sleep(2000);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
    String msg = "SDK authentication successful";
    Mockito.verify(listener).onInitialized(msg);

    ConferenceInfo conferenceInfo = new ConferenceInfo("callstats.io/room1", "2345", "site1");
    System.out.println("sending conference start ");
    callstatslib.sendCallStatsConferenceEvent(CallStatsConferenceEvents.CONFERENCE_SETUP,
        conferenceInfo, new CallStatsStartConferenceListener() {
          public void onResponse(String ucid) {
            String userID = "2345";
            String confID = "callstats.io/room1";
            System.out.println("UCID is " + ucid);
            // UserInfo userInfo = new UserInfo(confID, userID, ucid);

            // callstatslib.sendCallStatsConferenceEvent(CallStatsConferenceEvents.CONFERENCE_TERMINATED,
            // userInfo);

            callstatslib.startStatsReportingForUser(userID, confID);
            ConferenceStats conferenceStats = new ConferenceStatsBuilder().bytesSent(23456)
                .packetsSent(34556).ssrc("34567898").confID(confID).localUserID("2345")
                .remoteUserID("1234").statsType(CallStatsStreamType.INBOUND).jitter(3).rtt(34)
                .avsync(3.2).ucID(ucid).build();
            callstatslib.reportConferenceStats(userID, conferenceStats);

            conferenceStats = new ConferenceStatsBuilder().bytesSent(23456).packetsSent(34556)
                .ssrc("34567899").confID(confID).localUserID("2345").remoteUserID("1234")
                .statsType(CallStatsStreamType.INBOUND).jitter(3).rtt(34).avsync(3.2).ucID(ucid)
                .build();
            callstatslib.reportConferenceStats(userID, conferenceStats);

            conferenceStats =
                new ConferenceStatsBuilder().bytesSent(23456).packetsSent(34556).ssrc("34567890")
                    .confID(confID).fromUserID("2345").localUserID("2345").remoteUserID("1234")
                    .statsType(CallStatsStreamType.OUTBOUND).jitter(3).rtt(34).ucID(ucid).build();
            callstatslib.reportConferenceStats(userID, conferenceStats);

            callstatslib.stopStatsReportingForUser(userID, confID);

          }

          public void onError(CallStatsErrors error, String errMsg) {

        }
        });

    try {
      Thread.sleep(3000);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }

  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy