summaryrefslogtreecommitdiff
path: root/tests/src/com/android/loganalysis/heuristic/MemoryUsageHeuristicTest.java
blob: c185badbf451d6ab4f07f2eda1e82382bacd7aaf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/*
 * Copyright (C) 2013 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.android.loganalysis.heuristic;

import com.android.loganalysis.item.LogcatItem;
import com.android.loganalysis.item.MemInfoItem;
import com.android.loganalysis.item.MiscLogcatItem;
import com.android.loganalysis.parser.LogcatParser;

import junit.framework.TestCase;

/**
 * Unit test for {@link MemoryUsageHeuristic}.
 */
public class MemoryUsageHeuristicTest extends TestCase {

    /**
     * Test that {@link MemoryUsageHeuristic#failed()} returns true if memory usage is high.
     */
    public void testCheckHeuristic_high_memory() {
        MemoryUsageHeuristic heuristic = new MemoryUsageHeuristic();
        MemInfoItem memInfo = new MemInfoItem();
        memInfo.put("MemTotal", 1000000);
        memInfo.put("MemFree", (int) ((1.0 - heuristic.getCutoff()) * memInfo.get("MemTotal")) - 1);
        heuristic.addMemInfo(null, memInfo);

        assertTrue(heuristic.failed());
    }

    /**
     * Test that {@link MemoryUsageHeuristic#failed()} returns false if memory usage is low.
     */
    public void testCheckHeuristic_low_memory() {
        MemoryUsageHeuristic heuristic = new MemoryUsageHeuristic();
        MemInfoItem memInfo = new MemInfoItem();
        memInfo.put("MemTotal", 1000000);
        memInfo.put("MemFree", (int) ((1.0 - heuristic.getCutoff()) * memInfo.get("MemTotal")) + 1);
        heuristic.addMemInfo(null, memInfo);

        assertFalse(heuristic.failed());
    }

    /**
     * Test that {@link CpuUsageHeuristic#failed()} returns true if a high memory usage
     * indicator is found in the logcat.
     */
    public void testCheckHeuristic_logcat() {
        MemoryUsageHeuristic heuristic = new MemoryUsageHeuristic();
        LogcatItem logcat = new LogcatItem();
        MiscLogcatItem item = new MiscLogcatItem();
        item.setCategory(LogcatParser.HIGH_MEMORY_USAGE);
        logcat.addEvent(item);
        heuristic.addLogcat(null, logcat);

        assertTrue(heuristic.failed());
    }
}