1

首先感谢大家谁试图帮助我的:我试图验证列表与至少一个元素,如果我检查使用验证器接收空对象为什么?

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)); 
} 

}

最后,这是发生了什么,当我运行这个

首先,你可以请参阅使用一个元素的列表创建的团队。 注意:助手创建一个球员并坚持它,然后添加到一个球队并返回它,这是我们可以看到的团队。 enter image description here

第二步,当它试图坚持元素并通过验证器时,列表为空...¿为什么?

enter image description here

最后,当然,用一个空表,合并方法抛出一个异常:

enter image description here

什么可能会发生任何想法?我不知道为什么会发生这种情况,正如你所看到的,我评论了其他行,测试通过可以,但不是当我尝试更新时,它看起来是另一个对象,或者当对象再次实例化时

谢谢再次给大家


编辑:

的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; 
    } 
} 
+0

你可以发布TeamDAO.updateEntity的代码吗? – Franck

+0

当然,我已经在上一版中加入了。 DAO层是一个抽象类,TeamDAO只扩展它以提供一些方法,就像你在代码中看到的一样,但是现在我没有更多的方法。在最后一张图片中,您可以看到抛出异常的方法 –

回答

1

请检查this 。这个问题与BV无关,而与jpa合并语义和多对多关系有关。

+0

谢谢,你说得对,现在它正在工作 http://stackoverflow.com/questions/1069992/jpa-entitymanager-why-use-persist-over-merge ?LQ = 1 –

相关问题