ch.powerunit.extensions.matchers.provideprocessor.fields.CollectionFieldDescription Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of powerunit-extensions-matchers-factory Show documentation
Show all versions of powerunit-extensions-matchers-factory Show documentation
This is a test framework for the JDK 1.8 - Extension to provide matchers based on annotation. - Factory Support
/**
* 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 .
*/
package ch.powerunit.extensions.matchers.provideprocessor.fields;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;
import java.util.Optional;
import ch.powerunit.extensions.matchers.provideprocessor.ProvidesMatchersAnnotatedElementData;
import ch.powerunit.extensions.matchers.provideprocessor.RoundMirror;
import ch.powerunit.extensions.matchers.provideprocessor.RoundMirrorSupport;
public class CollectionFieldDescription extends DefaultFieldDescription implements RoundMirrorSupport {
private static final String DEFAULT_JAVADOC_MATCHER_ON_ELEMENTS = "matchersOnElements the matchers on the elements";
private final RoundMirror roundMirror;
public CollectionFieldDescription(ProvidesMatchersAnnotatedElementData containingElementMirror,
FieldDescriptionMirror mirror) {
super(containingElementMirror, mirror);
roundMirror = containingElementMirror.getRoundMirror();
}
@Override
protected Collection getSpecificFieldDslMethodFor() {
List tmp = new ArrayList<>(getFieldDslMethodForIterableAndComparable());
if (!"".equals(generic)) {
tmp.addAll(getDslForIterableWithGeneric());
}
return tmp;
}
public List getFieldDslMethodForIterableAndComparable() {
return Arrays.asList(
getDslMethodBuilder().withSuffixDeclarationJavadocAndDefault("IsEmptyIterable",
"that the iterable is empty", "(org.hamcrest.Matcher)" + MATCHERS + ".emptyIterable()"),
getDslMethodBuilder().withSuffixDeclarationJavadocAndDefault("IsEmpty", "that the collection is empty",
"(org.hamcrest.Matcher)" + MATCHERS + ".empty()"));
}
public List getDslForIterableWithGeneric() {
String tgeneric = this.generic;
String genericmatcher = "org.hamcrest.Matcher<" + tgeneric + ">";
return Arrays.asList(
getDslMethodBuilder().withDeclaration("Contains", tgeneric + "... elements")
.withJavaDoc("that the iterable contains the received elements", "elements the elements",
MATCHERS + "#contains(java.lang.Object[])")
.havingDefault(MATCHERS + ".contains(elements)"),
getDslMethodBuilder().withDeclaration("Contains", genericmatcher + "... matchersOnElements")
.withJavaDoc("that the iterable contains the received elements, using matchers",
DEFAULT_JAVADOC_MATCHER_ON_ELEMENTS, MATCHERS + "#contains(org.hamcrest.Matcher[])")
.havingDefault(MATCHERS + ".contains(matchersOnElements)"),
getDslMethodBuilder().withDeclaration("ContainsInAnyOrder", tgeneric + "... elements")
.withJavaDoc("that the iterable contains the received elements in any order",
"elements the elements", MATCHERS + "#containsInAnyOrder(java.lang.Object[])")
.havingDefault(MATCHERS + ".containsInAnyOrder(elements)"),
getDslMethodBuilder().withDeclaration("ContainsInAnyOrder", genericmatcher + "... matchersOnElements")
.withJavaDoc("that the iterable contains the received elements, using matchers in any order",
DEFAULT_JAVADOC_MATCHER_ON_ELEMENTS,
MATCHERS + "#containsInAnyOrder(org.hamcrest.Matcher[])")
.havingDefault(MATCHERS + ".containsInAnyOrder(matchersOnElements)"),
getDslMethodBuilder()
.withDeclaration("Contains",
"java.util.List> matchersOnElements")
.withJavaDoc("that the iterable contains the received elements, using list of matcher",
DEFAULT_JAVADOC_MATCHER_ON_ELEMENTS, MATCHERS + "#contains(java.util.List)")
.havingDefault(MATCHERS + ".contains(matchersOnElements)"));
}
@Override
public String getFieldCopy(String lhs, String rhs) {
if (!"".equals(generic)) {
return getFieldCopyForList(lhs, rhs);
}
return super.getFieldCopy(lhs, rhs);
}
public String getFieldCopyForList(String lhs, String rhs) {
String fieldAccessor = getFieldAccessor();
String fieldName = getFieldName();
return "if(" + rhs + "." + fieldAccessor + "==null) {" + lhs + "." + fieldName + "(" + MATCHERS
+ ".nullValue()); } else if (" + rhs + "." + fieldAccessor + ".isEmpty()) {" + lhs + "." + fieldName
+ "IsEmptyIterable(); } else {" + lhs + "." + fieldName + "Contains(" + rhs + "." + fieldAccessor
+ ".stream().map(" + generateMatcherBuilderReferenceFor(generic)
+ ").collect(java.util.stream.Collectors.toList())); }";
}
public String generateMatcherBuilderReferenceFor(String generic) {
return Optional.ofNullable(getByName(generic)).map(
t -> t.getFullyQualifiedNameOfGeneratedClass() + "::" + t.getMethodShortClassName() + "WithSameValue")
.orElse(MATCHERS + "::is");
}
@Override
public RoundMirror getRoundMirror() {
return roundMirror;
}
}