summaryrefslogtreecommitdiff
path: root/tests/src/com/android/loganalysis/util/LogPatternUtilTest.java
blob: 98226d4ebd530f10284fdcd597c21a3fed6fa67c (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
/*
 * 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.util;

import junit.framework.TestCase;

import java.util.regex.Pattern;

/**
 * Unit tests for {@link LogPatternUtil}.
 */
public class LogPatternUtilTest extends TestCase {

    /**
     * Test basic pattern matching.
     */
    public void testPatternMatching() {
        LogPatternUtil patternUtil = new LogPatternUtil();
        patternUtil.addPattern(Pattern.compile("abc"), "cat1");
        patternUtil.addPattern(Pattern.compile("123"), "cat2");

        assertNull(patternUtil.checkMessage("xyz"));
        assertEquals("cat1", patternUtil.checkMessage("abc"));
        assertEquals("cat2", patternUtil.checkMessage("123"));
    }

    /**
     * Test pattern matching with extras.
     */
    public void testExtrasMatching() {
        LogPatternUtil patternUtil = new LogPatternUtil();
        patternUtil.addPattern(Pattern.compile("abc"), null, "cat1");
        patternUtil.addPattern(Pattern.compile("123"), "E/tag1", "cat2");
        patternUtil.addPattern(Pattern.compile("123"), "E/tag2", "cat3");

        assertNull(patternUtil.checkMessage("xyz"));
        assertEquals("cat1", patternUtil.checkMessage("abc"));
        assertEquals("cat1", patternUtil.checkMessage("abc", "E/tag1"));
        assertEquals("cat1", patternUtil.checkMessage("abc", "E/tag2"));
        assertNull(patternUtil.checkMessage("123"));
        assertEquals("cat2", patternUtil.checkMessage("123", "E/tag1"));
        assertEquals("cat3", patternUtil.checkMessage("123", "E/tag2"));
    }
}