首先感谢大家谁试图帮助我的:我试图验证列表与至少一个元素,如果我检查使用验证器接收空对象为什么?
Set<ConstraintViolation<Object>> constraintViolations = VALIDATOR.validate(anObj);
约束工作正常,但是当我尝试坚持,一个元素的对象再次通过和列表为空...
这是用类列表的一部分:
public class Team implements Serializable {
//...
@AtLeastOneNotNull
@ManyToMany
@JoinTable(
name="teams_players"
, joinColumns={
@JoinColumn(name="id_team")
}
, inverseJoinColumns={
@JoinColumn(name="id_player")
}
)
private List<Player> players;
//...
}
的验证:
public class AtLeastOneNotNullValidator implements ConstraintValidator<AtLeastOneNotNull, List<?>> {
@Override
public void initialize(AtLeastOneNotNull constraint) {
}
@Override
public boolean isValid(List<?> aCollection, ConstraintValidatorContext aConstraintValidatorContext) {
if(aCollection == null || aCollection.isEmpty())
return false;
else
return true;
}
}
译注:
@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Constraint(validatedBy = AtLeastOneNotNullValidator.class)
public @interface AtLeastOneNotNull {
String message() default "{[ERROR] Collection must have at least one element}";
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
}
测试类:
public class TeamDAOTest {
private static Validator VALIDATOR;
TeamTestHelper teamTestHelper = null;
TeamDAO teamDaoTest = null;
@Before
public void initTestClass() {
teamDaoTest = new TeamDAO();
teamTestHelper = new TeamTestHelper();
ValidatorFactory factory = Validation.buildDefaultValidatorFactory();
VALIDATOR = factory.getValidator();
}
@After
public void endTestClass() {
}
@Test
public void savingRightTeam() {
Team testTeam = teamTestHelper.getTeamOK();
// Set<ConstraintViolation<Team>> constraintViolations = VALIDATOR.validate(testTeam);
//
// assertEquals(0, constraintViolations.size());
//
assertEquals("Inserting right Team", true, teamDaoTest.updateEntity(testTeam));
}
@Test
public void savingWrongTeam() {
Team testTeam = teamTestHelper.getTeamKO_WithoutPlayers();
// Set<ConstraintViolation<Team>> constraintViolations = VALIDATOR.validate(testTeam);
//
// assertEquals(1, constraintViolations.size());
assertEquals("Inserting empty Team", false, teamDaoTest.updateEntity(testTeam));
}
}
最后,这是发生了什么,当我运行这个
首先,你可以请参阅使用一个元素的列表创建的团队。 注意:助手创建一个球员并坚持它,然后添加到一个球队并返回它,这是我们可以看到的团队。
第二步,当它试图坚持元素并通过验证器时,列表为空...¿为什么?
最后,当然,用一个空表,合并方法抛出一个异常:
什么可能会发生任何想法?我不知道为什么会发生这种情况,正如你所看到的,我评论了其他行,测试通过可以,但不是当我尝试更新时,它看起来是另一个对象,或者当对象再次实例化时
谢谢再次给大家
编辑:
的getPlayer()和addPlayer()在团队对象的方法:
public List<Player> getPlayers() {
if(this.players == null)
this.players = new ArrayList<Player>();
return this.players;
}
public boolean addPlayer(Player aPlayer){
if(!getPlayers().contains(aPlayer)){
this.players.add(aPlayer);
return true;
}
else return false;
}
编辑2:DAO,你可以看到,现在我并不需要更具体的方法TeamDAO
public class TeamDAO extends AbstractDAOLayer<Team> {
}
UpdateEntity方法AbstractDAOLayer
public boolean updateEntity(T anObject){
try{
this.beginTransaction();
this.entityManager.merge(anObject);
this.finishtTransaction();
return true;
}
catch(Exception e){
return false;
}
}
你可以发布TeamDAO.updateEntity的代码吗? – Franck
当然,我已经在上一版中加入了。 DAO层是一个抽象类,TeamDAO只扩展它以提供一些方法,就像你在代码中看到的一样,但是现在我没有更多的方法。在最后一张图片中,您可以看到抛出异常的方法 –