1 |
|
|
2 |
|
|
3 |
|
|
4 |
|
|
5 |
|
|
6 |
|
|
7 |
|
|
8 |
|
|
9 |
|
|
10 |
|
|
11 |
|
|
12 |
|
|
13 |
|
|
14 |
|
|
15 |
|
|
16 |
|
|
17 |
|
|
18 |
|
|
19 |
|
|
20 |
|
package org.xwiki.test.escaping.framework; |
21 |
|
|
22 |
|
import java.io.BufferedReader; |
23 |
|
import java.io.IOException; |
24 |
|
import java.io.Reader; |
25 |
|
import java.util.HashSet; |
26 |
|
import java.util.Set; |
27 |
|
import java.util.regex.Matcher; |
28 |
|
import java.util.regex.Pattern; |
29 |
|
|
30 |
|
|
31 |
|
|
32 |
|
|
33 |
|
|
34 |
|
|
35 |
|
@version |
36 |
|
@since |
37 |
|
|
|
|
| 92.6% |
Uncovered Elements: 2 (27) |
Complexity: 9 |
Complexity Density: 0.53 |
|
38 |
|
public abstract class AbstractVelocityEscapingTest extends AbstractAutomaticTest |
39 |
|
{ |
40 |
|
|
41 |
|
|
42 |
|
|
43 |
|
@param |
44 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
45 |
3707 |
protected AbstractVelocityEscapingTest(Pattern fileNameMatcher)... |
46 |
|
{ |
47 |
3707 |
super(fileNameMatcher); |
48 |
|
} |
49 |
|
|
50 |
|
|
51 |
|
@inheritDoc |
52 |
|
|
53 |
|
|
54 |
|
|
55 |
|
|
|
|
| 91.7% |
Uncovered Elements: 2 (24) |
Complexity: 8 |
Complexity Density: 0.5 |
|
56 |
948 |
@Override... |
57 |
|
protected Set<String> parse(Reader reader) |
58 |
|
{ |
59 |
|
|
60 |
948 |
Set<String> ignored = new HashSet<String>(); |
61 |
|
|
62 |
|
|
63 |
948 |
ignored.add("xpage"); |
64 |
|
|
65 |
948 |
ignored.add("form_token"); |
66 |
|
|
67 |
948 |
Set<String> input = new HashSet<String>(); |
68 |
948 |
BufferedReader data = new BufferedReader(reader); |
69 |
948 |
Pattern pattern = Pattern.compile("\\$!?\\{?request\\.get\\((?:\"|')(\\w+)(?:\"|')\\)|" |
70 |
|
+ "\\$!?\\{?request\\.getParameter\\((?:\"|')(\\w+)(?:\"|')\\)|" |
71 |
|
+ "\\$!?\\{?request\\.(\\w+)[^(a-zA-Z_0-9]|" |
72 |
|
+ "\\b(editor)\\b|" |
73 |
|
+ "\\b(viewer)\\b|" |
74 |
|
+ "\\b(section)\\b|" |
75 |
|
+ "\\$!?\\{?(template)\\b|" |
76 |
|
+ "\\$!?\\{?(revparams)\\b|" |
77 |
|
+ "\\b(xredirect)\\b|" |
78 |
|
+ "\\b(x-maximized)\\b|" |
79 |
|
+ "\\b(xnotification)\\b|" |
80 |
|
+ "\\b(classname)\\b|" |
81 |
|
+ "\\b(comment)\\b|" |
82 |
|
+ "\\b(rev1)\\b|" |
83 |
|
+ "\\b(rev2)\\b|" |
84 |
|
+ "\\b(sourcedoc)\\b|" |
85 |
|
+ "\\b(targetdoc)\\b|" |
86 |
|
+ "\\b(srid)\\b|" |
87 |
|
+ "\\b(language)\\b"); |
88 |
948 |
try { |
89 |
948 |
String line; |
90 |
? |
while ((line = data.readLine()) != null) { |
91 |
219958 |
Matcher match = pattern.matcher(line); |
92 |
225756 |
while (match.find()) { |
93 |
115960 |
for (int i = 1; i <= match.groupCount(); i++) { |
94 |
110162 |
String parameter = match.group(i); |
95 |
110162 |
if (parameter != null && !parameter.matches("\\s*") && !ignored.contains(parameter)) { |
96 |
5664 |
input.add(parameter); |
97 |
|
} |
98 |
|
} |
99 |
|
} |
100 |
|
} |
101 |
|
} catch (IOException exception) { |
102 |
|
|
103 |
|
} |
104 |
948 |
return input; |
105 |
|
} |
106 |
|
} |