use of com.zimbra.soap.admin.type.PrincipalSelector in project zm-mailbox by Zimbra.
the class TestAutoProvision method errorHandling.
@Test
@Bug(bug = 70720)
public void errorHandling() throws Exception {
/*
* create and setup zimbra domain
*/
Map<String, Object> domainAttrs = Maps.newHashMap();
domainAttrs.put(Provisioning.A_zimbraAutoProvLdapURL, "ldap://localhost:389");
domainAttrs.put(Provisioning.A_zimbraAutoProvLdapAdminBindDn, extDomainAdminBindDn);
domainAttrs.put(Provisioning.A_zimbraAutoProvLdapAdminBindPassword, extDomainAdminBindPassword);
StringUtil.addToMultiMap(domainAttrs, Provisioning.A_zimbraAutoProvMode, AutoProvMode.LAZY.name());
StringUtil.addToMultiMap(domainAttrs, Provisioning.A_zimbraAutoProvMode, AutoProvMode.MANUAL.name());
domainAttrs.put(Provisioning.A_zimbraAutoProvLdapSearchFilter, "(cn=auth*)");
// domainAttrs.put(Provisioning.A_zimbraAutoProvLdapSearchFilter, "(cn=%n)");
domainAttrs.put(Provisioning.A_zimbraAutoProvLdapSearchBase, extDomainDn);
domainAttrs.put(Provisioning.A_zimbraAutoProvAccountNameMap, "cn");
domainAttrs.put(Provisioning.A_zimbraAutoProvAttrMap, "userPassword=userPassword");
Domain domain = createZimbraDomain(genDomainSegmentName(), domainAttrs);
/*
* create external accounts
*/
Map<String, Object> extAcct1Attrs = Maps.newHashMap();
extAcct1Attrs.put("cn", "authaccount01");
createExternalAcctEntry("acct1", "test123", extAcct1Attrs);
Map<String, Object> extAcct2Attrs = Maps.newHashMap();
extAcct2Attrs.put("cn", "authaccount02");
createExternalAcctEntry("acct2", "test123", extAcct2Attrs);
Map<String, Object> extAcct3Attrs = Maps.newHashMap();
extAcct3Attrs.put("cn", "authaccount03");
createExternalAcctEntry("acct3", "test123", extAcct3Attrs);
Map<String, Object> extAcct4Attrs = Maps.newHashMap();
extAcct4Attrs.put("cn", "authaccount04");
createExternalAcctEntry("acct4", "test123", extAcct4Attrs);
/*
* do a manual auto provision
*/
SoapTransport transport = authZimbraAdmin();
DomainSelector domainSel = new DomainSelector(DomainSelector.DomainBy.name, domain.getName());
PrincipalSelector principalSel = PrincipalSelector.create(AutoProvPrincipalBy.name, "authaccount04");
AutoProvAccountRequest req = AutoProvAccountRequest.create(domainSel, principalSel);
boolean caughtException = false;
try {
invokeJaxb(transport, req);
} catch (ServiceException e) {
String msg = e.getMessage();
if (e.getCode().equals(LdapException.MULTIPLE_ENTRIES_MATCHED) && msg.contains(String.format("uid=acct1,ou=people,%s", extDomainDn)) && msg.contains(String.format("uid=acct2,ou=people,%s", extDomainDn)) && msg.contains(String.format("uid=acct3,ou=people,%s", extDomainDn)) && msg.contains(String.format("uid=acct4,ou=people,%s", extDomainDn))) {
caughtException = true;
}
}
assertTrue(caughtException);
/*
* modify domain to have the correct search filter
*/
domain.setAutoProvLdapSearchFilter("(cn=%n)");
/*
* do the manual provision, should succeed this time
*/
AutoProvAccountResponse resp = invokeJaxb(transport, req);
AccountInfo acctInfo = resp.getAccount();
assertEquals(TestUtil.getAddress("authaccount04", domain.getName()), acctInfo.getName());
/*
* do the same manual provision again, should fail with
*/
caughtException = false;
try {
invokeJaxb(transport, req);
} catch (ServiceException e) {
String msg = e.getMessage();
if (e.getCode().equals(AccountServiceException.ACCOUNT_EXISTS)) {
caughtException = true;
}
}
assertTrue(caughtException);
/*
<CreateDomainRequest xmlns="urn:zimbraAdmin">
<name>autoprov44.1330496906457.com</name>
<a n="zimbraAutoProvLdapURL">ldap://zqa-003.eng.vmware.com:389/</a>
<a n="zimbraAutoProvLdapAdminBindDn">administrator@zimbraqa.com</a>
<a n="zimbraAutoProvLdapAdminBindPassword">liquidsys</a>
<a n="zimbraAutoProvMode">LAZY</a>
<a n="zimbraAutoProvMode">MANUAL</a>
<a n="zimbraAutoProvLdapSearchFilter">(cn=auth*)</a>
<a n="zimbraAutoProvLdapSearchBase">OU=CommonUsers,DC=zimbraqa,DC=com</a>
<a n="zimbraAutoProvAccountNameMap">cn</a>
<a n="zimbraAutoProvAttrMap">userPassword=userPassword</a>
</CreateDomainRequest>
zmsoap -z AutoProvAccountRequest domain=bug70720.com.zimbra.qa.unittest.prov.soap.testautoprovision.soaptest.unittest @by=name ../principal=authaccount04 @by=name
this zmsoap yields the following soap:
<AutoProvAccountRequest xmlns="urn:zimbraAdmin">
<domain by="name">bug70720.com.zimbra.qa.unittest.prov.soap.testautoprovision.soaptest.unittest</domain>
<principal by="name">authaccount04</principal>
</AutoProvAccountRequest>
*/
}
Aggregations