Mocking a generic RestTemplate with Mockito 2 stubs the arguments as null or an empty string
up vote
0
down vote
favorite
Here is my stubbing code. The exchange method is called with the proper parameters (shown below the stubbing code) but for some reason, the when().then()
statement is looking for null parameters. Why is the PotentialStubbingProblem
exception being thrown here?
@BeforeEach
public <T> void configureMocks() {
when(apiAccess.getKey()).thenReturn("abcdefghijklmnopqrstuvwxyz");
when(apiAccess.getUrlPrefix()).thenReturn("{region}.api.riotgames.com");
val response = new ResponseEntity<Collection<T>>(HttpStatus.OK);
when(restTemplate.exchange(ArgumentMatchers.anyString(),
ArgumentMatchers.any(HttpMethod.class),
(HttpEntity<?>) isNull(),
eq(new ParameterizedTypeReference<Collection<T>>() {})))
.thenReturn(response);
}
PotentialStubbingProblem
output is shown belown:
org.mockito.exceptions.misusing.PotentialStubbingProblem:
Strict stubbing argument mismatch. Please check:
- this invocation of 'exchange' method:
restTemplate.exchange(
https://JP1.api.riotgames.com/lol/champion-mastery/v3/champion-masteries/by-summoner/1234567890?api_key=abcdefghijklmnopqrstuvwxyz,
GET,
null,
ParameterizedTypeReference<java.util.Collection<T>>
);
-> at org.eyeoftheherald.riotapiinterface.service.RiotApiService.getEntityList(RiotApiService.java:176)
- has following stubbing(s) with different arguments:
1. restTemplate.exchange("", null, null, null);
ApiAccess
is shown below:
@Configuration
public class RiotApiInterfaceConfiguration {
@Getter
@Setter
@Configuration
@PropertySource("classpath:configuration.properties")
@ConfigurationProperties(prefix = "api-access")
public static class ApiAccess {
private String key;
private String urlPrefix;
}
@Autowired
public RiotApiInterfaceConfiguration() {
}
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
}
java spring junit mockito resttemplate
|
show 1 more comment
up vote
0
down vote
favorite
Here is my stubbing code. The exchange method is called with the proper parameters (shown below the stubbing code) but for some reason, the when().then()
statement is looking for null parameters. Why is the PotentialStubbingProblem
exception being thrown here?
@BeforeEach
public <T> void configureMocks() {
when(apiAccess.getKey()).thenReturn("abcdefghijklmnopqrstuvwxyz");
when(apiAccess.getUrlPrefix()).thenReturn("{region}.api.riotgames.com");
val response = new ResponseEntity<Collection<T>>(HttpStatus.OK);
when(restTemplate.exchange(ArgumentMatchers.anyString(),
ArgumentMatchers.any(HttpMethod.class),
(HttpEntity<?>) isNull(),
eq(new ParameterizedTypeReference<Collection<T>>() {})))
.thenReturn(response);
}
PotentialStubbingProblem
output is shown belown:
org.mockito.exceptions.misusing.PotentialStubbingProblem:
Strict stubbing argument mismatch. Please check:
- this invocation of 'exchange' method:
restTemplate.exchange(
https://JP1.api.riotgames.com/lol/champion-mastery/v3/champion-masteries/by-summoner/1234567890?api_key=abcdefghijklmnopqrstuvwxyz,
GET,
null,
ParameterizedTypeReference<java.util.Collection<T>>
);
-> at org.eyeoftheherald.riotapiinterface.service.RiotApiService.getEntityList(RiotApiService.java:176)
- has following stubbing(s) with different arguments:
1. restTemplate.exchange("", null, null, null);
ApiAccess
is shown below:
@Configuration
public class RiotApiInterfaceConfiguration {
@Getter
@Setter
@Configuration
@PropertySource("classpath:configuration.properties")
@ConfigurationProperties(prefix = "api-access")
public static class ApiAccess {
private String key;
private String urlPrefix;
}
@Autowired
public RiotApiInterfaceConfiguration() {
}
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
}
java spring junit mockito resttemplate
What is the type ofapiAccess
?
– chrylis
Nov 12 at 0:45
apiAccess
is a spring configuration class, I'll post the source in the OP
– Nuradin
Nov 12 at 1:07
Note that there is an interfaceRestOperations
that is easier to mock specifically for this case.
– chrylis
Nov 12 at 1:45
I've never seen that interface, I'll do some research on it. How would I mock out an exchange call from its implemented interface? OH kind of vital piece of information but if I haven't made it clear -- this is a unit test :)
– Nuradin
Nov 12 at 1:54
1) What do your actual invocations look like? 2) Do you have multiple stubbings defined for that method? 3) Did you meanany
instead ofeq
within the following definitioneq(new ParameterizedTypeReference<Collection<T>>() {}))
?
– Morfic
Nov 12 at 17:06
|
show 1 more comment
up vote
0
down vote
favorite
up vote
0
down vote
favorite
Here is my stubbing code. The exchange method is called with the proper parameters (shown below the stubbing code) but for some reason, the when().then()
statement is looking for null parameters. Why is the PotentialStubbingProblem
exception being thrown here?
@BeforeEach
public <T> void configureMocks() {
when(apiAccess.getKey()).thenReturn("abcdefghijklmnopqrstuvwxyz");
when(apiAccess.getUrlPrefix()).thenReturn("{region}.api.riotgames.com");
val response = new ResponseEntity<Collection<T>>(HttpStatus.OK);
when(restTemplate.exchange(ArgumentMatchers.anyString(),
ArgumentMatchers.any(HttpMethod.class),
(HttpEntity<?>) isNull(),
eq(new ParameterizedTypeReference<Collection<T>>() {})))
.thenReturn(response);
}
PotentialStubbingProblem
output is shown belown:
org.mockito.exceptions.misusing.PotentialStubbingProblem:
Strict stubbing argument mismatch. Please check:
- this invocation of 'exchange' method:
restTemplate.exchange(
https://JP1.api.riotgames.com/lol/champion-mastery/v3/champion-masteries/by-summoner/1234567890?api_key=abcdefghijklmnopqrstuvwxyz,
GET,
null,
ParameterizedTypeReference<java.util.Collection<T>>
);
-> at org.eyeoftheherald.riotapiinterface.service.RiotApiService.getEntityList(RiotApiService.java:176)
- has following stubbing(s) with different arguments:
1. restTemplate.exchange("", null, null, null);
ApiAccess
is shown below:
@Configuration
public class RiotApiInterfaceConfiguration {
@Getter
@Setter
@Configuration
@PropertySource("classpath:configuration.properties")
@ConfigurationProperties(prefix = "api-access")
public static class ApiAccess {
private String key;
private String urlPrefix;
}
@Autowired
public RiotApiInterfaceConfiguration() {
}
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
}
java spring junit mockito resttemplate
Here is my stubbing code. The exchange method is called with the proper parameters (shown below the stubbing code) but for some reason, the when().then()
statement is looking for null parameters. Why is the PotentialStubbingProblem
exception being thrown here?
@BeforeEach
public <T> void configureMocks() {
when(apiAccess.getKey()).thenReturn("abcdefghijklmnopqrstuvwxyz");
when(apiAccess.getUrlPrefix()).thenReturn("{region}.api.riotgames.com");
val response = new ResponseEntity<Collection<T>>(HttpStatus.OK);
when(restTemplate.exchange(ArgumentMatchers.anyString(),
ArgumentMatchers.any(HttpMethod.class),
(HttpEntity<?>) isNull(),
eq(new ParameterizedTypeReference<Collection<T>>() {})))
.thenReturn(response);
}
PotentialStubbingProblem
output is shown belown:
org.mockito.exceptions.misusing.PotentialStubbingProblem:
Strict stubbing argument mismatch. Please check:
- this invocation of 'exchange' method:
restTemplate.exchange(
https://JP1.api.riotgames.com/lol/champion-mastery/v3/champion-masteries/by-summoner/1234567890?api_key=abcdefghijklmnopqrstuvwxyz,
GET,
null,
ParameterizedTypeReference<java.util.Collection<T>>
);
-> at org.eyeoftheherald.riotapiinterface.service.RiotApiService.getEntityList(RiotApiService.java:176)
- has following stubbing(s) with different arguments:
1. restTemplate.exchange("", null, null, null);
ApiAccess
is shown below:
@Configuration
public class RiotApiInterfaceConfiguration {
@Getter
@Setter
@Configuration
@PropertySource("classpath:configuration.properties")
@ConfigurationProperties(prefix = "api-access")
public static class ApiAccess {
private String key;
private String urlPrefix;
}
@Autowired
public RiotApiInterfaceConfiguration() {
}
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
}
java spring junit mockito resttemplate
java spring junit mockito resttemplate
edited Nov 12 at 1:13
asked Nov 11 at 23:46
Nuradin
5719
5719
What is the type ofapiAccess
?
– chrylis
Nov 12 at 0:45
apiAccess
is a spring configuration class, I'll post the source in the OP
– Nuradin
Nov 12 at 1:07
Note that there is an interfaceRestOperations
that is easier to mock specifically for this case.
– chrylis
Nov 12 at 1:45
I've never seen that interface, I'll do some research on it. How would I mock out an exchange call from its implemented interface? OH kind of vital piece of information but if I haven't made it clear -- this is a unit test :)
– Nuradin
Nov 12 at 1:54
1) What do your actual invocations look like? 2) Do you have multiple stubbings defined for that method? 3) Did you meanany
instead ofeq
within the following definitioneq(new ParameterizedTypeReference<Collection<T>>() {}))
?
– Morfic
Nov 12 at 17:06
|
show 1 more comment
What is the type ofapiAccess
?
– chrylis
Nov 12 at 0:45
apiAccess
is a spring configuration class, I'll post the source in the OP
– Nuradin
Nov 12 at 1:07
Note that there is an interfaceRestOperations
that is easier to mock specifically for this case.
– chrylis
Nov 12 at 1:45
I've never seen that interface, I'll do some research on it. How would I mock out an exchange call from its implemented interface? OH kind of vital piece of information but if I haven't made it clear -- this is a unit test :)
– Nuradin
Nov 12 at 1:54
1) What do your actual invocations look like? 2) Do you have multiple stubbings defined for that method? 3) Did you meanany
instead ofeq
within the following definitioneq(new ParameterizedTypeReference<Collection<T>>() {}))
?
– Morfic
Nov 12 at 17:06
What is the type of
apiAccess
?– chrylis
Nov 12 at 0:45
What is the type of
apiAccess
?– chrylis
Nov 12 at 0:45
apiAccess
is a spring configuration class, I'll post the source in the OP– Nuradin
Nov 12 at 1:07
apiAccess
is a spring configuration class, I'll post the source in the OP– Nuradin
Nov 12 at 1:07
Note that there is an interface
RestOperations
that is easier to mock specifically for this case.– chrylis
Nov 12 at 1:45
Note that there is an interface
RestOperations
that is easier to mock specifically for this case.– chrylis
Nov 12 at 1:45
I've never seen that interface, I'll do some research on it. How would I mock out an exchange call from its implemented interface? OH kind of vital piece of information but if I haven't made it clear -- this is a unit test :)
– Nuradin
Nov 12 at 1:54
I've never seen that interface, I'll do some research on it. How would I mock out an exchange call from its implemented interface? OH kind of vital piece of information but if I haven't made it clear -- this is a unit test :)
– Nuradin
Nov 12 at 1:54
1) What do your actual invocations look like? 2) Do you have multiple stubbings defined for that method? 3) Did you mean
any
instead of eq
within the following definition eq(new ParameterizedTypeReference<Collection<T>>() {}))
?– Morfic
Nov 12 at 17:06
1) What do your actual invocations look like? 2) Do you have multiple stubbings defined for that method? 3) Did you mean
any
instead of eq
within the following definition eq(new ParameterizedTypeReference<Collection<T>>() {}))
?– Morfic
Nov 12 at 17:06
|
show 1 more comment
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53254395%2fmocking-a-generic-resttemplate-with-mockito-2-stubs-the-arguments-as-null-or-an%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
What is the type of
apiAccess
?– chrylis
Nov 12 at 0:45
apiAccess
is a spring configuration class, I'll post the source in the OP– Nuradin
Nov 12 at 1:07
Note that there is an interface
RestOperations
that is easier to mock specifically for this case.– chrylis
Nov 12 at 1:45
I've never seen that interface, I'll do some research on it. How would I mock out an exchange call from its implemented interface? OH kind of vital piece of information but if I haven't made it clear -- this is a unit test :)
– Nuradin
Nov 12 at 1:54
1) What do your actual invocations look like? 2) Do you have multiple stubbings defined for that method? 3) Did you mean
any
instead ofeq
within the following definitioneq(new ParameterizedTypeReference<Collection<T>>() {}))
?– Morfic
Nov 12 at 17:06