2 * This document is a part of the source code and related artifacts
3 * for CollectionSpace, an open source collections management system
4 * for museums and related institutions:
6 * http://www.collectionspace.org
7 * http://wiki.collectionspace.org
9 * Copyright 2009 University of California at Berkeley
11 * Licensed under the Educational Community License (ECL), Version 2.0.
12 * You may not use this file except in compliance with this License.
14 * You may obtain a copy of the ECL 2.0 License at
16 * https://source.collectionspace.org/collection-space/LICENSE.txt
18 * Unless required by applicable law or agreed to in writing, software
19 * distributed under the License is distributed on an "AS IS" BASIS,
20 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21 * See the License for the specific language governing permissions and
22 * limitations under the License.
24 * This document is a part of the source code and related artifacts
25 * for CollectionSpace, an open source collections management system
26 * for museums and related institutions:
28 * http://www.collectionspace.org
29 * http://wiki.collectionspace.org
31 * Copyright 2009 University of California at Berkeley
33 * Licensed under the Educational Community License (ECL), Version 2.0.
34 * You may not use this file except in compliance with this License.
36 * You may obtain a copy of the ECL 2.0 License at
38 * https://source.collectionspace.org/collection-space/LICENSE.txt
40 * Unless required by applicable law or agreed to in writing, software
41 * distributed under the License is distributed on an "AS IS" BASIS,
42 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
43 * See the License for the specific language governing permissions and
44 * limitations under the License.
47 * To change this template, choose Tools | Templates
48 * and open the template in the editor.
50 package org.collectionspace.services.authorization.importer;
53 import java.io.FileInputStream;
54 import java.io.InputStream;
55 import org.slf4j.Logger;
56 import org.slf4j.LoggerFactory;
57 import java.lang.reflect.Method;
58 import java.util.HashSet;
59 import javax.xml.bind.JAXBContext;
60 import javax.xml.bind.Marshaller;
61 import javax.xml.bind.Unmarshaller;
62 import org.collectionspace.services.authorization.AuthZ;
63 import org.collectionspace.services.authorization.PermissionsList;
64 import org.collectionspace.services.authorization.PermissionsRolesList;
65 import org.springframework.context.support.ClassPathXmlApplicationContext;
66 import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
67 import org.springframework.security.core.Authentication;
68 import org.springframework.security.core.GrantedAuthority;
69 import org.springframework.security.core.authority.GrantedAuthorityImpl;
70 import org.springframework.security.core.context.SecurityContextHolder;
71 import org.springframework.transaction.TransactionDefinition;
72 import org.springframework.transaction.TransactionStatus;
73 import org.springframework.transaction.support.DefaultTransactionDefinition;
74 import org.testng.annotations.DataProvider;
75 import org.testng.annotations.Test;
81 public abstract class AbstractAuthorizationTestImpl {
83 final Logger logger = LoggerFactory.getLogger(AbstractAuthorizationTestImpl.class);
84 private org.springframework.jdbc.datasource.DataSourceTransactionManager txManager;
87 * Returns the name of the currently running test.
89 * Note: although the return type is listed as Object[][],
90 * this method instead returns a String.
92 * @param m The currently running test method.
94 * @return The name of the currently running test method.
96 @DataProvider(name = "testName")
97 protected static Object[][] testName(Method m) {
98 return new Object[][]{
99 new Object[]{m.getName()}
103 protected void setup() {
104 ClassPathXmlApplicationContext appContext = new ClassPathXmlApplicationContext(
105 new String[]{"applicationContext-authorization-test.xml"});
107 AuthZ authZ = AuthZ.get();
108 txManager = (org.springframework.jdbc.datasource.DataSourceTransactionManager) appContext.getBean("transactionManager");
111 protected void login() {
112 GrantedAuthority gauth = new GrantedAuthorityImpl("ROLE_ADMINISTRATOR");
113 HashSet<GrantedAuthority> gauths = new HashSet<GrantedAuthority>();
115 Authentication authRequest = new UsernamePasswordAuthenticationToken("test", "test", gauths);
116 SecurityContextHolder.getContext().setAuthentication(authRequest);
119 protected void logout() {
120 SecurityContextHolder.getContext().setAuthentication(null);
123 protected TransactionStatus beginTransaction(String name) {
124 DefaultTransactionDefinition def = new DefaultTransactionDefinition();
125 // explicitly setting the transaction name is something that can only be done programmatically
127 def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);
128 return txManager.getTransaction(def);
131 protected void rollbackTransaction(TransactionStatus status) {
132 txManager.rollback(status);
135 protected void commitTransaction(TransactionStatus status) {
136 txManager.commit(status);
140 static Object fromFile(Class jaxbClass, String fileName) throws Exception {
141 InputStream is = new FileInputStream(fileName);
143 JAXBContext context = JAXBContext.newInstance(jaxbClass);
144 Unmarshaller unmarshaller = context.createUnmarshaller();
145 //note: setting schema to null will turn validator off
146 unmarshaller.setSchema(null);
147 return jaxbClass.cast(unmarshaller.unmarshal(is));
152 } catch (Exception e) {
159 @Test(dataProvider = "testName", dataProviderClass = AbstractAuthorizationTestImpl.class)
160 public void test(String testName) {
161 if (logger.isDebugEnabled()) {
162 logger.debug(testName);