1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package org.owasp.dependencycheck.xml.hints;
19
20 import java.io.File;
21 import java.io.InputStream;
22 import org.junit.Test;
23 import static org.junit.Assert.assertEquals;
24 import org.owasp.dependencycheck.BaseTest;
25
26
27
28
29
30 public class HintParserTest extends BaseTest {
31
32
33
34
35 @Test
36 public void testParseHints_File() throws Exception {
37 File file = BaseTest.getResourceAsFile(this, "hints.xml");
38 HintParser instance = new HintParser();
39 Hints results = instance.parseHints(file);
40 assertEquals("Two duplicating hints should have been read", 2, results.getVendorDuplicatingHintRules().size());
41 assertEquals("Two hint rules should have been read", 2, results.getHintRules().size());
42 }
43
44
45
46
47 @Test
48 public void testParseHints_InputStream() throws Exception {
49 InputStream ins = BaseTest.getResourceAsStream(this, "hints.xml");
50 HintParser instance = new HintParser();
51 Hints results = instance.parseHints(ins);
52 assertEquals("Two duplicating hints should have been read", 2, results.getVendorDuplicatingHintRules().size());
53 assertEquals("Two hint rules should have been read", 2, results.getHintRules().size());
54 assertEquals("One add product should have been read", 1, results.getHintRules().get(0).getAddProduct().size());
55 assertEquals("One add vendor should have been read", 1, results.getHintRules().get(0).getAddVendor().size());
56 assertEquals("Two file name should have been read", 2, results.getHintRules().get(1).getFilenames().size());
57
58 assertEquals("add product name not found", "add product name", results.getHintRules().get(0).getAddProduct().get(0).getName());
59 assertEquals("add vendor name not found", "add vendor name", results.getHintRules().get(0).getAddVendor().get(0).getName());
60 assertEquals("given product name not found", "given product name", results.getHintRules().get(0).getGivenProduct().get(0).getName());
61 assertEquals("given vendor name not found", "given vendor name", results.getHintRules().get(0).getGivenVendor().get(0).getName());
62
63 assertEquals("spring file name not found", "spring", results.getHintRules().get(1).getFilenames().get(0).getValue());
64 assertEquals("file name 1 should not be case sensitive", false, results.getHintRules().get(1).getFilenames().get(0).isCaseSensitive());
65 assertEquals("file name 1 should not be a regex", false, results.getHintRules().get(1).getFilenames().get(0).isRegex());
66 assertEquals("file name 2 should be case sensitive", true, results.getHintRules().get(1).getFilenames().get(1).isCaseSensitive());
67 assertEquals("file name 2 should be a regex", true, results.getHintRules().get(1).getFilenames().get(1).isRegex());
68
69
70 assertEquals("sun duplicating vendor", "sun", results.getVendorDuplicatingHintRules().get(0).getValue());
71 assertEquals("sun duplicates vendor oracle", "oracle", results.getVendorDuplicatingHintRules().get(0).getDuplicate());
72 }
73 }