-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathViewAssignments_183.java
84 lines (70 loc) · 2.94 KB
/
ViewAssignments_183.java
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
71
72
73
74
75
76
77
78
79
80
81
82
83
package unitn.sectest;
import net.sourceforge.jwebunit.api.IElement;
import net.sourceforge.jwebunit.htmlunit.HtmlUnitElementImpl;
import net.sourceforge.jwebunit.junit.WebTester;
import org.junit.Before;
import org.junit.Test;
import org.xml.sax.helpers.AttributesImpl;
import com.gargoylesoftware.htmlunit.html.DomElement;
import com.gargoylesoftware.htmlunit.html.HtmlElement;
import com.gargoylesoftware.htmlunit.html.InputElementFactory;
public class ViewAssignments_183 {
private WebTester tester;
@Before
public void setup(){
tester = new WebTester();
tester.setBaseUrl("http://localhost/schoolmate");
tester.beginAt("index.php");
tester.setTextField("username", "Mother");
tester.setTextField("password", "Mother");
tester.submit();
tester.assertMatch("Students of Nicoletta Riso");
tester.clickLinkWithText("Noellar Kappa");
tester.assertMatch("Noellar Kappa's Classes");
tester.clickLinkWithText("Security Testing");
tester.assertMatch("Class Settings");
tester.clickLinkWithText("Assignments");
tester.assertMatch("View Assignments");
}
@Test
public void page(){
tester.setWorkingForm("student");
tester.setTextField("page", "5'> <a href =http://unitn.it>malicious link</a> <br'");
tester.clickLinkWithExactText("Assignments");
tester.assertLinkNotPresentWithText("malicious link");
}
@Test
public void onpage(){
tester.setWorkingForm("assignments");
tester.setTextField("onpage", "1'> <a href =http://unitn.it>malicious link</a> <br'");
addSubmitButton("//form[@name='assignments']");
tester.submit();
tester.assertMatch("View Assignments");
tester.assertLinkNotPresentWithText("malicious link");
}
@Test
public void page2(){
tester.setWorkingForm("student");
tester.setTextField("page2", "2'> <a href =http://unitn.it>malicious link</a> <br'");
addSubmitButton("//form[@name='student']");
tester.submit();
tester.assertMatch("View Assignments");
tester.assertLinkNotPresentWithText("malicious link");
}
@Test
public void selectclass(){
tester.setWorkingForm("student");
tester.setTextField("selectclass", "1 --'> <a href =http://unitn.it>malicious link</a> <br'");
tester.clickLinkWithExactText("Assignments");
tester.assertLinkNotPresentWithText("malicious link");
}
private void addSubmitButton(String fromXpath){
IElement element = tester.getElementByXPath(fromXpath);
DomElement form= ((HtmlUnitElementImpl)element).getHtmlElement();
InputElementFactory factory = InputElementFactory.instance;
AttributesImpl attributes = new AttributesImpl();
attributes.addAttribute("", "", "type", "", "submit");
HtmlElement submit = factory.createElement(form.getPage(), "input", attributes);
form.appendChild(submit);
}
}