Merge "Portal Spring Boot Development"
[portal.git] / ecomp-portal-BE-common / src / test / java / org / onap / portalapp / validation / DataValidatorTest.java
1 /*-
2  * ============LICENSE_START==========================================
3  * ONAP Portal
4  * ===================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6  * ===================================================================
7  *
8  * Unless otherwise specified, all software contained herein is licensed
9  * under the Apache License, Version 2.0 (the "License");
10  * you may not use this software except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *             http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  * Unless otherwise specified, all documentation contained herein is licensed
22  * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
23  * you may not use this documentation except in compliance with the License.
24  * You may obtain a copy of the License at
25  *
26  *             https://creativecommons.org/licenses/by/4.0/
27  *
28  * Unless required by applicable law or agreed to in writing, documentation
29  * distributed under the License is distributed on an "AS IS" BASIS,
30  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
31  * See the License for the specific language governing permissions and
32  * limitations under the License.
33  *
34  * ============LICENSE_END============================================
35  *
36  *
37  */
38
39 package org.onap.portalapp.validation;
40
41 import static org.junit.Assert.*;
42
43 import java.util.Set;
44 import javax.validation.ConstraintViolation;
45 import javax.validation.Validation;
46 import javax.validation.Validator;
47 import javax.validation.ValidatorFactory;
48 import org.junit.Test;
49 import org.junit.runner.RunWith;
50 import org.mockito.InjectMocks;
51 import org.onap.portalapp.portal.domain.EPUser;
52 import org.powermock.modules.junit4.PowerMockRunner;
53 import org.springframework.beans.factory.annotation.Autowired;
54
55 @RunWith(PowerMockRunner.class)
56 public class DataValidatorTest {
57        private static final ValidatorFactory VALIDATOR_FACTORY  = Validation.buildDefaultValidatorFactory();
58        @InjectMocks
59        DataValidator dataValidator;
60
61        @Test
62        public void getConstraintViolationsSecureString() {
63               SecureString secureString = new SecureString("<script>alert(“XSS”);</script>");
64               Validator validator = VALIDATOR_FACTORY.getValidator();
65               Set<ConstraintViolation<SecureString>> expectedConstraintViolations = validator.validate(secureString);
66               Set<ConstraintViolation<SecureString>> actualConstraintViolations = dataValidator.getConstraintViolations(secureString);
67               assertEquals(expectedConstraintViolations, actualConstraintViolations);
68        }
69
70        @Test
71        public void isValidSecureString() {
72               SecureString secureString = new SecureString("<script>alert(“XSS”);</script>");
73               assertFalse(dataValidator.isValid(secureString));
74        }
75
76        @Test
77        public void getConstraintViolationsEPUser() {
78               EPUser user = new EPUser();
79               user.setEmail("“><script>alert(“XSS”)</script>");
80               user.setLoginId("<IMG SRC=”javascript:alert(‘XSS’);”>");
81               user.setFinancialLocCode("<IMG SRC=javascript:alert(‘XSS’)> ");
82               Validator validator = VALIDATOR_FACTORY.getValidator();
83               Set<ConstraintViolation<EPUser>> expectedConstraintViolations = validator.validate(user);
84               Set<ConstraintViolation<EPUser>> actualConstraintViolations = dataValidator.getConstraintViolations(user);
85               assertEquals(expectedConstraintViolations, actualConstraintViolations);
86        }
87
88        @Test
89        public void isValidEPUser() {
90               EPUser user = new EPUser();
91               user.setEmail("“><script>alert(“XSS”)</script>");
92               user.setLoginId("<IMG SRC=”javascript:alert(‘XSS’);”>");
93               user.setFinancialLocCode("<IMG SRC=javascript:alert(‘XSS’)> ");
94               assertFalse(dataValidator.isValid(user));
95        }
96
97 }