Object name validator component
* Moved the component from the -user package to the -naming package * Added a separate interface to the component
This commit is contained in:
parent
35d8891fe3
commit
b4903d78e4
14 changed files with 483 additions and 104 deletions
|
@ -0,0 +1,136 @@
|
|||
package com.deepclone.lw.beans.naming;
|
||||
|
||||
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
import com.deepclone.lw.cmd.ObjectNameError;
|
||||
import com.deepclone.lw.interfaces.naming.ObjectNameValidator;
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Object name validation component
|
||||
*
|
||||
* <p>
|
||||
* This component implements the simple name "pre-validation" component, used before an empire or
|
||||
* map name is sent to the database.
|
||||
*
|
||||
* <p>
|
||||
* By default, it will accept names that are between 2 and 20 characters. That may be modified in
|
||||
* the component's initialisation.
|
||||
*
|
||||
* @author <a href="mailto:tseeker@legacyworlds.com">E. Benoît</a>
|
||||
*/
|
||||
class ObjectNameValidatorBean
|
||||
implements ObjectNameValidator
|
||||
{
|
||||
/** Default minimal length */
|
||||
public static final int MIN_LENGTH = 2;
|
||||
|
||||
/** Default maximal length */
|
||||
public static final int MAX_LENGTH = 20;
|
||||
|
||||
/**
|
||||
* Invalid patterns
|
||||
*
|
||||
* <p>
|
||||
* This constant lists patterns which must be rejected systematically.
|
||||
*/
|
||||
private static final Pattern fail[] = {
|
||||
Pattern.compile( "\\s\\s+" ) , Pattern.compile( "[^A-Za-z0-9 _\\'\\!\\:\\,\\-\\.\\*@\\[\\]\\{\\}]" )
|
||||
};
|
||||
|
||||
/**
|
||||
* Required patterns
|
||||
*
|
||||
* <p>
|
||||
* This constant lists patters which must be present for a name to be considered valid.
|
||||
*/
|
||||
private static final Pattern needed[] = {
|
||||
Pattern.compile( "[A-Za-z]" )
|
||||
};
|
||||
|
||||
/** Minimal length of a name */
|
||||
private int minLength = MIN_LENGTH;
|
||||
|
||||
/** Maximal length of a name */
|
||||
private int maxLength = MAX_LENGTH;
|
||||
|
||||
|
||||
/**
|
||||
* Set the minimal length of a name
|
||||
*
|
||||
* @param length
|
||||
* the new minimal length
|
||||
*/
|
||||
public void setMinLength( Integer length )
|
||||
{
|
||||
this.minLength = length;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set the maximal length of a name
|
||||
*
|
||||
* @param length
|
||||
* the new maximal length
|
||||
*/
|
||||
public void setMaxLength( Integer length )
|
||||
{
|
||||
this.maxLength = length;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* (non-Javadoc)
|
||||
*
|
||||
* @see com.deepclone.lw.beans.user.ObjectNameValidator#validate(java.lang.String)
|
||||
*/
|
||||
@Override
|
||||
public ObjectNameError validate( String name )
|
||||
{
|
||||
return this.validate( name , this.minLength , this.maxLength );
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* (non-Javadoc)
|
||||
*
|
||||
* @see com.deepclone.lw.beans.user.ObjectNameValidator#customValidate(java.lang.String, int,
|
||||
* int)
|
||||
*/
|
||||
@Override
|
||||
public ObjectNameError validate( String name , int minLength , int maxLength )
|
||||
{
|
||||
if ( "".equals( name.trim( ) ) ) {
|
||||
return ObjectNameError.EMPTY;
|
||||
}
|
||||
|
||||
// No leading or trailing spaces
|
||||
if ( !name.equals( name.trim( ) ) ) {
|
||||
return ObjectNameError.INVALID;
|
||||
}
|
||||
|
||||
// Check length
|
||||
int length = name.length( );
|
||||
if ( length < minLength || length > maxLength ) {
|
||||
return ObjectNameError.INVALID;
|
||||
}
|
||||
|
||||
// Check bad patterns
|
||||
for ( Pattern p : ObjectNameValidatorBean.fail ) {
|
||||
if ( p.matcher( name ).find( ) ) {
|
||||
return ObjectNameError.INVALID;
|
||||
}
|
||||
}
|
||||
|
||||
// Check good patterns
|
||||
for ( Pattern p : ObjectNameValidatorBean.needed ) {
|
||||
if ( !p.matcher( name ).find( ) ) {
|
||||
return ObjectNameError.INVALID;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
|
@ -4,6 +4,7 @@
|
|||
xsi:schemaLocation="
|
||||
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd">
|
||||
|
||||
<bean id="objectNameValidator" class="com.deepclone.lw.beans.naming.ObjectNameValidatorBean" />
|
||||
<bean id="namesManager" class="com.deepclone.lw.beans.naming.NamesManagerBean" />
|
||||
<bean id="namingDAO" class="com.deepclone.lw.beans.naming.NamingDAOBean" />
|
||||
|
||||
|
|
|
@ -1,77 +0,0 @@
|
|||
package com.deepclone.lw.beans.user;
|
||||
|
||||
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
import com.deepclone.lw.cmd.ObjectNameError;
|
||||
|
||||
|
||||
|
||||
public class ObjectNameValidatorBean
|
||||
{
|
||||
|
||||
private int minLength = 2;
|
||||
private int maxLength = 20;
|
||||
|
||||
private static Pattern fail[] = {
|
||||
Pattern.compile( "\\s\\s+" ) ,
|
||||
Pattern.compile( "[^A-Za-z0-9 _\\'\\!\\:\\,\\-\\.\\*@\\[\\]\\{\\}]" )
|
||||
};
|
||||
|
||||
private static Pattern needed[] = {
|
||||
Pattern.compile( "[A-Za-z]" )
|
||||
};
|
||||
|
||||
|
||||
public void setMinLength( Integer v )
|
||||
{
|
||||
this.minLength = v;
|
||||
}
|
||||
|
||||
|
||||
public void setMaxLength( Integer v )
|
||||
{
|
||||
this.maxLength = v;
|
||||
}
|
||||
|
||||
|
||||
public ObjectNameError validate( String name )
|
||||
{
|
||||
return this.customValidate( name , this.minLength , this.maxLength );
|
||||
}
|
||||
|
||||
|
||||
public ObjectNameError customValidate( String name , int minLength , int maxLength )
|
||||
{
|
||||
if ( "".equals( name.trim( ) ) ) {
|
||||
return ObjectNameError.EMPTY;
|
||||
}
|
||||
|
||||
// No leading or trailing spaces
|
||||
if ( !name.equals( name.trim( ) ) ) {
|
||||
return ObjectNameError.INVALID;
|
||||
}
|
||||
|
||||
// Check length
|
||||
int length = name.length( );
|
||||
if ( length < minLength || length > maxLength ) {
|
||||
return ObjectNameError.INVALID;
|
||||
}
|
||||
|
||||
// Check bad patterns
|
||||
for ( Pattern p : ObjectNameValidatorBean.fail ) {
|
||||
if ( p.matcher( name ).find( ) ) {
|
||||
return ObjectNameError.INVALID;
|
||||
}
|
||||
}
|
||||
|
||||
// Check good patterns
|
||||
for ( Pattern p : ObjectNameValidatorBean.needed ) {
|
||||
if ( !p.matcher( name ).find( ) ) {
|
||||
return ObjectNameError.INVALID;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
|
@ -3,7 +3,6 @@ package com.deepclone.lw.beans.user.admin.main.su;
|
|||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
|
||||
import com.deepclone.lw.beans.user.ObjectNameValidatorBean;
|
||||
import com.deepclone.lw.cmd.ObjectNameError;
|
||||
import com.deepclone.lw.cmd.admin.adata.Administrator;
|
||||
import com.deepclone.lw.cmd.admin.adata.Privileges;
|
||||
|
@ -11,6 +10,7 @@ import com.deepclone.lw.cmd.admin.su.AddAdministratorCommand;
|
|||
import com.deepclone.lw.cmd.admin.su.AddAdministratorResponse;
|
||||
import com.deepclone.lw.cmd.admin.su.AddAdministratorResponse.AddressError;
|
||||
import com.deepclone.lw.interfaces.admin.Administration;
|
||||
import com.deepclone.lw.interfaces.naming.ObjectNameValidator;
|
||||
import com.deepclone.lw.session.Command;
|
||||
import com.deepclone.lw.session.CommandResponse;
|
||||
import com.deepclone.lw.utils.EmailAddress;
|
||||
|
@ -22,7 +22,7 @@ public class AddAdministratorCommandDelegateBean
|
|||
{
|
||||
|
||||
private Administration administration;
|
||||
private ObjectNameValidatorBean validator;
|
||||
private ObjectNameValidator validator;
|
||||
|
||||
|
||||
@Autowired( required = true )
|
||||
|
@ -33,7 +33,7 @@ public class AddAdministratorCommandDelegateBean
|
|||
|
||||
|
||||
@Autowired( required = true )
|
||||
public void setValidator( ObjectNameValidatorBean validator )
|
||||
public void setValidator( ObjectNameValidator validator )
|
||||
{
|
||||
this.validator = validator;
|
||||
}
|
||||
|
@ -57,7 +57,7 @@ public class AddAdministratorCommandDelegateBean
|
|||
if ( "".equals( name ) ) {
|
||||
nameError = ObjectNameError.EMPTY;
|
||||
} else {
|
||||
nameError = this.validator.customValidate( name , 2 , 64 );
|
||||
nameError = this.validator.validate( name , 2 , 64 );
|
||||
}
|
||||
|
||||
// Check address
|
||||
|
|
|
@ -3,13 +3,13 @@ package com.deepclone.lw.beans.user.player;
|
|||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
|
||||
import com.deepclone.lw.beans.user.ObjectNameValidatorBean;
|
||||
import com.deepclone.lw.beans.user.abst.AutowiredCommandDelegate;
|
||||
import com.deepclone.lw.beans.user.abst.SessionCommandHandler;
|
||||
import com.deepclone.lw.cmd.ObjectNameError;
|
||||
import com.deepclone.lw.cmd.player.account.AccountValidationCommand;
|
||||
import com.deepclone.lw.cmd.player.account.AccountValidationResponse;
|
||||
import com.deepclone.lw.interfaces.acm.AccountManagement;
|
||||
import com.deepclone.lw.interfaces.naming.ObjectNameValidator;
|
||||
import com.deepclone.lw.interfaces.session.ServerSession;
|
||||
import com.deepclone.lw.session.Command;
|
||||
import com.deepclone.lw.session.CommandResponse;
|
||||
|
@ -23,7 +23,7 @@ public class ValidationCommandDelegateBean
|
|||
{
|
||||
|
||||
private AccountManagement manager;
|
||||
private ObjectNameValidatorBean validator;
|
||||
private ObjectNameValidator validator;
|
||||
|
||||
|
||||
@Autowired( required = true )
|
||||
|
@ -34,7 +34,7 @@ public class ValidationCommandDelegateBean
|
|||
|
||||
|
||||
@Autowired( required = true )
|
||||
public void setObjectNameValidator( ObjectNameValidatorBean validator )
|
||||
public void setObjectNameValidator( ObjectNameValidator validator )
|
||||
{
|
||||
this.validator = validator;
|
||||
}
|
||||
|
|
|
@ -3,7 +3,6 @@ package com.deepclone.lw.beans.user.player.game;
|
|||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
|
||||
import com.deepclone.lw.beans.user.ObjectNameValidatorBean;
|
||||
import com.deepclone.lw.beans.user.abst.AutowiredCommandDelegate;
|
||||
import com.deepclone.lw.beans.user.abst.SessionCommandHandler;
|
||||
import com.deepclone.lw.beans.user.player.GameSubTypeBean;
|
||||
|
@ -11,6 +10,7 @@ import com.deepclone.lw.cmd.ObjectNameError;
|
|||
import com.deepclone.lw.cmd.player.GetNewPlanetCommand;
|
||||
import com.deepclone.lw.cmd.player.GetNewPlanetResponse;
|
||||
import com.deepclone.lw.interfaces.game.EmpireManagement;
|
||||
import com.deepclone.lw.interfaces.naming.ObjectNameValidator;
|
||||
import com.deepclone.lw.interfaces.session.ServerSession;
|
||||
import com.deepclone.lw.session.Command;
|
||||
import com.deepclone.lw.session.CommandResponse;
|
||||
|
@ -23,7 +23,7 @@ public class GetNewPlanetCommandDelegateBean
|
|||
{
|
||||
|
||||
private EmpireManagement empireManagement;
|
||||
private ObjectNameValidatorBean validator;
|
||||
private ObjectNameValidator validator;
|
||||
|
||||
|
||||
@Autowired( required = true )
|
||||
|
@ -34,7 +34,7 @@ public class GetNewPlanetCommandDelegateBean
|
|||
|
||||
|
||||
@Autowired( required = true )
|
||||
public void setObjectNameValidator( ObjectNameValidatorBean validator )
|
||||
public void setObjectNameValidator( ObjectNameValidator validator )
|
||||
{
|
||||
this.validator = validator;
|
||||
}
|
||||
|
|
|
@ -3,7 +3,6 @@ package com.deepclone.lw.beans.user.player.game.alliances;
|
|||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
|
||||
import com.deepclone.lw.beans.user.ObjectNameValidatorBean;
|
||||
import com.deepclone.lw.beans.user.abst.AutowiredCommandDelegate;
|
||||
import com.deepclone.lw.beans.user.abst.SessionCommandHandler;
|
||||
import com.deepclone.lw.beans.user.player.GameSubTypeBean;
|
||||
|
@ -13,6 +12,7 @@ import com.deepclone.lw.cmd.player.alliances.CreateAllianceCommand;
|
|||
import com.deepclone.lw.cmd.player.alliances.CreateAllianceResponse;
|
||||
import com.deepclone.lw.cmd.player.gdata.alliance.AllianceCreationStatus;
|
||||
import com.deepclone.lw.interfaces.game.AllianceManagement;
|
||||
import com.deepclone.lw.interfaces.naming.ObjectNameValidator;
|
||||
import com.deepclone.lw.interfaces.session.ServerSession;
|
||||
import com.deepclone.lw.session.Command;
|
||||
import com.deepclone.lw.session.CommandResponse;
|
||||
|
@ -24,7 +24,7 @@ public class CreateAllianceCommandDelegateBean
|
|||
{
|
||||
|
||||
private AllianceManagement allianceManagement;
|
||||
private ObjectNameValidatorBean validator;
|
||||
private ObjectNameValidator validator;
|
||||
|
||||
|
||||
@Autowired( required = true )
|
||||
|
@ -35,7 +35,7 @@ public class CreateAllianceCommandDelegateBean
|
|||
|
||||
|
||||
@Autowired( required = true )
|
||||
public void setObjectNameValidator( ObjectNameValidatorBean validator )
|
||||
public void setObjectNameValidator( ObjectNameValidator validator )
|
||||
{
|
||||
this.validator = validator;
|
||||
}
|
||||
|
@ -65,10 +65,10 @@ public class CreateAllianceCommandDelegateBean
|
|||
}
|
||||
|
||||
String tag = command.getTag( );
|
||||
ObjectNameError tagError = this.validator.customValidate( tag , 2 , 5 );
|
||||
ObjectNameError tagError = this.validator.validate( tag , 2 , 5 );
|
||||
|
||||
String name = command.getName( );
|
||||
ObjectNameError nameError = this.validator.customValidate( name , 5 , 64 );
|
||||
ObjectNameError nameError = this.validator.validate( name , 5 , 64 );
|
||||
|
||||
if ( tagError != null || nameError != null ) {
|
||||
AllianceStatusResponse r = this.allianceManagement.getView( empireId );
|
||||
|
|
|
@ -3,13 +3,13 @@ package com.deepclone.lw.beans.user.player.game.fleets;
|
|||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
|
||||
import com.deepclone.lw.beans.user.ObjectNameValidatorBean;
|
||||
import com.deepclone.lw.beans.user.abst.AutowiredCommandDelegate;
|
||||
import com.deepclone.lw.beans.user.abst.SessionCommandHandler;
|
||||
import com.deepclone.lw.beans.user.player.GameSubTypeBean;
|
||||
import com.deepclone.lw.cmd.player.fleets.RenameFleetsCommand;
|
||||
import com.deepclone.lw.cmd.player.fleets.RenameFleetsResponse;
|
||||
import com.deepclone.lw.interfaces.game.FleetManagement;
|
||||
import com.deepclone.lw.interfaces.naming.ObjectNameValidator;
|
||||
import com.deepclone.lw.interfaces.session.ServerSession;
|
||||
import com.deepclone.lw.session.Command;
|
||||
import com.deepclone.lw.session.CommandResponse;
|
||||
|
@ -20,7 +20,7 @@ public class RenameFleetsCommandDelegateBean
|
|||
implements AutowiredCommandDelegate
|
||||
{
|
||||
private FleetManagement fleetManager;
|
||||
private ObjectNameValidatorBean validator;
|
||||
private ObjectNameValidator validator;
|
||||
|
||||
|
||||
@Autowired( required = true )
|
||||
|
@ -31,7 +31,7 @@ public class RenameFleetsCommandDelegateBean
|
|||
|
||||
|
||||
@Autowired( required = true )
|
||||
public void setObjectNameValidator( ObjectNameValidatorBean validator )
|
||||
public void setObjectNameValidator( ObjectNameValidator validator )
|
||||
{
|
||||
this.validator = validator;
|
||||
}
|
||||
|
@ -64,7 +64,7 @@ public class RenameFleetsCommandDelegateBean
|
|||
boolean error;
|
||||
if ( command.isRename( ) ) {
|
||||
name = command.getName( ).trim( );
|
||||
if ( !"".equals( name ) && this.validator.customValidate( name , 1 , 40 ) != null ) {
|
||||
if ( !"".equals( name ) && this.validator.validate( name , 1 , 40 ) != null ) {
|
||||
error = true;
|
||||
name = null;
|
||||
} else {
|
||||
|
|
|
@ -3,13 +3,13 @@ package com.deepclone.lw.beans.user.player.game.fleets;
|
|||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
|
||||
import com.deepclone.lw.beans.user.ObjectNameValidatorBean;
|
||||
import com.deepclone.lw.beans.user.abst.AutowiredCommandDelegate;
|
||||
import com.deepclone.lw.beans.user.abst.SessionCommandHandler;
|
||||
import com.deepclone.lw.beans.user.player.GameSubTypeBean;
|
||||
import com.deepclone.lw.cmd.player.fleets.SplitFleetCommand;
|
||||
import com.deepclone.lw.cmd.player.fleets.SplitFleetResponse;
|
||||
import com.deepclone.lw.interfaces.game.FleetManagement;
|
||||
import com.deepclone.lw.interfaces.naming.ObjectNameValidator;
|
||||
import com.deepclone.lw.interfaces.session.ServerSession;
|
||||
import com.deepclone.lw.session.Command;
|
||||
import com.deepclone.lw.session.CommandResponse;
|
||||
|
@ -20,7 +20,7 @@ public class SplitFleetCommandDelegateBean
|
|||
implements AutowiredCommandDelegate
|
||||
{
|
||||
private FleetManagement fleetManager;
|
||||
private ObjectNameValidatorBean validator;
|
||||
private ObjectNameValidator validator;
|
||||
|
||||
|
||||
@Autowired( required = true )
|
||||
|
@ -31,7 +31,7 @@ public class SplitFleetCommandDelegateBean
|
|||
|
||||
|
||||
@Autowired( required = true )
|
||||
public void setObjectNameValidator( ObjectNameValidatorBean validator )
|
||||
public void setObjectNameValidator( ObjectNameValidator validator )
|
||||
{
|
||||
this.validator = validator;
|
||||
}
|
||||
|
@ -64,7 +64,7 @@ public class SplitFleetCommandDelegateBean
|
|||
boolean error;
|
||||
if ( name != null ) {
|
||||
name = command.getName( ).trim( );
|
||||
if ( !"".equals( name ) && this.validator.customValidate( name , 1 , 40 ) != null ) {
|
||||
if ( !"".equals( name ) && this.validator.validate( name , 1 , 40 ) != null ) {
|
||||
error = true;
|
||||
name = "";
|
||||
} else {
|
||||
|
|
|
@ -3,7 +3,6 @@ package com.deepclone.lw.beans.user.player.game.planets;
|
|||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
|
||||
import com.deepclone.lw.beans.user.ObjectNameValidatorBean;
|
||||
import com.deepclone.lw.beans.user.abst.AutowiredCommandDelegate;
|
||||
import com.deepclone.lw.beans.user.abst.SessionCommandHandler;
|
||||
import com.deepclone.lw.beans.user.player.GameSubTypeBean;
|
||||
|
@ -12,6 +11,7 @@ import com.deepclone.lw.cmd.player.planets.RenamePlanetCommand;
|
|||
import com.deepclone.lw.cmd.player.planets.RenamePlanetResponse;
|
||||
import com.deepclone.lw.cmd.player.planets.ViewPlanetResponse;
|
||||
import com.deepclone.lw.interfaces.game.PlanetsManagement;
|
||||
import com.deepclone.lw.interfaces.naming.ObjectNameValidator;
|
||||
import com.deepclone.lw.interfaces.session.ServerSession;
|
||||
import com.deepclone.lw.session.Command;
|
||||
import com.deepclone.lw.session.CommandResponse;
|
||||
|
@ -24,7 +24,7 @@ public class RenamePlanetCommandDelegateBean
|
|||
{
|
||||
|
||||
private PlanetsManagement planetsManagement;
|
||||
private ObjectNameValidatorBean validator;
|
||||
private ObjectNameValidator validator;
|
||||
|
||||
|
||||
@Autowired( required = true )
|
||||
|
@ -35,7 +35,7 @@ public class RenamePlanetCommandDelegateBean
|
|||
|
||||
|
||||
@Autowired( required = true )
|
||||
public void setObjectNameValidator( ObjectNameValidatorBean validator )
|
||||
public void setObjectNameValidator( ObjectNameValidator validator )
|
||||
{
|
||||
this.validator = validator;
|
||||
}
|
||||
|
|
|
@ -4,7 +4,6 @@
|
|||
xsi:schemaLocation="
|
||||
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd">
|
||||
|
||||
<bean id="objectNameValidator" class="com.deepclone.lw.beans.user.ObjectNameValidatorBean" />
|
||||
<bean id="sessionCommandWiring" class="com.deepclone.lw.beans.user.abst.SessionCommandWiringBean" />
|
||||
<bean id="sessionSubTypeWiring" class="com.deepclone.lw.beans.user.abst.SessionSubTypeWiringBean" />
|
||||
|
||||
|
|
|
@ -0,0 +1,55 @@
|
|||
package com.deepclone.lw.interfaces.naming;
|
||||
|
||||
|
||||
import com.deepclone.lw.cmd.ObjectNameError;
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Object name validator
|
||||
*
|
||||
* <p>
|
||||
* This interface corresponds to a component which can be used to "pre-validate" the names of
|
||||
* objects (empires, map objects, fleets, etc...). It does not check for banned or duplicate names.
|
||||
*
|
||||
* @author <a href="mailto:tseeker@legacyworlds.com">E. Benoît</a>
|
||||
*/
|
||||
public interface ObjectNameValidator
|
||||
{
|
||||
|
||||
/**
|
||||
* Validate a name using the component's defaults
|
||||
*
|
||||
* <p>
|
||||
* Check the name's validity. The name must match the usual naming constraints (valid
|
||||
* characters, no sequences of white space, name starts with an alphabetic character) and its
|
||||
* length is checked against the component's default constraints.
|
||||
*
|
||||
* @param name
|
||||
* the name to validate
|
||||
*
|
||||
* @return the validation error if one occurred, or <code>null</code> if the name is valid
|
||||
*/
|
||||
public ObjectNameError validate( String name );
|
||||
|
||||
|
||||
/**
|
||||
* Validate a name using specific length constraints
|
||||
*
|
||||
* <p>
|
||||
* Check the name's validity. The name must match the usual naming constraints (valid
|
||||
* characters, no sequences of white space, name starts with an alphabetic character) and its
|
||||
* length is checked against the specific constraints given as arguments.
|
||||
*
|
||||
* @param name
|
||||
* the name to validate
|
||||
* @param minLength
|
||||
* the minimal accepted length
|
||||
* @param maxLength
|
||||
* the maximal accepted length
|
||||
*
|
||||
* @return the validation error if one occurred, or <code>null</code> if the name is valid
|
||||
*/
|
||||
public ObjectNameError validate( String name , int minLength , int maxLength );
|
||||
|
||||
}
|
|
@ -0,0 +1,249 @@
|
|||
package com.deepclone.lw.beans.naming;
|
||||
|
||||
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
import com.deepclone.lw.cmd.ObjectNameError;
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Tests for {@link ObjectNameValidatorBean}
|
||||
*
|
||||
* @author <a href="mailto:tseeker@legacyworlds.com">E. Benoît</a>
|
||||
*
|
||||
*/
|
||||
public class TestObjectNameValidatorBean
|
||||
{
|
||||
|
||||
/** Object name validator being tested */
|
||||
private ObjectNameValidatorBean validator;
|
||||
|
||||
|
||||
/**
|
||||
* Create the validator to run tests on
|
||||
*/
|
||||
@Before
|
||||
public void setUp( )
|
||||
{
|
||||
this.validator = new ObjectNameValidatorBean( );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* A string shorter than the default minimal length will cause validation to fail with the
|
||||
* {@link ObjectNameError#INVALID} error on an unmodified validator.
|
||||
*/
|
||||
@Test
|
||||
public void testDefaultMinimalLength( )
|
||||
{
|
||||
String test = "";
|
||||
for ( int i = 0 ; i < ObjectNameValidatorBean.MIN_LENGTH - 1 ; i++ ) {
|
||||
test += "x";
|
||||
}
|
||||
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.INVALID , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* A string longer than the default maximal length will cause validation to fail with the
|
||||
* {@link ObjectNameError#INVALID} error on an unmodified validator.
|
||||
*/
|
||||
@Test
|
||||
public void testDefaultMaximalLength( )
|
||||
{
|
||||
String test = "";
|
||||
for ( int i = 0 ; i < ObjectNameValidatorBean.MAX_LENGTH + 1 ; i++ ) {
|
||||
test += "x";
|
||||
}
|
||||
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.INVALID , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* A string shorter than a modified minimal length will cause validation to fail with the
|
||||
* {@link ObjectNameError#INVALID} error.
|
||||
*/
|
||||
@Test
|
||||
public void testMinimalLength( )
|
||||
{
|
||||
String test = "";
|
||||
for ( int i = 0 ; i < 3 ; i++ ) {
|
||||
test += "x";
|
||||
}
|
||||
|
||||
this.validator.setMinLength( 4 );
|
||||
this.validator.setMaxLength( 10 );
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.INVALID , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* A string longer than a modified maximal length will cause validation to fail with the
|
||||
* {@link ObjectNameError#INVALID} error on an unmodified validator.
|
||||
*/
|
||||
@Test
|
||||
public void testMaximalLength( )
|
||||
{
|
||||
String test = "";
|
||||
for ( int i = 0 ; i < 11 ; i++ ) {
|
||||
test += "x";
|
||||
}
|
||||
|
||||
this.validator.setMinLength( 4 );
|
||||
this.validator.setMaxLength( 10 );
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.INVALID , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* A string that's empty will cause an {@link ObjectNameError#EMPTY} error.
|
||||
*/
|
||||
@Test
|
||||
public void testEmptyString( )
|
||||
{
|
||||
String test = "";
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.EMPTY , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* A string that's full of spaces will cause an {@link ObjectNameError#EMPTY} error.
|
||||
*/
|
||||
@Test
|
||||
public void testSpacesOnlyString( )
|
||||
{
|
||||
String test = " ";
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.EMPTY , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* An otherwise valid string that starts with spaces will cause an
|
||||
* {@link ObjectNameError#INVALID} error.
|
||||
*/
|
||||
@Test
|
||||
public void testStringStartsWithSpace( )
|
||||
{
|
||||
String test = " abcde";
|
||||
this.validator.setMinLength( 1 );
|
||||
this.validator.setMaxLength( 10 );
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.INVALID , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* An otherwise valid string that ends with spaces will cause an {@link ObjectNameError#INVALID}
|
||||
* error.
|
||||
*/
|
||||
@Test
|
||||
public void testStringEndsWithSpace( )
|
||||
{
|
||||
String test = "abcde ";
|
||||
this.validator.setMinLength( 1 );
|
||||
this.validator.setMaxLength( 10 );
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.INVALID , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* An otherwise valid string that contains a sequence of two spaces will cause an
|
||||
* {@link ObjectNameError#INVALID} error.
|
||||
*/
|
||||
@Test
|
||||
public void testStringSpaceSequence( )
|
||||
{
|
||||
String test = "ab cde";
|
||||
this.validator.setMinLength( 1 );
|
||||
this.validator.setMaxLength( 10 );
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.INVALID , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* A string that contains an unsupported character will cause an {@link ObjectNameError#INVALID}
|
||||
* error.
|
||||
*/
|
||||
@Test
|
||||
public void testStringInvalidCharacter( )
|
||||
{
|
||||
String test = "abcdœ";
|
||||
this.validator.setMinLength( 1 );
|
||||
this.validator.setMaxLength( 10 );
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.INVALID , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* A string that does not contain any letter (but is otherwise valid) will cause an
|
||||
* {@link ObjectNameError#INVALID} error.
|
||||
*/
|
||||
@Test
|
||||
public void testStringNoLetters( )
|
||||
{
|
||||
String test = "@_@12";
|
||||
this.validator.setMinLength( 1 );
|
||||
this.validator.setMaxLength( 10 );
|
||||
ObjectNameError error = this.validator.validate( test );
|
||||
assertNotNull( error );
|
||||
assertEquals( ObjectNameError.INVALID , error );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Test validation on a "good" string
|
||||
*/
|
||||
@Test
|
||||
public void testValidString( )
|
||||
{
|
||||
this.validator.setMinLength( 1 );
|
||||
this.validator.setMaxLength( 5 );
|
||||
|
||||
ObjectNameError error = this.validator.validate( "ab12@" );
|
||||
assertNull( error );
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Test validation with call-specific length constraints
|
||||
*/
|
||||
@Test
|
||||
public void testLengthConstraints( )
|
||||
{
|
||||
this.validator.setMinLength( 5 );
|
||||
this.validator.setMaxLength( 6 );
|
||||
|
||||
ObjectNameError error = this.validator.validate( "ab" , 2 , 10 );
|
||||
assertNull( error );
|
||||
|
||||
error = this.validator.validate( "a012345678" , 2 , 10 );
|
||||
assertNull( error );
|
||||
}
|
||||
|
||||
}
|
|
@ -1,11 +1,27 @@
|
|||
package com.deepclone.lw.cmd;
|
||||
|
||||
|
||||
/**
|
||||
* The results of a name validation operation
|
||||
*
|
||||
* @author <a href="mailto:tseeker@legacyworlds.com">E. Benoît</a>
|
||||
*
|
||||
*/
|
||||
public enum ObjectNameError {
|
||||
|
||||
/** The name is empty */
|
||||
EMPTY ,
|
||||
|
||||
/** The name is used by another object (e.g. duplicate empire name) */
|
||||
UNAVAILABLE ,
|
||||
|
||||
/** The name has been banned from being used again */
|
||||
BANNED ,
|
||||
|
||||
/**
|
||||
* The name is invalid (too short, too long, sequences of white space, invalid characters, does
|
||||
* not start with a letter)
|
||||
*/
|
||||
INVALID
|
||||
|
||||
}
|
||||
|
|
Reference in a new issue