/**
* Copyright (c) 2011, SOCIETIES Consortium
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following
* conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
* BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
* SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package org.societies.privacytrust.privacyprotection.test.datamanagement;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
import java.net.URISyntaxException;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.concurrent.ExecutionException;
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mockito;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.societies.api.cis.management.ICisManager;
import org.societies.api.cis.management.ICisOwned;
import org.societies.api.cis.management.ICisParticipant;
import org.societies.api.cis.model.CisAttributeTypes;
import org.societies.api.comm.xmpp.exceptions.CommunicationException;
import org.societies.api.comm.xmpp.interfaces.ICommManager;
import org.societies.api.context.model.MalformedCtxIdentifierException;
import org.societies.api.identity.IIdentity;
import org.societies.api.identity.IIdentityManager;
import org.societies.api.identity.INetworkNode;
import org.societies.api.identity.InvalidFormatException;
import org.societies.api.identity.util.DataIdentifierFactory;
import org.societies.api.identity.util.RequestorUtils;
import org.societies.api.internal.privacytrust.privacyprotection.IPrivacyDataManager;
import org.societies.api.internal.privacytrust.privacyprotection.IPrivacyPolicyManager;
import org.societies.api.privacytrust.privacy.model.PrivacyException;
import org.societies.api.privacytrust.privacy.util.privacypolicy.ActionUtils;
import org.societies.api.privacytrust.privacy.util.privacypolicy.ConditionUtils;
import org.societies.api.privacytrust.privacy.util.privacypolicy.RequestItemUtils;
import org.societies.api.privacytrust.privacy.util.privacypolicy.RequestPolicyUtils;
import org.societies.api.privacytrust.privacy.util.privacypolicy.ResourceUtils;
import org.societies.api.privacytrust.privacy.util.privacypolicy.ResponseItemUtils;
import org.societies.api.schema.identity.DataIdentifier;
import org.societies.api.schema.identity.DataIdentifierScheme;
import org.societies.api.schema.identity.RequestorBean;
import org.societies.api.schema.identity.RequestorCisBean;
import org.societies.api.schema.identity.RequestorServiceBean;
import org.societies.api.schema.privacytrust.privacy.model.privacypolicy.Action;
import org.societies.api.schema.privacytrust.privacy.model.privacypolicy.ActionConstants;
import org.societies.api.schema.privacytrust.privacy.model.privacypolicy.Condition;
import org.societies.api.schema.privacytrust.privacy.model.privacypolicy.ConditionConstants;
import org.societies.api.schema.privacytrust.privacy.model.privacypolicy.Decision;
import org.societies.api.schema.privacytrust.privacy.model.privacypolicy.RequestItem;
import org.societies.api.schema.privacytrust.privacy.model.privacypolicy.RequestPolicy;
import org.societies.api.schema.privacytrust.privacy.model.privacypolicy.ResponseItem;
import org.societies.api.services.ServiceUtils;
import org.societies.privacytrust.privacyprotection.datamanagement.PrivacyDataManager;
import org.societies.util.commonmock.MockIdentity;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.annotation.Rollback;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
/**
* @author Olivier Maridat (Trialog)
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = { "PrivacyDataManagerInternalTest-context.xml" })
public class CisDataAccessControlTest {
private static final Logger LOG = LoggerFactory.getLogger(CisDataAccessControlTest.class.getSimpleName());
public static ICisManager cisManager;
public static ICommManager commManager;
public static IPrivacyPolicyManager privacyPolicyManager;
@Autowired
IPrivacyDataManager privacyDataManager;
private static DataIdentifier cisPublicDataId;
private static DataIdentifier cisMembersOnlyDataId;
private static DataIdentifier cisPrivateDataId;
private static RequestorBean requestorMyCssId;
private static RequestorBean requestorMemberCssId;
private static RequestorBean requestorOtherCssId;
private static RequestorCisBean requestorCisPublic;
private static RequestorCisBean requestorCisMembersOnly;
private static RequestorCisBean requestorCisPrivate;
private static RequestorServiceBean requestorMyService;
private static IIdentity myCssId;
private static IIdentity memberCssId;
private static IIdentity otherCssId;
private static ICisParticipant memberCssCisParticipant;
private static IIdentity cisPublicId;
private static IIdentity cisMembersOnlyId;
private static IIdentity cisPrivateId;
private static ICisOwned cisPublic;
private static ICisOwned cisMembersOnly;
private static ICisOwned cisPrivate;
private static List<Action> actionsRead;
private static List<Condition> conditionsPublic;
private static List<Condition> conditionsMembersOnly;
private static List<Condition> conditionsPrivate;
private static RequestPolicy privacyPolicyPublic;
private static RequestPolicy privacyPolicyMembersOnly;
private static RequestPolicy privacyPolicyPrivate;
@BeforeClass
public static void setUpClass() throws PrivacyException, InvalidFormatException, URISyntaxException, InterruptedException, ExecutionException, CommunicationException
{
LOG.info("CisDataAccessControl::setUpClass");
}
@Before
public void setUp() throws Exception
{
LOG.info(""+getClass().getSimpleName()+"::setUp");
// - Actions
actionsRead = new ArrayList<Action>();
actionsRead.add(ActionUtils.create(ActionConstants.READ));
// - Conditions
conditionsPublic = new ArrayList<Condition>();
conditionsPublic.add(ConditionUtils.create(ConditionConstants.SHARE_WITH_3RD_PARTIES, "1"));
conditionsPublic.add(ConditionUtils.create(ConditionConstants.STORE_IN_SECURE_STORAGE, "1"));
conditionsMembersOnly = new ArrayList<Condition>();
conditionsMembersOnly.add(ConditionUtils.create(ConditionConstants.SHARE_WITH_CIS_MEMBERS_ONLY, "1"));
conditionsMembersOnly.add(ConditionUtils.create(ConditionConstants.STORE_IN_SECURE_STORAGE, "1"));
conditionsPrivate = new ArrayList<Condition>();
conditionsPrivate.add(ConditionUtils.create(ConditionConstants.SHARE_WITH_CIS_OWNER_ONLY, "1"));
conditionsPrivate.add(ConditionUtils.create(ConditionConstants.STORE_IN_SECURE_STORAGE, "1"));
try {
// Comm Manager
String host = "societies.local";
commManager = Mockito.mock(ICommManager.class);
IIdentityManager idManager = Mockito.mock(IIdentityManager.class);
INetworkNode myCssNetworkNode = Mockito.mock(INetworkNode.class);
String myCssIdString = "university."+host;
String memberCssIdString = "emma."+host;
String otherCssIdString = "arthur."+host;
String cisPublicIdString = "cis-public."+host;
String cisMembersOnlyIdString = "cis-members-only."+host;
String cisPrivateIdString = "cis-private."+host;
myCssId = new MockIdentity(myCssIdString);
memberCssId = new MockIdentity(memberCssIdString);
otherCssId = new MockIdentity(otherCssIdString);
cisPublicId = new MockIdentity(cisPublicIdString);
cisMembersOnlyId = new MockIdentity(cisMembersOnlyIdString);
cisPrivateId = new MockIdentity(cisPrivateIdString);
cisPublic = Mockito.mock(ICisOwned.class);
cisMembersOnly = Mockito.mock(ICisOwned.class);
cisPrivate = Mockito.mock(ICisOwned.class);
Set<ICisParticipant> emptyMemberList = new HashSet<ICisParticipant>();
Set<ICisParticipant> memberList = new HashSet<ICisParticipant>();
memberCssCisParticipant = Mockito.mock(ICisParticipant.class);
Mockito.when(memberCssCisParticipant.getMembershipType()).thenReturn("participant");
Mockito.when(memberCssCisParticipant.getMembersJid()).thenReturn(memberCssId.getJid());
memberList.add(memberCssCisParticipant);
Mockito.when(cisPublic.getCisId()).thenReturn(cisPublicId.getJid());
Mockito.when(cisPublic.getOwnerId()).thenReturn(myCssId.getJid());
Mockito.when(cisPublic.getMemberList()).thenReturn(emptyMemberList);
Mockito.when(cisMembersOnly.getCisId()).thenReturn(cisMembersOnlyId.getJid());
Mockito.when(cisMembersOnly.getOwnerId()).thenReturn(myCssId.getJid());
Mockito.when(cisMembersOnly.getMemberList()).thenReturn(memberList);
Mockito.when(cisPrivate.getCisId()).thenReturn(cisPrivateId.getJid());
Mockito.when(cisPrivate.getOwnerId()).thenReturn(myCssId.getJid());
Mockito.when(cisPrivate.getMemberList()).thenReturn(emptyMemberList);
Mockito.when(myCssNetworkNode.getJid()).thenReturn(myCssId.getJid());
Mockito.when(idManager.getThisNetworkNode()).thenReturn(myCssNetworkNode);
Mockito.when(idManager.fromJid(myCssIdString)).thenReturn(myCssId);
Mockito.when(idManager.fromJid(memberCssIdString)).thenReturn(memberCssId);
Mockito.when(idManager.fromJid(otherCssIdString)).thenReturn(otherCssId);
Mockito.when(idManager.fromJid(cisPublicId.getJid())).thenReturn(cisPublicId);
Mockito.when(idManager.fromJid(cisMembersOnlyId.getJid())).thenReturn(cisMembersOnlyId);
Mockito.when(idManager.fromJid(cisPrivateId.getJid())).thenReturn(cisPrivateId);
Mockito.when(commManager.getIdManager()).thenReturn(idManager);
// CIS Manager
cisManager = Mockito.mock(ICisManager.class);
Mockito.when(cisManager.deleteCis(Mockito.anyString())).thenReturn(true);
Mockito.when(cisManager.getOwnedCis(cisPublicId.getJid())).thenReturn(cisPublic);
Mockito.when(cisManager.getOwnedCis(cisMembersOnlyId.getJid())).thenReturn(cisMembersOnly);
Mockito.when(cisManager.getOwnedCis(cisPrivateId.getJid())).thenReturn(cisPrivate);
// - Privacy Policy
List<RequestItem> requestItemsPublic = new ArrayList<RequestItem>();
requestItemsPublic.add(RequestItemUtils.create(ResourceUtils.create(DataIdentifierScheme.CIS, CisAttributeTypes.MEMBER_LIST), actionsRead, conditionsPublic));
List<RequestItem> requestItemsMembersOnly = new ArrayList<RequestItem>();
requestItemsMembersOnly.add(RequestItemUtils.create(ResourceUtils.create(DataIdentifierScheme.CIS, CisAttributeTypes.MEMBER_LIST), actionsRead, conditionsMembersOnly));
List<RequestItem> requestItemsPrivate = new ArrayList<RequestItem>();
requestItemsPrivate.add(RequestItemUtils.create(ResourceUtils.create(DataIdentifierScheme.CIS, CisAttributeTypes.MEMBER_LIST), actionsRead, conditionsPrivate));
requestorCisPublic = (RequestorCisBean) RequestorUtils.create(myCssId.getJid(), cisPublicId.getJid());
requestorCisMembersOnly = (RequestorCisBean) RequestorUtils.create(myCssId.getJid(), cisMembersOnlyId.getJid());
requestorCisPrivate = (RequestorCisBean) RequestorUtils.create(myCssId.getJid(), cisPrivateId.getJid());
requestorMyService = RequestorUtils.create(myCssId.getJid(), ServiceUtils.generateServiceResourceIdentifierFromString("mygreatservice test"));
requestorMyCssId = RequestorUtils.create(myCssId.getJid());
requestorMemberCssId = RequestorUtils.create(memberCssId.getJid());
requestorOtherCssId = RequestorUtils.create(otherCssId.getJid());
privacyPolicyPublic = RequestPolicyUtils.create(requestorCisPublic, requestItemsPublic);
privacyPolicyMembersOnly = RequestPolicyUtils.create(requestorCisMembersOnly, requestItemsMembersOnly);
privacyPolicyPrivate = RequestPolicyUtils.create(requestorCisPrivate, requestItemsPrivate);
// Privacy Policy Manager
privacyPolicyManager = Mockito.mock(IPrivacyPolicyManager.class);
Mockito.when(privacyPolicyManager.getPrivacyPolicy((requestorCisPublic))).thenReturn((privacyPolicyPublic));
Mockito.when(privacyPolicyManager.getPrivacyPolicy((requestorCisMembersOnly))).thenReturn((privacyPolicyMembersOnly));
Mockito.when(privacyPolicyManager.getPrivacyPolicy((requestorCisPrivate))).thenReturn((privacyPolicyPrivate));
// Privacy Data Manager
((PrivacyDataManager) privacyDataManager).setCommManager(commManager);
((PrivacyDataManager) privacyDataManager).setCisManager(cisManager);
((PrivacyDataManager) privacyDataManager).setPrivacyPolicyManager(privacyPolicyManager);
// - Data Id
cisPublicDataId = DataIdentifierFactory.fromUri(DataIdentifierScheme.CIS+"://"+cisPublic.getCisId()+"/"+CisAttributeTypes.MEMBER_LIST);
cisMembersOnlyDataId = DataIdentifierFactory.fromUri(DataIdentifierScheme.CIS+"://"+cisMembersOnly.getCisId()+"/"+CisAttributeTypes.MEMBER_LIST);
cisPrivateDataId = DataIdentifierFactory.fromUri(DataIdentifierScheme.CIS+"://"+cisPrivate.getCisId()+"/"+CisAttributeTypes.MEMBER_LIST);
}
catch (MalformedCtxIdentifierException e) {
LOG.error("setUpClass(): DataId creation error", e);
fail("setUpClass(): DataId creation error "+e);
}
catch (Exception e) {
LOG.error("setUpClass(): error", e);
fail("setUpClass(): error "+e);
}
}
@After
public void tearDown() throws Exception
{
LOG.info(""+getClass().getSimpleName()+"::tearDown");
}
@AfterClass
public static void tearDownClass() throws Exception
{
LOG.info("CisDataAccessControl::tearDownClass");
try {
cisManager.deleteCis(cisPublic.getCisId());
cisManager.deleteCis(cisMembersOnly.getCisId());
cisManager.deleteCis(cisPrivate.getCisId());
}
catch(Exception e) {
LOG.error("tearDownClass(): Can't delete CISs "+e+"\n", e);
fail("tearDownClass(): Can't delete CISs "+e);
}
}
/* --- CHECK PERMISSION CIS --- */
@Test
@Rollback(true)
public void testCheckPermissionPublicCis()
{
String testTitle = new String("testCheckPermissionPublicCis - Check permission public CIS: retrieve a privacy (for the first time, and then retrieved)");
LOG.info(""+testTitle);
List<ResponseItem> permissionsOther0 = null;
List<ResponseItem> permissionsOther1 = null;
List<ResponseItem> permissionsMember1 = null;
List<ResponseItem> permissionsMe1 = null;
List<ResponseItem> permissionsOther2 = null;
List<ResponseItem> permissionsMember2 = null;
List<ResponseItem> permissionsMe2 = null;
try {
permissionsOther0 = privacyDataManager.checkPermission(requestorMyService, cisPublicDataId, actionsRead);
permissionsOther1 = privacyDataManager.checkPermission(requestorOtherCssId, cisPublicDataId, actionsRead);
permissionsMember1 = privacyDataManager.checkPermission(requestorMemberCssId, cisPublicDataId, actionsRead);
permissionsMe1 = privacyDataManager.checkPermission(requestorMyCssId, cisPublicDataId, actionsRead);
permissionsOther2 = privacyDataManager.checkPermission(requestorOtherCssId, cisPublicDataId, actionsRead);
permissionsMember2 = privacyDataManager.checkPermission(requestorMemberCssId, cisPublicDataId, actionsRead);
permissionsMe2 = privacyDataManager.checkPermission(requestorMyCssId, cisPublicDataId, actionsRead);
} catch (PrivacyException e) {
LOG.error("[PrivacyException] "+testTitle, e);
fail("PrivacyException ("+e+") "+testTitle);
}
assertNotNull("Other0: No permission retrieved", permissionsOther0);
assertTrue("Other0: No permission retrieved", permissionsOther0.size() > 0);
assertNotNull("Other0: No (real) permission retrieved", permissionsOther0.get(0).getDecision());
assertEquals("Other0: Bad permission retrieved", Decision.PERMIT.name(), permissionsOther0.get(0).getDecision().name());
assertNotNull("Other1: No permission retrieved", permissionsOther1);
assertTrue("Other1: No permission retrieved", permissionsOther1.size() > 0);
assertNotNull("Other1: No (real) permission retrieved", permissionsOther1.get(0).getDecision());
assertEquals("Other1: Bad permission retrieved", Decision.PERMIT.name(), permissionsOther1.get(0).getDecision().name());
assertNotNull("Other2: No permission retrieved", permissionsOther2);
assertTrue("Other2: No permission retrieved", permissionsOther2.size() > 0);
assertNotNull("Other2: No (real) permission retrieved", permissionsOther2.get(0).getDecision());
assertEquals("Other2: Bad permission retrieved", Decision.PERMIT.name(), permissionsOther2.get(0).getDecision().name());
assertEquals("Other1-2: Two requests, not the same answer", ResponseItemUtils.toXmlString(permissionsOther1.get(0)), ResponseItemUtils.toXmlString(permissionsOther2.get(0)));
assertNotNull("Member1: No permission retrieved", permissionsMember1);
assertTrue("Member1: No permission retrieved", permissionsMember1.size() > 0);
assertNotNull("Member1: No (real) permission retrieved", permissionsMember1.get(0).getDecision());
assertEquals("Member1: Bad permission retrieved", Decision.PERMIT.name(), permissionsMember1.get(0).getDecision().name());
assertNotNull("Member2: No permission retrieved", permissionsMember2);
assertTrue("Member2: No permission retrieved", permissionsMember1.size() > 0);
assertNotNull("Member2: No (real) permission retrieved", permissionsMember2.get(0).getDecision());
assertEquals("Member2: Bad permission retrieved", Decision.PERMIT.name(), permissionsMember2.get(0).getDecision().name());
assertEquals("Member1-2: Two requests, not the same answer", ResponseItemUtils.toXmlString(permissionsMember1.get(0)), ResponseItemUtils.toXmlString(permissionsMember2.get(0)));
assertNotNull("Me1: No permission retrieved", permissionsMe1);
assertTrue("Me1: No permission retrieved", permissionsMe1.size() > 0);
assertNotNull("Me1: No (real) permission retrieved", permissionsMe1.get(0).getDecision());
assertEquals("Me1: Bad permission retrieved", Decision.PERMIT.name(), permissionsMe1.get(0).getDecision().name());
assertNotNull("Me2: No permission retrieved", permissionsMe2);
assertTrue("Me2: No permission retrieved", permissionsMe2.size() > 0);
assertNotNull("Me2: No (real) permission retrieved", permissionsMe2.get(0).getDecision());
assertEquals("Me2: Bad permission retrieved", Decision.PERMIT.name(), permissionsMe2.get(0).getDecision().name());
assertEquals("Me1-2: Two requests, not the same answer", ResponseItemUtils.toXmlString(permissionsMe1.get(0)), ResponseItemUtils.toXmlString(permissionsMe2.get(0)));
}
@Test
@Rollback(true)
public void testCheckPermissionMembersOnlyCis()
{
String testTitle = new String("testCheckPermissionMembersOnlyCis - Check permission members only CIS: retrieve a privacy (for the first time, and then retrieved)");
LOG.info(""+testTitle);
List<ResponseItem> permissionsOther0 = null;
List<ResponseItem> permissionsOther1 = null;
List<ResponseItem> permissionsMember1 = null;
List<ResponseItem> permissionsMe1 = null;
List<ResponseItem> permissionsOther2 = null;
List<ResponseItem> permissionsMember2 = null;
List<ResponseItem> permissionsMe2 = null;
try {
permissionsOther0 = privacyDataManager.checkPermission(requestorMyService, cisMembersOnlyDataId, actionsRead);
permissionsOther1 = privacyDataManager.checkPermission(requestorOtherCssId, cisMembersOnlyDataId, actionsRead);
permissionsMember1 = privacyDataManager.checkPermission(requestorMemberCssId, cisMembersOnlyDataId, actionsRead);
permissionsMe1 = privacyDataManager.checkPermission(requestorMyCssId, cisMembersOnlyDataId, actionsRead);
permissionsOther2 = privacyDataManager.checkPermission(requestorOtherCssId, cisMembersOnlyDataId, actionsRead);
permissionsMember2 = privacyDataManager.checkPermission(requestorMemberCssId, cisMembersOnlyDataId, actionsRead);
permissionsMe2 = privacyDataManager.checkPermission(requestorMyCssId, cisMembersOnlyDataId, actionsRead);
} catch (PrivacyException e) {
LOG.error("[PrivacyException] "+testTitle, e);
fail("PrivacyException ("+e+") "+testTitle);
}
assertNotNull("Other0: No permission retrieved", permissionsOther0);
assertTrue("Other0: No permission retrieved", permissionsOther0.size() > 0);
assertNotNull("Other0: No (real) permission retrieved", permissionsOther0.get(0).getDecision());
assertEquals("Other0: Bad permission retrieved", Decision.DENY.name(), permissionsOther0.get(0).getDecision().name());
assertNotNull("Other1: No permission retrieved", permissionsOther1);
assertTrue("Other1: No permission retrieved", permissionsOther1.size() > 0);
assertNotNull("Other1: No (real) permission retrieved", permissionsOther1.get(0).getDecision());
assertEquals("Other1: Bad permission retrieved", Decision.DENY.name(), permissionsOther1.get(0).getDecision().name());
assertNotNull("Other2: No permission retrieved", permissionsOther2);
assertTrue("Other2: No permission retrieved", permissionsOther2.size() > 0);
assertNotNull("Other2: No (real) permission retrieved", permissionsOther2.get(0).getDecision());
assertEquals("Other2: Bad permission retrieved", Decision.DENY.name(), permissionsOther2.get(0).getDecision().name());
assertEquals("Other1-2: Two requests, not the same answer", ResponseItemUtils.toXmlString(permissionsOther1.get(0)), ResponseItemUtils.toXmlString(permissionsOther2.get(0)));
assertNotNull("Member1: No permission retrieved", permissionsMember1);
assertTrue("Member1: No permission retrieved", permissionsMember1.size() > 0);
assertNotNull("Member1: No (real) permission retrieved", permissionsMember1.get(0).getDecision());
assertEquals("Member1: Bad permission retrieved", Decision.PERMIT.name(), permissionsMember1.get(0).getDecision().name());
assertNotNull("Member2: No permission retrieved", permissionsMember2);
assertTrue("Member2: No permission retrieved", permissionsMember1.size() > 0);
assertNotNull("Member2: No (real) permission retrieved", permissionsMember2.get(0).getDecision());
assertEquals("Member2: Bad permission retrieved", Decision.PERMIT.name(), permissionsMember2.get(0).getDecision().name());
assertEquals("Member1-2: Two requests, not the same answer", ResponseItemUtils.toXmlString(permissionsMember1.get(0)), ResponseItemUtils.toXmlString(permissionsMember2.get(0)));
assertNotNull("Me1: No permission retrieved", permissionsMe1);
assertTrue("Me1: No permission retrieved", permissionsMe1.size() > 0);
assertNotNull("Me1: No (real) permission retrieved", permissionsMe1.get(0).getDecision());
assertEquals("Me1: Bad permission retrieved", Decision.PERMIT.name(), permissionsMe1.get(0).getDecision().name());
assertNotNull("Me2: No permission retrieved", permissionsMe2);
assertTrue("Me2: No permission retrieved", permissionsMe2.size() > 0);
assertNotNull("Me2: No (real) permission retrieved", permissionsMe2.get(0).getDecision());
assertEquals("Me2: Bad permission retrieved", Decision.PERMIT.name(), permissionsMe2.get(0).getDecision().name());
assertEquals("Me1-2: Two requests, not the same answer", ResponseItemUtils.toXmlString(permissionsMe1.get(0)), ResponseItemUtils.toXmlString(permissionsMe2.get(0)));
}
@Test
@Rollback(true)
public void testCheckPermissionPrivateCis()
{
String testTitle = new String("testCheckPermissionPrivateCis- Check permission private CIS: retrieve a privacy (for the first time, and then retrieved)");
LOG.info(""+testTitle);
List<ResponseItem> permissionsOther0 = null;
List<ResponseItem> permissionsOther1 = null;
List<ResponseItem> permissionsMember1 = null;
List<ResponseItem> permissionsMe1 = null;
List<ResponseItem> permissionsOther2 = null;
List<ResponseItem> permissionsMember2 = null;
List<ResponseItem> permissionsMe2 = null;
try {
permissionsOther0 = privacyDataManager.checkPermission(requestorMyService, cisPrivateDataId, actionsRead);
permissionsOther1 = privacyDataManager.checkPermission(requestorOtherCssId, cisPrivateDataId, actionsRead);
permissionsMember1 = privacyDataManager.checkPermission(requestorMemberCssId, cisPrivateDataId, actionsRead);
permissionsMe1 = privacyDataManager.checkPermission(requestorMyCssId, cisPrivateDataId, actionsRead);
permissionsOther2 = privacyDataManager.checkPermission(requestorOtherCssId, cisPrivateDataId, actionsRead);
permissionsMember2 = privacyDataManager.checkPermission(requestorMemberCssId, cisPrivateDataId, actionsRead);
permissionsMe2 = privacyDataManager.checkPermission(requestorMyCssId, cisPrivateDataId, actionsRead);
} catch (PrivacyException e) {
LOG.error("[PrivacyException] "+testTitle, e);
fail("PrivacyException ("+e+") "+testTitle);
}
assertNotNull("Other0: No permission retrieved", permissionsOther0);
assertTrue("Other0: No permission retrieved", permissionsOther0.size() > 0);
assertNotNull("Other0: No (real) permission retrieved", permissionsOther0.get(0).getDecision());
assertEquals("Other0: Bad permission retrieved", Decision.DENY.name(), permissionsOther0.get(0).getDecision().name());
assertNotNull("Other1: No permission retrieved", permissionsOther1);
assertTrue("Other1: No permission retrieved", permissionsOther1.size() > 0);
assertNotNull("Other1: No (real) permission retrieved", permissionsOther1.get(0).getDecision());
assertEquals("Other1: Bad permission retrieved", Decision.DENY.name(), permissionsOther1.get(0).getDecision().name());
assertNotNull("Other2: No permission retrieved", permissionsOther2);
assertTrue("Other2: No permission retrieved", permissionsOther2.size() > 0);
assertNotNull("Other2: No (real) permission retrieved", permissionsOther2.get(0).getDecision());
assertEquals("Other2: Bad permission retrieved", Decision.DENY.name(), permissionsOther2.get(0).getDecision().name());
assertEquals("Other1-2: Two requests, not the same answer", ResponseItemUtils.toXmlString(permissionsOther1.get(0)), ResponseItemUtils.toXmlString(permissionsOther2.get(0)));
assertNotNull("Member1: No permission retrieved", permissionsMember1);
assertTrue("Member1: No permission retrieved", permissionsMember1.size() > 0);
assertNotNull("Member1: No (real) permission retrieved", permissionsMember1.get(0).getDecision());
assertEquals("Member1: Bad permission retrieved", Decision.DENY.name(), permissionsMember1.get(0).getDecision().name());
assertNotNull("Member2: No permission retrieved", permissionsMember2);
assertTrue("Member2: No permission retrieved", permissionsMember1.size() > 0);
assertNotNull("Member2: No (real) permission retrieved", permissionsMember2.get(0).getDecision());
assertEquals("Member2: Bad permission retrieved", Decision.DENY.name(), permissionsMember2.get(0).getDecision().name());
assertEquals("Member1-2: Two requests, not the same answer", ResponseItemUtils.toXmlString(permissionsMember1.get(0)), ResponseItemUtils.toXmlString(permissionsMember2.get(0)));
assertNotNull("Me1: No permission retrieved", permissionsMe1);
assertTrue("Me1: No permission retrieved", permissionsMe1.size() > 0);
assertNotNull("Me1: No (real) permission retrieved", permissionsMe1.get(0).getDecision());
assertEquals("Me1: Bad permission retrieved", Decision.PERMIT.name(), permissionsMe1.get(0).getDecision().name());
assertNotNull("Me2: No permission retrieved", permissionsMe2);
assertTrue("Me2: No permission retrieved", permissionsMe2.size() > 0);
assertNotNull("Me2: No (real) permission retrieved", permissionsMe2.get(0).getDecision());
assertEquals("Me2: Bad permission retrieved", Decision.PERMIT.name(), permissionsMe2.get(0).getDecision().name());
assertEquals("Me1-2: Two requests, not the same answer", ResponseItemUtils.toXmlString(permissionsMe1.get(0)), ResponseItemUtils.toXmlString(permissionsMe2.get(0)));
}
// -- Dependency Injection
public void setPrivacyDataManager(IPrivacyDataManager privacyDataManager) {
this.privacyDataManager = privacyDataManager;
LOG.info("[Dependency Injection] IPrivacyDataManager injected");
}
}