blob: c9a8d39a82b38212fb15fe19aa72d9f7239c01b1 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2011-2014 EclipseSource Muenchen GmbH and others.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Edgar - initial API and implementation
******************************************************************************/
package org.eclipse.emf.emfstore.server.accesscontrol.test;
import static org.eclipse.emf.emfstore.client.test.common.util.ProjectUtil.share;
import static org.eclipse.emf.emfstore.client.test.common.util.ServerUtil.createGroup;
import static org.eclipse.emf.emfstore.client.test.common.util.ServerUtil.createUser;
import static org.eclipse.emf.emfstore.client.test.common.util.ServerUtil.deleteGroup;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.fail;
import org.eclipse.emf.emfstore.client.test.common.dsl.Roles;
import org.eclipse.emf.emfstore.client.test.common.util.ServerUtil;
import org.eclipse.emf.emfstore.internal.client.model.ProjectSpace;
import org.eclipse.emf.emfstore.internal.client.model.impl.api.ESUsersessionImpl;
import org.eclipse.emf.emfstore.internal.server.exceptions.AccessControlException;
import org.eclipse.emf.emfstore.internal.server.model.accesscontrol.ACOrgUnitId;
import org.eclipse.emf.emfstore.server.auth.ESProjectAdminPrivileges;
import org.eclipse.emf.emfstore.server.exceptions.ESException;
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
/**
* Tests whether organizational units can be assigned to groups.
*
* @author emueller
*
*/
public class AssignOrgUnitToGroupTests extends ProjectAdminTest {
@BeforeClass
public static void beforeClass() {
startEMFStoreWithPAProperties(
ESProjectAdminPrivileges.ShareProject,
ESProjectAdminPrivileges.AssignRoleToOrgUnit,
ESProjectAdminPrivileges.ChangeAssignmentsOfOrgUnits);
}
@AfterClass
public static void afterClass() {
stopEMFStore();
}
@Override
@After
public void after() {
try {
deleteGroup(getSuperUsersession(), getNewGroupName());
deleteGroup(getSuperUsersession(), getNewOtherGroupName());
} catch (final ESException ex) {
fail(ex.getMessage());
}
super.after();
}
@Override
@Before
public void before() {
super.before();
}
@Test(expected = AccessControlException.class)
public void addMemberToGroupWhichBelongsToOtherProject() throws ESException {
makeUserPA();
share(getSuperUsersession(), getLocalProject());
final ACOrgUnitId newUser = createUser(getSuperUsersession(), getNewUsername());
final ACOrgUnitId group = createGroup(getSuperUsersession(), getNewGroupName());
share(getUsersession(), getLocalProject());
final ProjectSpace clonedProjectSpace = cloneProjectSpace(getProjectSpace());
share(getSuperUsersession(), clonedProjectSpace.toAPI());
getSuperAdminBroker().changeRole(clonedProjectSpace.getProjectId(), group, Roles.writer());
// fails
getAdminBroker().addMember(group, newUser);
}
@Test(expected = AccessControlException.class)
public void removeMemberFromGroupWhichBelongsToOtherProject() throws ESException {
makeUserPA();
share(getSuperUsersession(), getLocalProject());
final ACOrgUnitId newUser = createUser(getSuperUsersession(), getNewUsername());
final ACOrgUnitId group = createGroup(getSuperUsersession(), getNewGroupName());
share(getUsersession(), getLocalProject());
final ProjectSpace clonedProjectSpace = cloneProjectSpace(getProjectSpace());
share(getSuperUsersession(), clonedProjectSpace.toAPI());
getSuperAdminBroker().changeRole(clonedProjectSpace.getProjectId(), group, Roles.writer());
getSuperAdminBroker().addMember(group, newUser);
getAdminBroker().removeMember(group, newUser);
}
@Test
public void removeMemberFromGroupWithProject() throws ESException {
makeUserPA();
share(getUsersession(), getLocalProject());
final ACOrgUnitId newUser = createUser(getSuperUsersession(), getNewUsername());
final ACOrgUnitId group = createGroup(getSuperUsersession(), getNewGroupName());
getAdminBroker().changeRole(getProjectSpace().getProjectId(), group, Roles.writer());
getAdminBroker().addMember(group, newUser);
getAdminBroker().removeMember(group, newUser);
assertEquals(0, getAdminBroker().getMembers(group).size());
}
@Test
public void addMemberToGroup() throws ESException {
makeUserPA();
final ACOrgUnitId newUser = createUser(getSuperUsersession(), getNewUsername());
final ACOrgUnitId group = createGroup(getSuperUsersession(), getNewGroupName());
getAdminBroker().addMember(group, newUser);
assertEquals(1, getAdminBroker().getMembers(group).size());
}
@Test
public void addParticipantAsPA() throws ESException {
makeUserPA();
final ACOrgUnitId newUserId = ServerUtil.createUser(getSuperUsersession(), getNewUsername());
share(getUsersession(), getLocalProject());
final int oldSize = getAdminBroker().getParticipants(getProjectSpace().getProjectId()).size();
getAdminBroker().addParticipant(getProjectSpace().getProjectId(), newUserId, Roles.reader());
assertEquals(oldSize + 1, getAdminBroker().getParticipants(getProjectSpace().getProjectId()).size());
}
@Test
public void addReaderToDifferentProjectsAsPA() throws ESException {
makeUserPA();
final ACOrgUnitId newUserId = ServerUtil.createUser(getSuperUsersession(), getNewUsername());
share(getUsersession(), getLocalProject());
final int oldSize = getAdminBroker().getParticipants(getProjectSpace().getProjectId()).size();
final ProjectSpace clonedProjectSpace = cloneProjectSpace(getProjectSpace());
share(getUsersession(), clonedProjectSpace.toAPI());
getAdminBroker().addParticipant(getProjectSpace().getProjectId(), newUserId, Roles.reader());
getAdminBroker().addParticipant(clonedProjectSpace.getProjectId(), newUserId, Roles.reader());
assertEquals(oldSize + 1, getAdminBroker().getParticipants(getProjectSpace().getProjectId()).size());
}
@Test
public void addParticipantTwiceAsPA() throws ESException {
makeUserPA();
final ACOrgUnitId newUserId = ServerUtil.createUser(getSuperUsersession(), getNewUsername());
share(getUsersession(), getLocalProject());
final int oldSize = getAdminBroker().getParticipants(getProjectSpace().getProjectId()).size();
getAdminBroker().addParticipant(getProjectSpace().getProjectId(), newUserId, Roles.reader());
getAdminBroker().addParticipant(getProjectSpace().getProjectId(), newUserId, Roles.reader());
assertEquals(oldSize + 1, getAdminBroker().getParticipants(getProjectSpace().getProjectId()).size());
}
@Test(expected = AccessControlException.class)
public void addParticipantSAasPA() throws ESException {
makeUserPA();
final ACOrgUnitId newUserId = ServerUtil.createUser(getSuperUsersession(), getNewUsername());
share(getUsersession(), getLocalProject());
final int oldSize = getAdminBroker().getParticipants(getProjectSpace().getProjectId()).size();
getAdminBroker().addParticipant(getProjectSpace().getProjectId(), newUserId, Roles.serverAdmin());
assertEquals(oldSize + 1, getAdminBroker().getParticipants(getProjectSpace().getProjectId()).size());
}
@Test(expected = AccessControlException.class)
public void addParticipantNotPA() throws ESException {
final ACOrgUnitId newUserId = ServerUtil.createUser(getSuperUsersession(), getNewUsername());
share(getUsersession(), getLocalProject());
getAdminBroker().addParticipant(getProjectSpace().getProjectId(), newUserId, Roles.reader());
}
@Test
public void removeParticipantPA() throws ESException {
makeUserPA();
final ACOrgUnitId newUserId = ServerUtil.createUser(getSuperUsersession(), getNewUsername());
share(getUsersession(), getLocalProject());
getAdminBroker().addParticipant(getProjectSpace().getProjectId(), newUserId, Roles.reader());
final int oldSize = getAdminBroker().getParticipants(getProjectSpace().getProjectId()).size();
getAdminBroker().removeParticipant(getProjectSpace().getProjectId(), newUserId);
assertEquals(oldSize - 1, getAdminBroker().getParticipants(getProjectSpace().getProjectId()).size());
}
@Test(expected = AccessControlException.class)
public void removeParticipantNotPA() throws ESException {
makeUserPA();
final ACOrgUnitId newUserId = ServerUtil.createUser(getSuperUsersession(), getNewUsername());
share(getUsersession(), getLocalProject());
getAdminBroker().addParticipant(getProjectSpace().getProjectId(), newUserId, Roles.reader());
// downgrade project admin
getAdminBroker().changeRole(getProjectSpace().getProjectId(),
ESUsersessionImpl.class.cast(getUsersession()).toInternalAPI().getACUser().getId(),
Roles.writer());
getAdminBroker().removeParticipant(getProjectSpace().getProjectId(), newUserId);
}
}