1
/*******************************************************************************
2
* Copyright (c) 2009 Red Hat, Inc.
3
* All rights reserved. This program and the accompanying materials
4
* are made available under the terms of the Eclipse Public License v1.0
5
* which accompanies this distribution, and is available at
6
* http://www.eclipse.org/legal/epl-v10.html
9
* Kent Sebastian <ksebasti@redhat.com> - initial API and implementation
10
*******************************************************************************/
11
package org.eclipse.linuxtools.oprofile.core.tests;
13
import java.io.FileReader;
15
import javax.xml.parsers.SAXParserFactory;
17
import junit.framework.TestCase;
19
import org.eclipse.core.runtime.FileLocator;
20
import org.eclipse.core.runtime.Path;
21
import org.eclipse.linuxtools.internal.oprofile.core.model.OpModelImage;
22
import org.eclipse.linuxtools.internal.oprofile.core.model.OpModelSample;
23
import org.eclipse.linuxtools.internal.oprofile.core.model.OpModelSymbol;
24
import org.eclipse.linuxtools.internal.oprofile.core.opxml.OprofileSAXHandler;
25
import org.eclipse.linuxtools.internal.oprofile.core.opxml.modeldata.ModelDataProcessor;
26
import org.osgi.framework.FrameworkUtil;
27
import org.xml.sax.InputSource;
28
import org.xml.sax.XMLReader;
30
public class TestModelDataParse extends TestCase {
31
private static final String REL_PATH_TO_TEST_XML = "resources/test_model-data.xml"; //$NON-NLS-1$
32
private static final String REL_PATH_TO_TEST_XML_MULTI_IMAGE = "resources/test_model-data_multiple_image.xml"; //$NON-NLS-1$
33
private static final String IMAGE_OUTPUT = "/test/path/for/image, Count: 205000, Dependent Count: 5000\nSymbols: TestFunction1(int), File: /test/path/for/src/image.cpp, Count: 180000\n\tSample: Line #: 42, Count: 130000\n\tSample: Line #: 36, Count: 40000\n\tSample: Line #: 31, Count: 9999\n\tSample: Line #: 39, Count: 1\nSymbols: TestFunction2(int, int), File: /test/path/for/src/image2.cpp, Count: 20000\n\tSample: Line #: 94, Count: 19998\n\tSample: Line #: 12, Count: 1\n\tSample: Line #: 55, Count: 1\nDependent Image: /no-vmlinux, Count: 4400\nDependent Image: /lib64/ld-2.9.so, Count: 300\n\tSymbols: do_lookup_x, File: dl-lookup.c, Count: 299\n\t\tSample: Line #: 0, Count: 299\n\tSymbols: _dl_unload_cache, File: rawmemchr.c, Count: 1\n\t\tSample: Line #: 0, Count: 1\nDependent Image: /usr/lib64/libstdc++.so.6.0.10, Count: 160\nDependent Image: /lib64/libc-2.9.so, Count: 140\n\tSymbols: _IO_new_file_seekoff, File: , Count: 100\n\t\tSample: Line #: 0, Count: 100\n\tSymbols: bool std::operator!=<char, std::char_traits<char>, std::allocator<char> >(std::basic_string<char, std::char_traits<char>, std::allocator<char> > const&, char const*), File: , Count: 40\n\t\tSample: Line #: 0, Count: 40\n"; //$NON-NLS-1$
34
private static final String IMAGE_OUTPUT_WITHTAB = "/test/path/for/image, Count: 205000, Dependent Count: 5000\n\tSymbols: TestFunction1(int), File: /test/path/for/src/image.cpp, Count: 180000\n\t\tSample: Line #: 42, Count: 130000\n\t\tSample: Line #: 36, Count: 40000\n\t\tSample: Line #: 31, Count: 9999\n\t\tSample: Line #: 39, Count: 1\n\tSymbols: TestFunction2(int, int), File: /test/path/for/src/image2.cpp, Count: 20000\n\t\tSample: Line #: 94, Count: 19998\n\t\tSample: Line #: 12, Count: 1\n\t\tSample: Line #: 55, Count: 1\n\tDependent Image: /no-vmlinux, Count: 4400\n\tDependent Image: /lib64/ld-2.9.so, Count: 300\n\t\tSymbols: do_lookup_x, File: dl-lookup.c, Count: 299\n\t\t\tSample: Line #: 0, Count: 299\n\t\tSymbols: _dl_unload_cache, File: rawmemchr.c, Count: 1\n\t\t\tSample: Line #: 0, Count: 1\n\tDependent Image: /usr/lib64/libstdc++.so.6.0.10, Count: 160\n\tDependent Image: /lib64/libc-2.9.so, Count: 140\n\t\tSymbols: _IO_new_file_seekoff, File: , Count: 100\n\t\t\tSample: Line #: 0, Count: 100\n\t\tSymbols: bool std::operator!=<char, std::char_traits<char>, std::allocator<char> >(std::basic_string<char, std::char_traits<char>, std::allocator<char> > const&, char const*), File: , Count: 40\n\t\t\tSample: Line #: 0, Count: 40\n"; //$NON-NLS-1$
36
private OpModelImage parsedImage;
37
private OpModelImage parsedErrorImage;
39
public TestModelDataParse() {
40
super("test model-data parsers"); //$NON-NLS-1$
44
protected void setUp() throws Exception {
45
/* this code mostly taken from OpxmlRunner */
46
XMLReader reader = null;
47
parsedImage = new OpModelImage();
48
ModelDataProcessor.CallData image = new ModelDataProcessor.CallData(parsedImage);
49
OprofileSAXHandler handler = OprofileSAXHandler.getInstance(image);
52
SAXParserFactory factory = SAXParserFactory.newInstance();
53
reader = factory.newSAXParser().getXMLReader();
55
// Set content/error handlers
56
reader.setContentHandler(handler);
57
reader.setErrorHandler(handler);
59
String filePath = FileLocator.toFileURL(FileLocator.find(FrameworkUtil.getBundle(this.getClass()), new Path(REL_PATH_TO_TEST_XML), null)).getFile();
60
reader.parse(new InputSource(new FileReader(filePath)));
63
parsedErrorImage = new OpModelImage();
64
ModelDataProcessor.CallData errorImage = new ModelDataProcessor.CallData(parsedErrorImage);
65
handler = OprofileSAXHandler.getInstance(errorImage);
67
// Set content/error handlers
68
reader.setContentHandler(handler);
69
reader.setErrorHandler(handler);
71
filePath = FileLocator.toFileURL(FileLocator.find(FrameworkUtil.getBundle(this.getClass()), new Path(REL_PATH_TO_TEST_XML_MULTI_IMAGE), null)).getFile();
72
reader.parse(new InputSource(new FileReader(filePath)));
75
public void testParse() {
77
assertEquals("/test/path/for/image", parsedImage.getName()); //$NON-NLS-1$
78
assertEquals(205000, parsedImage.getCount());
81
OpModelSymbol[] symbols = parsedImage.getSymbols();
82
assertEquals(2, symbols.length);
83
OpModelSymbol sym1 = symbols[0], sym2 = symbols[1];
84
assertEquals("TestFunction1(int)", sym1.getName()); //$NON-NLS-1$
85
assertEquals("/test/path/for/src/image.cpp", sym1.getFilePath()); //$NON-NLS-1$
86
assertEquals(180000, sym1.getCount());
87
assertEquals("TestFunction2(int, int)", sym2.getName()); //$NON-NLS-1$
88
assertEquals("/test/path/for/src/image2.cpp", sym2.getFilePath()); //$NON-NLS-1$
89
assertEquals(20000, sym2.getCount());
92
OpModelSample[] sym1_spls = sym1.getSamples(), sym2_spls = sym2.getSamples();
93
assertEquals(4, sym1_spls.length);
94
assertEquals(3, sym2_spls.length);
95
OpModelSample sym1_spl1 = sym1_spls[0], sym1_spl2 = sym1_spls[1], sym1_spl3 = sym1_spls[2], sym1_spl4 = sym1_spls[3];
96
OpModelSample sym2_spl1 = sym2_spls[0], sym2_spl2 = sym2_spls[1], sym2_spl3 = sym2_spls[2];
97
assertEquals(130000, sym1_spl1.getCount());
98
assertEquals(42, sym1_spl1.getLine());
99
assertEquals(40000, sym1_spl2.getCount());
100
assertEquals(36, sym1_spl2.getLine());
101
assertEquals(9999, sym1_spl3.getCount());
102
assertEquals(31, sym1_spl3.getLine());
103
assertEquals(1, sym1_spl4.getCount());
104
assertEquals(39, sym1_spl4.getLine());
105
assertEquals(19998, sym2_spl1.getCount());
106
assertEquals(94, sym2_spl1.getLine());
107
assertEquals(1, sym2_spl2.getCount());
108
assertEquals(12, sym2_spl2.getLine());
109
assertEquals(1, sym2_spl3.getCount());
110
assertEquals(55, sym2_spl3.getLine());
112
//test dependent images
113
assertEquals(true, parsedImage.hasDependents());
114
assertEquals(5000, parsedImage.getDepCount());
115
OpModelImage[] deps = parsedImage.getDependents();
116
assertEquals(4, deps.length);
117
OpModelImage dep1 = deps[0], dep2 = deps[1], dep3 = deps[2], dep4 = deps[3];
119
assertEquals(false, dep1.hasDependents());
120
assertEquals("/no-vmlinux", dep1.getName()); //$NON-NLS-1$
121
assertEquals(4400, dep1.getCount());
123
assertEquals(false, dep2.hasDependents());
124
OpModelSymbol[] dep2_syms = dep2.getSymbols();
125
assertEquals(2, dep2_syms.length);
126
OpModelSymbol dep2_sym1 = dep2_syms[0], dep2_sym2 = dep2_syms[1];
127
OpModelSample[] dep2_sym1_spls = dep2_sym1.getSamples(), dep2_sym2_spls = dep2_sym2.getSamples();
128
assertEquals(1, dep2_sym1_spls.length);
129
assertEquals(1, dep2_sym2_spls.length);
130
OpModelSample dep2_sym1_spl1 = dep2_sym1_spls[0], dep2_sym2_spl1 = dep2_sym2_spls[0];
131
assertEquals("/lib64/ld-2.9.so", dep2.getName()); //$NON-NLS-1$
132
assertEquals(300, dep2.getCount());
133
assertEquals("do_lookup_x", dep2_sym1.getName()); //$NON-NLS-1$
134
assertEquals("dl-lookup.c", dep2_sym1.getFilePath()); //$NON-NLS-1$
135
assertEquals(299, dep2_sym1.getCount());
136
assertEquals(299, dep2_sym1_spl1.getCount());
137
assertEquals(0, dep2_sym1_spl1.getLine());
138
assertEquals("_dl_unload_cache", dep2_sym2.getName()); //$NON-NLS-1$
139
assertEquals("rawmemchr.c", dep2_sym2.getFilePath()); //$NON-NLS-1$
140
assertEquals(1, dep2_sym2.getCount());
141
assertEquals(1, dep2_sym2_spl1.getCount());
142
assertEquals(0, dep2_sym2_spl1.getLine());
144
assertEquals(false, dep3.hasDependents());
145
assertEquals("/usr/lib64/libstdc++.so.6.0.10", dep3.getName()); //$NON-NLS-1$
146
assertEquals(160, dep3.getCount());
148
assertEquals(false, dep4.hasDependents());
149
OpModelSymbol[] dep4_syms = dep4.getSymbols();
150
assertEquals(2, dep4_syms.length);
151
OpModelSymbol dep4_sym1 = dep4_syms[0], dep4_sym2 = dep4_syms[1];
152
OpModelSample[] dep4_sym1_spls = dep4_sym1.getSamples(), dep4_sym2_spls = dep4_sym2.getSamples();
153
assertEquals(1, dep4_sym1_spls.length);
154
assertEquals(1, dep4_sym2_spls.length);
155
OpModelSample dep4_sym1_spl1 = dep4_sym1_spls[0], dep4_sym2_spl1 = dep4_sym2_spls[0];
156
assertEquals("/lib64/libc-2.9.so", dep4.getName()); //$NON-NLS-1$
157
assertEquals(140, dep4.getCount());
158
assertEquals("_IO_new_file_seekoff", dep4_sym1.getName()); //$NON-NLS-1$
159
assertEquals("", dep4_sym1.getFilePath()); //$NON-NLS-1$
160
assertEquals(100, dep4_sym1.getCount());
161
assertEquals(100, dep4_sym1_spl1.getCount());
162
assertEquals(0, dep4_sym1_spl1.getLine());
163
assertEquals("bool std::operator!=<char, std::char_traits<char>, std::allocator<char> >(std::basic_string<char, std::char_traits<char>, std::allocator<char> > const&, char const*)", dep4_sym2.getName()); //$NON-NLS-1$
164
assertEquals("", dep4_sym2.getFilePath()); //$NON-NLS-1$
165
assertEquals(40, dep4_sym2.getCount());
166
assertEquals(40, dep4_sym2_spl1.getCount());
167
assertEquals(0, dep4_sym2_spl1.getLine());
170
assertEquals(OpModelImage.IMAGE_PARSE_ERROR, parsedErrorImage.getCount());
171
assertEquals(0, parsedErrorImage.getDepCount());
172
assertNull(parsedErrorImage.getDependents());
173
assertNull(parsedErrorImage.getSymbols());
174
assertEquals("", parsedErrorImage.getName()); //$NON-NLS-1$
177
public void testStringOutput() throws Exception {
178
assertEquals(IMAGE_OUTPUT, parsedImage.toString());
179
assertEquals(IMAGE_OUTPUT_WITHTAB, parsedImage.toString("\t")); //$NON-NLS-1$