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 package org.collectionspace.services.authorization.test;
26 import java.util.ArrayList;
27 import java.util.List;
28 import org.slf4j.Logger;
29 import org.slf4j.LoggerFactory;
30 import org.collectionspace.services.authorization.AuthZ;
31 import org.collectionspace.services.authorization.Permission;
32 import org.collectionspace.services.authorization.PermissionRole;
33 import org.collectionspace.services.authorization.PermissionsList;
34 import org.collectionspace.services.authorization.PermissionsRolesList;
35 import org.springframework.transaction.TransactionStatus;
36 import org.testng.annotations.BeforeClass;
42 public class AuthorizationSeedTest extends AbstractAuthorizationTestImpl {
44 final Logger logger = LoggerFactory.getLogger(AuthorizationSeedTest.class);
46 @BeforeClass(alwaysRun = true)
47 public void seedData() {
49 TransactionStatus status = beginTransaction("seedData");
51 AuthorizationGen authzGen = new AuthorizationGen();
52 authzGen.genPermissions();
53 authzGen.genPermissionsRoles();
56 } catch (Exception ex) {
57 rollbackTransaction(status);
59 throw new RuntimeException(ex);
61 commitTransaction(status);
64 public void seedRoles() throws Exception {
67 public void seedPermissions() throws Exception {
69 PermissionsList pcList =
70 (PermissionsList) fromFile(PermissionsList.class,
71 AbstractAuthorizationTestImpl.testDataDir + "test-permissions.xml");
72 logger.info("read permissions from "
73 + AbstractAuthorizationTestImpl.testDataDir + "test-permissions.xml");
74 PermissionsRolesList pcrList =
75 (PermissionsRolesList) fromFile(PermissionsRolesList.class,
76 AbstractAuthorizationTestImpl.testDataDir + "test-permissions-roles.xml");
77 logger.info("read permissions-roles from "
78 + AbstractAuthorizationTestImpl.testDataDir + "test-permissions.xml");
79 AuthZ authZ = AuthZ.get();
80 for (Permission p : pcList.getPermissions()) {
81 if (logger.isDebugEnabled()) {
82 logger.debug("adding permission for res=" + p.getResourceName());
84 for (PermissionRole pr : pcrList.getPermissionRoles()) {
85 if (pr.getPermissions().get(0).getPermissionId().equals(p.getCsid())) {
86 authZ.addUriPermissions(p, pr);