Skip to content

Commit

Permalink
Improve unit test coverage.
Browse files Browse the repository at this point in the history
  • Loading branch information
Thisara-Welmilla committed Nov 22, 2024
1 parent 6899f28 commit 814c4fd
Show file tree
Hide file tree
Showing 3 changed files with 63 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -94,13 +94,6 @@ public int getCountOfFilteredIdPs(int tenantId, List<ExpressionNode> expressionC
return dao.getCountOfFilteredIdPs(tenantId, expressionConditions);
}

public ProvisioningConnectorConfig[] getProvisioningConnectorConfigs(Connection dbConnection,
String idPName, int idPId, int tenantId)
throws IdentityProviderManagementException, SQLException {

return dao.getProvisioningConnectorConfigs(dbConnection, idPName, idPId, tenantId);
}

public IdentityProvider getIdPByName(Connection dbConnection, String idPName, int tenantId, String tenantDomain)
throws IdentityProviderManagementException {

Expand Down Expand Up @@ -268,12 +261,6 @@ public void renameTenantRole(String newRoleName, String oldRoleName, int tenantI
dao.renameTenantRole(newRoleName, oldRoleName, tenantId, tenantDomain);
}

public void renameClaimURI(String newClaimURI, String oldClaimURI, int tenantId, String tenantDomain)
throws IdentityProviderManagementException {

dao.renameClaimURI(newClaimURI, oldClaimURI, tenantId, tenantDomain);
}

public boolean isIdPAvailableForAuthenticatorProperty(String authenticatorName, String propertyName,
String idPEntityId, int tenantId)
throws IdentityProviderManagementException {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -693,6 +693,25 @@ public void testForceDeleteIdP(String idpName) throws Exception {
Assert.assertNull(identityProviderManagementService.getIdPByName(idpName));
}

@Test(dataProvider = "forceDeleteIdPData")
public void testForceDeleteIdPDAOException(String idpName) throws Exception {

addTestIdps();
Assert.assertNotNull(identityProviderManagementService.getIdPByName(idpName));

IdPManagementDAO daoForError = mock(IdPManagementDAO.class);
doThrow(IdentityProviderManagementServerException.class).when(daoForError)
.forceDeleteIdPByResourceId(anyString(), anyInt(), anyString());
daoForException = new CacheBackedIdPMgtDAO(daoForError);
field.set(identityProviderManager, daoForException);

assertThrows(IdentityProviderManagementException.class, () ->
identityProviderManagementService.forceDeleteIdP(idpName));

field.set(identityProviderManager, dao);
Assert.assertNotNull(identityProviderManagementService.getIdPByName(idpName));
}

@DataProvider
public Object[][] forceDeleteIdPExceptionData() {

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -68,21 +68,15 @@
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.*;

import static org.mockito.ArgumentMatchers.any;
import static org.mockito.ArgumentMatchers.anyBoolean;
import static org.mockito.ArgumentMatchers.anyInt;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.mockStatic;
import static org.mockito.Mockito.when;
import static org.testng.Assert.assertEquals;
import static org.testng.Assert.assertNull;
import static org.testng.Assert.assertThrows;
import static org.testng.Assert.*;
import static org.wso2.carbon.idp.mgt.util.IdPManagementConstants.RESET_PROVISIONING_ENTITIES_ON_CONFIG_UPDATE;

/**
Expand Down Expand Up @@ -469,6 +463,29 @@ public void testGetIdPById(String idpName, int idpId, int tenantId, boolean isEx
}
}

@Test
public void testGetIdPNamesById() throws Exception {

try (MockedStatic<IdentityDatabaseUtil> identityDatabaseUtil = mockStatic(IdentityDatabaseUtil.class);
Connection connection = getConnection(DB_NAME)) {
identityDatabaseUtil.when(() -> IdentityDatabaseUtil.getDBConnection(anyBoolean())).thenReturn(connection);
identityDatabaseUtil.when(IdentityDatabaseUtil::getDataSource).thenReturn(dataSourceMap.get(DB_NAME));
addTestIdps();

Set<String> idpIds = new HashSet<>(Arrays.asList(
cacheBackedIdPMgtDAO.getIdPByName(connection, "testIdP1", SAMPLE_TENANT_ID1, TENANT_DOMAIN)
.getIdentityProviderName(),
cacheBackedIdPMgtDAO.getIdPByName(connection, "testIdP2", SAMPLE_TENANT_ID1, TENANT_DOMAIN)
.getIdentityProviderName()
));
// Retrieving IDP form DB and adding to cache.
Map<String, String> idpNameMap = cacheBackedIdPMgtDAO.getIdPNamesById(SAMPLE_TENANT_ID1, idpIds);

assertTrue(idpNameMap.containsKey("testIdP1"));
assertTrue(idpNameMap.containsKey("testIdP2"));
}
}

@DataProvider
public Object[][] getIDPbyResourceIdData() {

Expand Down Expand Up @@ -558,6 +575,25 @@ public void testGetIdPNameByResourceId(String idpName, int tenantId) throws Exce
}
}

@Test(dataProvider = "getIDPNameByResourceIdData")
public void testGetIdPNameByResourceIdFromDB(String idpName, int tenantId) throws Exception {

try (MockedStatic<IdentityDatabaseUtil> identityDatabaseUtil = mockStatic(IdentityDatabaseUtil.class);
Connection connection = getConnection(DB_NAME)) {
identityDatabaseUtil.when(() -> IdentityDatabaseUtil.getDBConnection(anyBoolean())).thenReturn(connection);
identityDatabaseUtil.when(IdentityDatabaseUtil::getDBConnection).thenReturn(connection);
identityDatabaseUtil.when(IdentityDatabaseUtil::getDataSource).thenReturn(dataSourceMap.get(DB_NAME));
addTestIdps();

// Retrieving IDP from DB.
IdentityProvider idPResult = idPManagementDAO.getIdPByName(connection, idpName, tenantId, TENANT_DOMAIN);
String uuid = idPResult.getResourceId();

String nameFromDB = cacheBackedIdPMgtDAO.getIdPNameByResourceId(uuid);
assertEquals(nameFromDB, idpName);
}
}

@DataProvider
public Object[][] getIdPByAuthenticatorPropertyValueWithoutAuthenticatorData() {

Expand Down

0 comments on commit 814c4fd

Please sign in to comment.