MapFieldDescription.java
/**
* Powerunit - A JDK1.8 test framework
* Copyright (C) 2014 Mathieu Boretti.
*
* This file is part of Powerunit
*
* Powerunit is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Powerunit is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Powerunit. If not, see <http://www.gnu.org/licenses/>.
*/
package ch.powerunit.extensions.matchers.provideprocessor.fields;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Optional;
import javax.lang.model.type.DeclaredType;
import ch.powerunit.extensions.matchers.provideprocessor.Matchable;
import ch.powerunit.extensions.matchers.provideprocessor.ProvidesMatchersAnnotatedElementData;
public class MapFieldDescription extends DefaultFieldDescription {
private static final String EMPTY_MATCHER = "new org.hamcrest.CustomTypeSafeMatcher<%1$s>(\"map is empty\"){ public boolean matchesSafely(%1$s o) {return o.isEmpty();}}";
private static final String SIZE_MATCHER = "new org.hamcrest.CustomTypeSafeMatcher<%1$s>(\"map size is \"+other.size()){ public boolean matchesSafely(%1$s o) {return o.size()==other.size();} protected void describeMismatchSafely(%1$s item, org.hamcrest.Description mismatchDescription) {mismatchDescription.appendText(\" was size=\").appendValue(item.size());}}";
public MapFieldDescription(ProvidesMatchersAnnotatedElementData containingElementMirror,
FieldDescriptionMirror mirror) {
super(containingElementMirror, mirror);
}
@Override
protected Collection<FieldDSLMethod> getSpecificFieldDslMethodFor() {
String fieldType = getFieldType();
final String emptyMatcher = String.format(EMPTY_MATCHER, fieldType);
Collection<FieldDSLMethod> tmp = new ArrayList<>();
tmp.add(getDslMethodBuilder().withSuffixDeclarationJavadocAndDefault("IsEmpty", "the map is empty",
emptyMatcher));
if (!"".equals(generic)) {
Object matchers[] = Optional.of(mirror.getFieldTypeMirror()).filter(m -> m instanceof DeclaredType)
.map(DeclaredType.class::cast).filter(m -> m.getTypeArguments().size() == 2)
.map(m -> m.getTypeArguments().stream().map(Object::toString)
.map(o -> Optional.ofNullable(getByName(o)).filter(Matchable::hasWithSameValue)
.map(t -> t.getWithSameValue(false)).orElse(MATCHERS + ".is"))
.toArray())
.orElseGet(()->new String[] { MATCHERS + ".is", MATCHERS + ".is" });
tmp.add(generateHasSameValue(fieldType, matchers[0].toString(), matchers[1].toString()));
}
return tmp;
}
private FieldDSLMethod generateHasSameValue(String fieldType, String keyMatcher, String keyValue) {
final String sizeMatcher = String.format(SIZE_MATCHER, fieldType);
return getDslMethodBuilder().withDeclaration("HasSameValues", fieldType + " other")
.withJavaDoc("verify that the value from the other map are exactly the once inside this map",
"other the other map")
.havingDefault(MATCHERS + ".both(" + sizeMatcher + ").and(" + MATCHERS
+ ".allOf(other.entrySet().stream().map(kv->" + MATCHERS + ".hasEntry(" + keyMatcher
+ "(kv.getKey())," + keyValue
+ "(kv.getValue()))).collect(java.util.stream.Collectors.toList())))");
}
@Override
public String getFieldCopy(String lhs, String rhs, String ignore) {
if (!"".equals(generic)) {
String fieldAccessor = getFieldAccessor();
String fieldName = getFieldName();
return "if(" + rhs + "." + fieldAccessor + "==null) {\n " + lhs + "." + fieldName + "(" + MATCHERS
+ ".nullValue());\n} else {\n " + lhs + "." + fieldName + "HasSameValues(" + rhs + "."
+ fieldAccessor + ");\n}";
}
return super.getFieldCopy(lhs, rhs, ignore);
}
}