Search in sources :

Example 1 with CpuActivity

use of com.att.aro.core.peripheral.pojo.CpuActivity in project VideoOptimzer by attdevsupport.

the class CpuActivityReaderImpl method readData.

@Override
public CpuActivityList readData(String directory, double startTime) {
    String cpuFileName = TraceDataConst.FileName.CPU_FILE;
    CpuActivityList cpuActivityList = new CpuActivityList();
    LOGGER.trace("Reading CPU file...");
    String filepath = directory + Util.FILE_SEPARATOR + cpuFileName;
    if (!filereader.fileExist(filepath)) {
        LOGGER.warn("cpu file not found: " + cpuFileName);
        return cpuActivityList;
    }
    String[] lines;
    try {
        lines = filereader.readAllLine(filepath);
    } catch (IOException e) {
        LOGGER.error("Failed to read CPU activity file: " + filepath);
        return cpuActivityList;
    }
    for (String line : lines) {
        if (!line.trim().isEmpty()) {
            CpuActivity cpuact = cpuActivityParser.parseCpuLine(line, startTime);
            cpuActivityList.add(cpuact);
        }
    }
    return cpuActivityList;
}
Also used : CpuActivityList(com.att.aro.core.peripheral.pojo.CpuActivityList) IOException(java.io.IOException) CpuActivity(com.att.aro.core.peripheral.pojo.CpuActivity)

Example 2 with CpuActivity

use of com.att.aro.core.peripheral.pojo.CpuActivity in project VideoOptimzer by attdevsupport.

the class BurstCollectionAnalysisImplTest method analyzeTest.

@Test
public void analyzeTest() {
    // Date date = new Date();
    InetAddress iAdr = Mockito.mock(InetAddress.class);
    InetAddress iAdr1 = Mockito.mock(InetAddress.class);
    Mockito.when(iAdr.getAddress()).thenReturn(new byte[] { 89, 10, 1, 1 });
    Mockito.when(iAdr1.getAddress()).thenReturn(new byte[] { 72, 12, 13, 1 });
    Set<InetAddress> inetSet = new HashSet<InetAddress>();
    inetSet.add(iAdr);
    inetSet.add(iAdr1);
    DomainNameSystem dns = Mockito.mock(DomainNameSystem.class);
    Mockito.when(dns.getIpAddresses()).thenReturn(inetSet);
    Mockito.when(dns.getDomainName()).thenReturn("www.att.com");
    // UDP Packet Mock
    UDPPacket udpPacket = Mockito.mock(UDPPacket.class);
    Mockito.when(udpPacket.isDNSPacket()).thenReturn(true);
    Mockito.when(udpPacket.getDns()).thenReturn(dns);
    Mockito.when(udpPacket.getSourcePort()).thenReturn(83);
    Mockito.when(udpPacket.getDestinationPort()).thenReturn(84);
    Mockito.when(udpPacket.getDestinationIPAddress()).thenReturn(iAdr);
    PacketInfo packetInfo1 = Mockito.mock(PacketInfo.class);
    Mockito.when(packetInfo1.getPacket()).thenReturn(udpPacket);
    Mockito.when(packetInfo1.getDir()).thenReturn(PacketDirection.UPLINK);
    Mockito.when(packetInfo1.getPayloadLen()).thenReturn(30);
    Mockito.when(packetInfo1.getLen()).thenReturn(10);
    Mockito.when(packetInfo1.getAppName()).thenReturn("Test1");
    Mockito.when(packetInfo1.getTcpFlagString()).thenReturn("TestString");
    Mockito.when(packetInfo1.getTimeStamp()).thenReturn(500d);
    InetAddress iAdr2 = Mockito.mock(InetAddress.class);
    Mockito.when(iAdr2.getAddress()).thenReturn(new byte[] { 95, 10, 1, 1 });
    TCPPacket tcpPacket = Mockito.mock(TCPPacket.class);
    Mockito.when(tcpPacket.getSourcePort()).thenReturn(81);
    Mockito.when(tcpPacket.getDestinationPort()).thenReturn(82);
    Mockito.when(tcpPacket.getDestinationIPAddress()).thenReturn(iAdr2);
    Mockito.when(tcpPacket.isSYN()).thenReturn(true);
    Mockito.when(tcpPacket.isFIN()).thenReturn(true);
    Mockito.when(tcpPacket.isRST()).thenReturn(true);
    Mockito.when(tcpPacket.getTimeStamp()).thenReturn(1000d);
    // Mockito.when(tcpPacket.getTimeStamp()).thenReturn((double)date.getTime()-10000);
    PacketInfo packetInfo2 = Mockito.mock(PacketInfo.class);
    Mockito.when(packetInfo2.getPacket()).thenReturn(tcpPacket);
    Mockito.when(packetInfo2.getDir()).thenReturn(PacketDirection.UPLINK);
    Mockito.when(packetInfo2.getTcpInfo()).thenReturn(TcpInfo.TCP_ESTABLISH);
    Mockito.when(packetInfo2.getPayloadLen()).thenReturn(25);
    Mockito.when(packetInfo2.getLen()).thenReturn(15);
    Mockito.when(packetInfo2.getAppName()).thenReturn("Test2");
    Mockito.when(packetInfo2.getTcpFlagString()).thenReturn("Test2String");
    Mockito.when(packetInfo2.getTimeStamp()).thenReturn(10d);
    TCPPacket tcpPacket2 = Mockito.mock(TCPPacket.class);
    Mockito.when(tcpPacket2.getSourcePort()).thenReturn(95);
    Mockito.when(tcpPacket2.getDestinationPort()).thenReturn(99);
    Mockito.when(tcpPacket2.getDestinationIPAddress()).thenReturn(iAdr2);
    Mockito.when(tcpPacket2.isSYN()).thenReturn(true);
    Mockito.when(tcpPacket2.isFIN()).thenReturn(true);
    Mockito.when(tcpPacket2.isRST()).thenReturn(false);
    Mockito.when(tcpPacket2.getTimeStamp()).thenReturn(50d);
    PacketInfo packetInfo3 = Mockito.mock(PacketInfo.class);
    Mockito.when(packetInfo3.getPacket()).thenReturn(tcpPacket2);
    Mockito.when(packetInfo3.getDir()).thenReturn(PacketDirection.DOWNLINK);
    Mockito.when(packetInfo3.getTcpInfo()).thenReturn(TcpInfo.TCP_ACK_RECOVER);
    Mockito.when(packetInfo3.getPayloadLen()).thenReturn(15);
    Mockito.when(packetInfo3.getLen()).thenReturn(20);
    Mockito.when(packetInfo3.getAppName()).thenReturn("Test3");
    Mockito.when(packetInfo3.getTcpFlagString()).thenReturn("Test3String");
    Mockito.when(packetInfo3.getTimeStamp()).thenReturn(700d);
    PacketInfo packetInfo4 = Mockito.mock(PacketInfo.class);
    Mockito.when(packetInfo4.getPacket()).thenReturn(tcpPacket2);
    Mockito.when(packetInfo4.getDir()).thenReturn(PacketDirection.DOWNLINK);
    Mockito.when(packetInfo4.getTcpInfo()).thenReturn(TcpInfo.TCP_ACK);
    Mockito.when(packetInfo4.getTimeStamp()).thenReturn(90d);
    Mockito.when(packetInfo4.getPayloadLen()).thenReturn(10);
    PacketInfo packetInfo5 = Mockito.mock(PacketInfo.class);
    Mockito.when(packetInfo5.getPacket()).thenReturn(tcpPacket2);
    Mockito.when(packetInfo5.getDir()).thenReturn(PacketDirection.DOWNLINK);
    Mockito.when(packetInfo5.getTcpInfo()).thenReturn(TcpInfo.TCP_DATA_RECOVER);
    Mockito.when(packetInfo5.getTimeStamp()).thenReturn(750d);
    Mockito.when(packetInfo5.getPayloadLen()).thenReturn(5);
    List<PacketInfo> packetsList = new ArrayList<PacketInfo>();
    // Adding UDP Packet to the list
    packetsList.add(packetInfo1);
    // Adding TCP Packet to the list
    packetsList.add(packetInfo2);
    packetsList.add(packetInfo3);
    packetsList.add(packetInfo4);
    packetsList.add(packetInfo5);
    ProfileWiFi profile = Mockito.mock(ProfileWiFi.class);
    Mockito.when(profile.getBurstTh()).thenReturn(50d);
    Mockito.when(profile.getLongBurstTh()).thenReturn(40.0d);
    Mockito.when(profile.getLargeBurstDuration()).thenReturn(150d);
    Mockito.when(profile.getLargeBurstSize()).thenReturn(50);
    Mockito.when(profile.getProfileType()).thenReturn(ProfileType.WIFI);
    Mockito.when(profile.getWifiTailTime()).thenReturn(25.0d);
    Mockito.when(profile.getWifiIdlePower()).thenReturn(50.0d);
    Mockito.when(profile.getWifiTailTime()).thenReturn(75.0d);
    Map<Integer, Integer> packetSizeToCountMap = new HashMap<Integer, Integer>();
    packetSizeToCountMap.put(1001, 10);
    packetSizeToCountMap.put(2002, 20);
    packetSizeToCountMap.put(3003, 30);
    RrcStateRange rrcStateRange1 = Mockito.mock(RrcStateRange.class);
    Mockito.when(rrcStateRange1.getBeginTime()).thenReturn(500d);
    Mockito.when(rrcStateRange1.getEndTime()).thenReturn(490d);
    Mockito.when(rrcStateRange1.getState()).thenReturn(RRCState.TAIL_DCH);
    RrcStateRange rrcStateRange2 = Mockito.mock(RrcStateRange.class);
    Mockito.when(rrcStateRange2.getBeginTime()).thenReturn(8.30d);
    Mockito.when(rrcStateRange2.getEndTime()).thenReturn(12.30d);
    Mockito.when(rrcStateRange2.getState()).thenReturn(RRCState.PROMO_FACH_DCH);
    RrcStateRange rrcStateRange3 = Mockito.mock(RrcStateRange.class);
    Mockito.when(rrcStateRange3.getBeginTime()).thenReturn(0.0d);
    Mockito.when(rrcStateRange3.getEndTime()).thenReturn(-2.0d);
    Mockito.when(rrcStateRange3.getState()).thenReturn(RRCState.TAIL_DCH);
    RrcStateRange rrcStateRange4 = Mockito.mock(RrcStateRange.class);
    Mockito.when(rrcStateRange4.getBeginTime()).thenReturn(25d);
    Mockito.when(rrcStateRange4.getEndTime()).thenReturn(75d);
    Mockito.when(rrcStateRange4.getState()).thenReturn(RRCState.WIFI_TAIL);
    RrcStateRange rrcStateRange5 = Mockito.mock(RrcStateRange.class);
    Mockito.when(rrcStateRange5.getBeginTime()).thenReturn(55d);
    Mockito.when(rrcStateRange5.getEndTime()).thenReturn(95d);
    Mockito.when(rrcStateRange5.getState()).thenReturn(RRCState.PROMO_IDLE_DCH);
    List<RrcStateRange> rrcstaterangelist = new ArrayList<RrcStateRange>();
    rrcstaterangelist.add(rrcStateRange1);
    rrcstaterangelist.add(rrcStateRange2);
    rrcstaterangelist.add(rrcStateRange3);
    rrcstaterangelist.add(rrcStateRange4);
    rrcstaterangelist.add(rrcStateRange5);
    UserEvent uEvent1 = Mockito.mock(UserEvent.class);
    Mockito.when(uEvent1.getEventType()).thenReturn(UserEventType.SCREEN_LANDSCAPE);
    Mockito.when(uEvent1.getPressTime()).thenReturn(503d);
    Mockito.when(uEvent1.getReleaseTime()).thenReturn(6d);
    UserEvent uEvent2 = Mockito.mock(UserEvent.class);
    Mockito.when(uEvent2.getEventType()).thenReturn(UserEventType.SCREEN_PORTRAIT);
    Mockito.when(uEvent2.getPressTime()).thenReturn(14d);
    Mockito.when(uEvent2.getReleaseTime()).thenReturn(2000d);
    UserEvent uEvent3 = Mockito.mock(UserEvent.class);
    Mockito.when(uEvent3.getEventType()).thenReturn(UserEventType.KEY_RED);
    Mockito.when(uEvent3.getPressTime()).thenReturn(497d);
    Mockito.when(uEvent3.getReleaseTime()).thenReturn(499d);
    UserEvent uEvent4 = Mockito.mock(UserEvent.class);
    Mockito.when(uEvent4.getEventType()).thenReturn(UserEventType.EVENT_UNKNOWN);
    Mockito.when(uEvent4.getPressTime()).thenReturn(25d);
    Mockito.when(uEvent4.getReleaseTime()).thenReturn(4d);
    UserEvent uEvent5 = Mockito.mock(UserEvent.class);
    Mockito.when(uEvent5.getEventType()).thenReturn(UserEventType.KEY_SEARCH);
    Mockito.when(uEvent5.getPressTime()).thenReturn(752d);
    Mockito.when(uEvent5.getReleaseTime()).thenReturn(30000d);
    List<UserEvent> uEventList = new ArrayList<UserEvent>();
    uEventList.add(uEvent1);
    uEventList.add(uEvent2);
    uEventList.add(uEvent3);
    uEventList.add(uEvent4);
    uEventList.add(uEvent5);
    CpuActivity cActivity1 = Mockito.mock(CpuActivity.class);
    Mockito.when(cActivity1.getTimeStamp()).thenReturn(23000d);
    Mockito.when(cActivity1.getTotalCpuUsage()).thenReturn(5000d);
    CpuActivity cActivity2 = Mockito.mock(CpuActivity.class);
    Mockito.when(cActivity2.getTimeStamp()).thenReturn(24000d);
    Mockito.when(cActivity2.getTotalCpuUsage()).thenReturn(6000d);
    CpuActivity cActivity3 = Mockito.mock(CpuActivity.class);
    Mockito.when(cActivity3.getTimeStamp()).thenReturn(25000d);
    Mockito.when(cActivity3.getTotalCpuUsage()).thenReturn(6000d);
    List<CpuActivity> cpuActivityList = new ArrayList<CpuActivity>();
    cpuActivityList.add(cActivity1);
    cpuActivityList.add(cActivity2);
    cpuActivityList.add(cActivity3);
    Session aSession = Mockito.mock(Session.class);
    List<Session> sessionList = new ArrayList<Session>();
    sessionList.add(aSession);
    BurstCollectionAnalysisData bcaData = aBurstCollectionAnalysis.analyze(packetsList, profile, packetSizeToCountMap, rrcstaterangelist, uEventList, cpuActivityList, sessionList);
    assertEquals(2, bcaData.getBurstAnalysisInfo().size());
    assertEquals(3, bcaData.getBurstCollection().size());
    assertEquals(0, bcaData.getLongBurstCount());
    assertEquals(0, (int) bcaData.getTotalEnergy());
}
Also used : DomainNameSystem(com.att.aro.core.packetreader.pojo.DomainNameSystem) HashMap(java.util.HashMap) ArrayList(java.util.ArrayList) RrcStateRange(com.att.aro.core.packetanalysis.pojo.RrcStateRange) UDPPacket(com.att.aro.core.packetreader.pojo.UDPPacket) UserEvent(com.att.aro.core.peripheral.pojo.UserEvent) TCPPacket(com.att.aro.core.packetreader.pojo.TCPPacket) PacketInfo(com.att.aro.core.packetanalysis.pojo.PacketInfo) BurstCollectionAnalysisData(com.att.aro.core.packetanalysis.pojo.BurstCollectionAnalysisData) ProfileWiFi(com.att.aro.core.configuration.pojo.ProfileWiFi) InetAddress(java.net.InetAddress) CpuActivity(com.att.aro.core.peripheral.pojo.CpuActivity) HashSet(java.util.HashSet) Session(com.att.aro.core.packetanalysis.pojo.Session) BaseTest(com.att.aro.core.BaseTest) Test(org.junit.Test)

Example 3 with CpuActivity

use of com.att.aro.core.peripheral.pojo.CpuActivity in project VideoOptimzer by attdevsupport.

the class CpuActivityParserImplTest method readData.

@Test
public void readData() throws IOException {
    reader = (CpuActivityParserImpl) context.getBean(ICpuActivityParser.class);
    CpuActivity cpuActivity = reader.parseCpuLine("1.413913604E9 56 /sbin/adbd=29 com.android.systemui=9 /system/bin/surfaceflinger=4 system_server=3 top=1", 1.413913604E9);
    double usage = cpuActivity.getTotalCpuUsage();
    assertEquals(56, usage, 0);
}
Also used : CpuActivity(com.att.aro.core.peripheral.pojo.CpuActivity) Test(org.junit.Test) BaseTest(com.att.aro.core.BaseTest)

Example 4 with CpuActivity

use of com.att.aro.core.peripheral.pojo.CpuActivity in project VideoOptimzer by attdevsupport.

the class CpuPlot method constructCpuToolTipText.

private String constructCpuToolTipText(CpuActivityList cpuAList, List<CpuActivity> cpuData, int item) {
    CpuActivity cpuA = cpuData.get(item);
    StringBuffer toolTip = new StringBuffer(ResourceBundleHelper.getMessageString("cpu.tooltip.prefix"));
    // generate initial opening total CPU tooltip
    String totalCpuTxt = MessageFormat.format(ResourceBundleHelper.getMessageString("cpu.tooltip.total"), cpuA.getCpuUsageTotalFiltered());
    toolTip.append(totalCpuTxt);
    // generate individual process CPU tooltip
    String individualCpuToolTips = generateIndividualCpuToolTips(cpuAList, cpuA);
    if (individualCpuToolTips != null) {
        toolTip.append(individualCpuToolTips);
    }
    // generate other tooltip
    if (cpuA.getCpuUsageOther() > 0) {
        String otherCpu = MessageFormat.format(ResourceBundleHelper.getMessageString("cpu.tooltip.other"), cpuA.getCpuUsageOther());
        toolTip.append(otherCpu);
    }
    // generate closing tooltip
    toolTip.append(ResourceBundleHelper.getMessageString("cpu.tooltip.suffix"));
    return toolTip.toString();
}
Also used : CpuActivity(com.att.aro.core.peripheral.pojo.CpuActivity)

Example 5 with CpuActivity

use of com.att.aro.core.peripheral.pojo.CpuActivity in project VideoOptimzer by attdevsupport.

the class CpuActivityParserImpl method parseCpuLine.

@Override
public CpuActivity parseCpuLine(String cpuLine, double pcapTime) {
    CpuActivity cpuActivity = null;
    String pattern = "[\\s=]";
    String[] splitLine = cpuLine.split(pattern);
    int numOfElements = splitLine.length;
    if (numOfElements < (CpuActivity.TOTAL_CPU_INFO_IDX + 1)) {
        return null;
    }
    cpuActivity = new CpuActivity();
    double time = Double.parseDouble(splitLine[CpuActivity.TIMESTAMP_IDX]);
    double timeStamp = Util.normalizeTime(time, pcapTime);
    double cpuUsageTotal = Double.parseDouble(splitLine[CpuActivity.TOTAL_CPU_INFO_IDX]);
    double cpuUsageTotalFiltered = cpuUsageTotal;
    cpuActivity.setTimestamp(timeStamp);
    cpuActivity.setTotalCpuUsage(cpuUsageTotal);
    cpuActivity.setCpuUsageTotalFiltered(cpuUsageTotalFiltered);
    if ((numOfElements >= (CpuActivity.PROCESS_INFO_IDX + 1)) && (((numOfElements - CpuActivity.PROCESS_INFO_IDX) % 2) == 0)) {
        List<String> processNameList = new ArrayList<String>();
        List<Double> cpuProcessUsageList = new ArrayList<Double>();
        String procName;
        String cpuUsage;
        for (int i = CpuActivity.PROCESS_INFO_IDX; i < splitLine.length; i++) {
            procName = splitLine[i];
            cpuUsage = splitLine[++i];
            processNameList.add(procName);
            cpuProcessUsageList.add(Double.parseDouble(cpuUsage));
        }
        cpuActivity.setProcessNames(processNameList);
        cpuActivity.setCpuUsages(cpuProcessUsageList);
        double other = 0.0;
        for (Double individualCpuUsage : cpuActivity.getCpuUsages()) {
            other += individualCpuUsage.doubleValue();
        }
        other = cpuUsageTotal - other;
        cpuActivity.setCpuUsageOther(other);
    }
    return cpuActivity;
}
Also used : ArrayList(java.util.ArrayList) CpuActivity(com.att.aro.core.peripheral.pojo.CpuActivity)

Aggregations

CpuActivity (com.att.aro.core.peripheral.pojo.CpuActivity)11 BaseTest (com.att.aro.core.BaseTest)6 ArrayList (java.util.ArrayList)6 Test (org.junit.Test)6 PacketInfo (com.att.aro.core.packetanalysis.pojo.PacketInfo)5 HashSet (java.util.HashSet)5 BurstCollectionAnalysisData (com.att.aro.core.packetanalysis.pojo.BurstCollectionAnalysisData)4 RrcStateRange (com.att.aro.core.packetanalysis.pojo.RrcStateRange)4 DomainNameSystem (com.att.aro.core.packetreader.pojo.DomainNameSystem)4 TCPPacket (com.att.aro.core.packetreader.pojo.TCPPacket)4 UDPPacket (com.att.aro.core.packetreader.pojo.UDPPacket)4 UserEvent (com.att.aro.core.peripheral.pojo.UserEvent)4 InetAddress (java.net.InetAddress)4 ProfileLTE (com.att.aro.core.configuration.pojo.ProfileLTE)3 Session (com.att.aro.core.packetanalysis.pojo.Session)3 CpuActivityList (com.att.aro.core.peripheral.pojo.CpuActivityList)3 HashMap (java.util.HashMap)3 AnalysisFilter (com.att.aro.core.packetanalysis.pojo.AnalysisFilter)2 PacketAnalyzerResult (com.att.aro.core.packetanalysis.pojo.PacketAnalyzerResult)2 TraceDirectoryResult (com.att.aro.core.packetanalysis.pojo.TraceDirectoryResult)2