- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在我的应用程序中使用公共(public) API Nutritionix 从他们的数据库中获取有关食品成分的详细信息。我想测试一种方法,该方法向公共(public) API 发送 POST 请求以接收有关产品营养值(value)的详细信息,然后在我的应用程序的下一个过程中使用它们。
我的测试类看起来像:
@ExtendWith(MockitoExtension.class)
class CaloriesServiceTest {
@InjectMocks
private CaloriesService caloriesService;
@Mock
private RestTemplate restTemplate;
@Mock
private NutritionixHeader nutritionixHeader;
@BeforeEach
void setUp() {
caloriesService = new CaloriesService(nutritionixHeader, restTemplate);
}
@Test
void receiveNutritionInformationFromAPI() {
given(nutritionixHeader.getNutritionixAppId()).willReturn("secretID");
given(nutritionixHeader.getNutritionixAppKey()).willReturn("secretKey");
var meal1 = Meal.builder()
.mealIngredients(List.of(RecipeIngredient.builder()
.foodName("grilled fish")
.build()))
.build();
var meal2 = Meal.builder()
.mealIngredients(List.of(RecipeIngredient.builder()
.foodName("eggs")
.build()))
.build();
var meal3 = Meal.builder()
.mealIngredients(List.of(RecipeIngredient.builder()
.foodName("bacon")
.build()))
.build();
var dailyMeals = DailyMeals.builder().dailyMeals(List.of(meal1, meal2, meal3)).build();
var foodNutritional1 = FoodNutritional.builder().foodName("food name1").calories(11.1).build();
var foodNutritional2 = FoodNutritional.builder().foodName("food name2").calories(22.2).build();
var foodNutritional3 = FoodNutritional.builder().foodName("food name3").calories(33.3).build();
var foodNutritional4 = FoodNutritional.builder().foodName("food name4").calories(44.4).build();
HttpEntity<NutrientsBodyForRequest> requestBody =
new HttpEntity<>(NutrientsBodyForRequest.builder()
.query("grilled fish | eggs | bacon | burger")
.build());
given(restTemplate
.exchange("https://trackapi.nutritionix.com/v2/natural/nutrients",
HttpMethod.POST,
requestBody,
new ParameterizedTypeReference<List<FoodNutritional>>() {
}))
.willReturn(
new ResponseEntity<List<FoodNutritional>>(
List.of(
foodNutritional1,
foodNutritional2,
foodNutritional3,
foodNutritional4),
HttpStatus.OK));
//when
List<FoodNutritional> foodsNutritional =
caloriesService.receiveNutritionInformationFromAPI(dailyMeals);
assertThat(foodsNutritional.get(0).getBrandName(), is("grilled fish"));
assertEquals(3, foodsNutritional.size());
}
}
不幸的是,当我运行上面的测试时,我收到了如下异常:
org.mockito.exceptions.misusing.PotentialStubbingProblem:
Strict stubbing argument mismatch. Please check:
- this invocation of 'exchange' method:
restTemplate.exchange(
"https://trackapi.nutritionix.com/v2/natural/nutrients",
POST,
<com.application.meal.NutrientsBodyForRequest@3c486eb1,[]>,
ParameterizedTypeReference<java.util.List<com.application.meal.FoodNutritional>>
);
-> at com.application.meal.CaloriesService.receiveNutritionInformationFromAPI(CaloriesService.java:45)
- has following stubbing(s) with different arguments:
1. restTemplate.exchange(
"https://trackapi.nutritionix.com/v2/natural/nutrients",
POST,
<com.application.meal.NutrientsBodyForRequest@afd496eb,[]>,
ParameterizedTypeReference<java.util.List<com.application.meal.FoodNutritional>>
);
-> at com.application.meal.CaloriesServiceTest.receiveNutritionInformationFromAPI(CaloriesServiceTest.java:69)
Typically, stubbing argument mismatch indicates user mistake when writing tests.
Mockito fails early so that you can debug potential problem easily.
我的服务看起来像:
@Service
public class CaloriesService {
private NutritionixHeader nutritionHeaderParam;
private RestTemplate restTemplate;
public CaloriesService(NutritionixHeader nutritionHeaderParam,
RestTemplate restTemplate) {
this.nutritionHeaderParam = nutritionHeaderParam;
this.restTemplate = restTemplate;
}
private String prepareFoodNamesForRequest(DailyMeals dailyMeals) {
return dailyMeals.getDailyMeals()
.stream()
.map(Meal::getMealIngredients)
.flatMap(Collection::stream)
.map(RecipeIngredient::getFoodName)
.collect(Collectors.joining(" | "));
}
public List<FoodNutritional> receiveNutritionInformationFromAPI(DailyMeals dailyMeals) {
String foodNamesForRequest = prepareFoodNamesForRequest(dailyMeals);
HttpHeaders headers = new HttpHeaders();
headers.set("x-app-id", nutritionHeaderParam.getNutritionixAppId());
headers.set("x-app-key", nutritionHeaderParam.getNutritionixAppKey());
HttpEntity<NutrientsBodyForRequest> request =
new HttpEntity<>(NutrientsBodyForRequest.builder()
.query(foodNamesForRequest)
.build(), headers);
ResponseEntity<List<FoodNutritional>> response =
restTemplate
.exchange(
"https://trackapi.nutritionix.com/v2/natural/nutrients",
HttpMethod.POST,
request,
new ParameterizedTypeReference<List<FoodNutritional>>() {
});
return response.getBody();
}
}
我的组件类如下:
DailyMeals.class
@Getter
@AllArgsConstructor
@EqualsAndHashCode
@Builder
class DailyMeals {
@Id
private Long id;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "dailyMeals")
List<Meal> dailyMeals;
}
FoodNutritional.class
@JsonInclude(JsonInclude.Include.NON_NULL)
@JsonIgnoreProperties(ignoreUnknown = true)
@Getter
@Setter
@Builder
@NoArgsConstructor
@AllArgsConstructor
@EqualsAndHashCode
public class FoodNutritional {
@JsonProperty("food_name")
private String foodName;
@JsonProperty("brand_name")
private String brandName;
@JsonProperty("serving_qty")
private Integer servingQuantity;
@JsonProperty("serving_unit")
private String servingUnit;
@JsonProperty("serving_weight_grams")
private String servingWeightGrams;
@JsonProperty("nf_calories")
private Double calories;
@JsonProperty("nf_total_fat")
private Double totalFat;
@JsonProperty("nf_saturated_fat")
private Double saturatedFat;
@JsonProperty("nf_cholesterol")
private Double cholesterol;
@JsonProperty("nf_sodium")
private Double sodium;
@JsonProperty("nf_total_carbohydrate")
private Double totalCarbohydrate;
@JsonProperty("nf_dietary_fiber")
private Double dietaryFiber;
@JsonProperty("nf_sugars")
private Double sugars;
@JsonProperty("nf_protein")
private Double protein;
@JsonProperty("nf_potassium")
private Double potassium;
}
膳食类
@AllArgsConstructor
@EqualsAndHashCode
@Getter
@Builder
@Entity
public class Meal {
@Id
@GeneratedValue
private Long id;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "meal")
List<RecipeIngredient> mealIngredients;
}
编辑:
对于 @Abhiram
我正在附加并且 IntelliJ 提示你建议的代码段
Edit2:经过深思熟虑,我认为我作为主体传递的对象的不同 HashCode 存在问题:NutrientsBodyForRequest@3c486eb1,[]
和 NutrientsBodyForRequest@ afd496eb,[]
,如果这可能是问题的根源,有什么建议吗?
我想要实现的是修复此错误并检查模拟服务是否会返回所需结果的测试。我将不胜感激关于如何达到目标的建议。
最佳答案
幸运的是,在与@Abhiram
合作后,我找到了解决方案。
我的 mock 中缺少参数的 ArgumentMatcher
。
given(restTemplate
.exchange(eq("https://trackapi.nutritionix.com/v2/natural/nutrients"),
ArgumentMatchers.eq(HttpMethod.POST),
ArgumentMatchers.any(),
ArgumentMatchers.<ParameterizedTypeReference<List<FoodNutritional>>>any()))
.willReturn(
new ResponseEntity<List<FoodNutritional>>(
foodsNutritionalStabData(),
HttpStatus.OK));
下面的方法解决了一个问题。非常感谢您的 promise 。
关于java - 获取 org.mockito.exceptions.misusing.PotentialStubbingProblem : Strict stubbing argument mismatch,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58180426/
这个问题在这里已经有了答案: Python try...except comma vs 'as' in except (5 个回答) 关闭7年前。 在python中,有两种方法可以捕获异常 excep
在 Java 中,我有一个从 Exception 扩展的异常类,但是每当我抛出它时,编译器都会说它需要被捕获/必须声明方法 throws异常。 当我使用从 Exception 扩展的 RuntimeE
我有一组用户、组以及用户和组之间的映射。我有各种操作这些集合的函数,但是不能为不存在的用户添加用户组映射,也不能删除仍然有用户作为成员的组等。 所以基本上我希望这些函数抛出必须由调用者明确处理的“异常
我正在尝试使用上载控件上载20兆的文件,并且在Visual Studio的内置Web服务器上可以正常工作,但是一旦将其发布到生产服务器(我无权访问),我总是收到以下错误消息: Server Error
我想断言运行某些代码时会引发特定异常(SSLHandshakeException)。 assertThatThrownBy(() -> { // some code }).is
这个问题我暂时解决不了。我很乐意提供一些建议。 当我尝试抛出异常时(我自己创建了一个 Java 风格的异常) throw Exception (); 编译器提出抗议: DataTypes/Date.c
我有以下文件: from fabric.api import env, execute, run env.hosts = ['1.2.3.4'] def taskA(): run('ls')
我正在阅读一些包含类似于以下功能的源代码: def dummy_function(): try: g = 1/0 except Exception as e:
根据标准 ML 的定义(修订版): The idea is that dynamic evaluation of a non-expansive expression will neither gen
当 GHCi 在运行时发现调用产生的值与函数的模式匹配不匹配时,有没有办法让 GHCi 产生更好的异常消息? 它目前给出了产生非详尽模式匹配的函数的行号,虽然有时会有所帮助,但确实需要一轮调试,有时我
我有一个最佳实践问题。我意识到这是主观的,但想问问比我更聪明的人,这是否是一种常见的编程实践。 如果您有一种不希望干扰应用程序重要功能的非关键方法,那么使用这样的错误接收器是否常见? Try
在编程中,异常是否总是错误(被零除,访问冲突等等)? 如果不是,您能否提供不是错误的异常示例? 谢谢。 最佳答案 异常通常用于管理错误,它们使错误处理更加容易,但它们并不总是错误。 任何需要单独代码路
我很想知道 OCaml 运行时如何处理异常以使它们如此轻量。他们是使用 setjmp/longjmp 还是在每个函数中返回一个特殊值并传播它? 在我看来,longjmp会给系统带来一点压力,但只有在引
在我的 C# 代码中,我可以访问 MyNamespace.Exception 以及 System.Exception。当我想捕获其中一个异常时,理想情况下我会完全限定要捕获的异常或使用别名来明确说明。
我正在使用 Visual C++ 2005 Express Edition 并遇到以下链接器错误: 19>mylib1.lib(mylibsource1.obj) : error LNK2019: u
这个问题在这里已经有了答案: Is there "Break on Exception" in IntelliJ? (6 个回答) 关闭7年前。 我想在调试器中运行我的测试套件并中断任何意外异常,但是
Like in this picture 我知道它们都可以正常工作,但我只是想知道它们之间有何不同? PS:我是初学者。 最佳答案 A LogEvent可以同时包含消息和异常。如果您使用第一种形式:
我知道避免 Doctrine 上的异常似乎是一种奇怪的行为,但我需要这样做,因为我在一个旧项目中工作,过去有人执行了一些迁移,然后他决定删除它,所以现在复制起来很复杂本地生产环境没有崩溃,这就是为什么
我想创建一个名为 SecurityException 的新异常。 我应该把代码放在哪里? class SecurityException extends CakeException {}; 谢谢! 最
我一直在使用throw new Exception("...")在我的代码中,因为我找不到其他可以使用的东西。我正在寻找像 C++'s 这样的东西 out_of_range 和 logic_error
我是一名优秀的程序员,十分优秀!