assertEquals(def.getMengs(), exp.getMengs());
échoue, les rapports: prévu: java.util.HashSet < [... donc mourir geht Legende ... ... la légende ...]> mais était: java.util.HashSet < [ ... donc la légende l'a ...]>Pourquoi ma méthode equals ne fonctionne pas?
En effet, à travers le débogueur, je vois que les deux ensembles ne contiennent qu'une signification avec objId = 1 pour les deux. Je m'attendais le code suivant dans la classe Signification (@Entity) pour garantir que ce qui précède fonctionne.
@Override
public boolean equals(Object object) {
if (!(object instanceof Meaning)) {
return false;
}
Meaning other = (Meaning) object;
if (other != null && objId == other.objId) return true;
return false;
}
@Override
public int hashCode() {
int hash = 7;
hash = 67 * hash + this.objId;
return hash;
}
En effet, ce test passe:
db.insert(admin);
final Meaning meng = new Meaning(admin, new Expression("essen"));
meng.setObjId(11);
final Meaning meng1 = new Meaning(admin, new Expression("mangiare"));
meng1.setObjId(11);
assertEquals(meng,meng1);
Alors, quel pourrait être mon problème? Thery sont tous deux des HashSets, ils sont tous deux de la même taille, et les objets qu'ils contiennent sont égaux. En effet
assertEquals(def.getMengs().iterator().next(), exp.getMengs().iterator().next());
avant qu'il ne passe. Toutefois, ce ne sera pas (mais je ne sais pas pourquoi):
assertTrue(def.getMengs().containsAll(exp.getMengs()));
Ainsi, il est le problème.
est ici le code de test:
try{
db.insertWords(toEnumMap(mengs[i],admin));
}catch(Exception e){
fail(e.getMessage());
}
final Expression exp = db.get(Expression.class, mengs[i][0]);
testGender(exp, mengs[i][2]);
final Expression def = db.get(Expression.class, mengs[i][1]);
assertNotNull(def);
assertEquals(def.getMengs().iterator().next(), exp.getMengs().iterator().next());
assertEquals(exp.getMengs().size(), def.getMengs().size());
assertTrue(def.getMengs().containsAll(def.getMengs()));
assertTrue(def.getMengs().containsAll(exp.getMengs()));
assertEquals(def.getMengs(), exp.getMengs());
db.get enveloppe juste em.find. InsertWords devrait persister def et exp.
public void insertWords(EnumMap<Input, MemoEntity> input) throws MultipleMengsException {
insert(input.get(Input.expression)); //INSERT OR IGNORE
final boolean isNewDef = insert(input.get(Input.definition));
final Expression def = get(Expression.class, input.get(Input.definition).getId());
final Expression exp = get(Expression.class, input.get(Input.expression).getId());
final MUser usr = get(MUser.class, input.get(Input.user).getId());
final Set<Meaning> mengs = getMengs(usr,def,isNewDef);
if (mengs == null) {//is new to the user
final Meaning meng = new Meaning(usr, exp, def);
insert(meng);
} else { //old meaning
if (mengs.size() > 1) throw new MultipleMengsException(mengs);
else{
final Meaning meng = mengs.iterator().next();
meng.addExp(exp);
meng.setLastPublishedDate(null); //reschedule
}
}
Logger.getAnonymousLogger().log(Level.INFO, "inserted pair <{0},{1}>", new String[]{exp.getExpression(), def.getExpression()});
}
public boolean insert(final MemoEntity entity) {
if (em.find(entity.getClass(), entity.getId()) == null) {
et.begin();
em.persist(entity);
et.commit();
return true;
}
return false;
}
public <MemoEntity> MemoEntity get(final Class<MemoEntity> entityClass, final Object primaryKey) {
return em.find(entityClass, primaryKey);
}
'int hash = 7; hash = 67 * hash' ??? Pourquoi pas 'int hash = 469 + obj.Id'? Ou juste 'return obj.Id'? Ajouter une constante au hashcode est inutile, – NullUserException
@NullUserException: 'return 4;' est la bonne variante! – Roman