Skip to content

Commit

Permalink
HV-1596 Fix TypeVariableBindings when dealing with parent classes
Browse files Browse the repository at this point in the history
  • Loading branch information
gsmet authored and gunnarmorling committed Mar 26, 2018
1 parent 1172a02 commit 6c39dd2
Show file tree
Hide file tree
Showing 2 changed files with 70 additions and 0 deletions.
Expand Up @@ -84,6 +84,7 @@ else if ( genericSuperType instanceof ParameterizedType ) {
}
else if ( genericSuperType instanceof Class ) {
allBindings.put( (Class<?>) genericSuperType, Collections.emptyMap() );
collectTypeBindings( (Class<?>) genericSuperType, allBindings, new HashMap<>() );
}
else {
throw new IllegalArgumentException( "Unexpected type: " + genericSuperType );
Expand Down
@@ -0,0 +1,69 @@
/*
* Hibernate Validator, declare and validate application constraints
*
* License: Apache License, Version 2.0
* See the license.txt file in the root directory or <http://www.apache.org/licenses/LICENSE-2.0>.
*/
package org.hibernate.validator.test.internal.engine.valueextraction;

import static org.hibernate.validator.testutil.ConstraintViolationAssert.pathWith;
import static org.hibernate.validator.testutil.ConstraintViolationAssert.violationOf;

import java.util.Arrays;
import java.util.Iterator;
import java.util.Set;

import javax.validation.ConstraintViolation;
import javax.validation.Valid;
import javax.validation.Validator;
import javax.validation.constraints.Email;
import javax.validation.constraints.NotNull;
import javax.validation.valueextraction.Unwrapping;

import org.hibernate.validator.testutil.ConstraintViolationAssert;
import org.hibernate.validator.testutil.TestForIssue;
import org.hibernate.validator.testutils.CandidateForTck;
import org.hibernate.validator.testutils.ValidatorUtil;
import org.testng.annotations.Test;

/**
* @author Guillaume Smet
*/
@TestForIssue(jiraKey = "HV-1596")
@CandidateForTck
public class ContainerInClassHierarchyTest {

@Test
public void testContainerInHierarchy() {
Validator validator = ValidatorUtil.getValidator();

Set<ConstraintViolation<Bean>> constraintViolations = validator.validate( new Bean() );
ConstraintViolationAssert.assertThat( constraintViolations ).containsOnlyViolations(
violationOf( Email.class ).withPropertyPath(
pathWith().property( "container" ).containerElement( "<iterable element>", true, null, null, Container.class, null ) ),
violationOf( NotNull.class ).withPropertyPath(
pathWith().property( "container" ).property( "property" ) )
);
}

private static class Bean {

@Valid
@Email(payload = Unwrapping.Unwrap.class)
private Container container = new Container();
}

private static class Container extends ContainerParentClass {
}

private static class ContainerParentClass implements Iterable<String> {

@NotNull
private String property;

@Override
public Iterator<String> iterator() {
return Arrays.asList( "valid-email@example.com", "invalid-email" ).iterator();
}
}
}

0 comments on commit 6c39dd2

Please sign in to comment.