Как сравнить Long и Int с assertEquals. Юнит Котлин

Как сравнить Long и Int с assertEquals с Kotlin и Junit

Например

var size: Int = 20
var totalElements: Long = 20
assertEquals(size, totalElements)

java.lang.AssertionError: expected: java.lang.Integer<20> but was: java.lang.Long<20>
Expected :java.lang.Integer<20> 
Actual   :java.lang.Long<20>
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Версия Java на основе версии загрузки
Версия Java на основе версии загрузки
Если вы зайдете на официальный сайт Spring Boot , там представлен start.spring.io , который упрощает создание проектов Spring Boot, как показано ниже.
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
0
0
743
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я думаю, вам придется преобразовать оба числа в один и тот же тип, например:

assertEquals(size.toLong(), totalElements)

Это преобразует size в Long; а totalElements уже является Long, поэтому компилятор может вывести тип Long для assertEquals(). Это немного неудобно, но компилируется и делает то, что вы хотите.

(Конечно, вы могли бы вместо этого преобразовать в Int (или другой числовой тип), но это не так хорошо, потому что он может давать ложные срабатывания, если totalElements находится за пределами диапазона Int.)

Это немного более неудобно, чем Java, потому что Kotlin более осторожен с числовыми преобразованиями, которые он выполняет; как и улучшенная проверка на null, это может выявить потенциальные ошибки, которых не будет в Java.

Как ни странно, когда я попробовал ваш код, он даже не компилировался: он терпит неудачу с ошибкой «Не удалось определить тип». (Я использую kotlinc-jvm 1.3.11.) И снова Kotlin обнаруживает проблемы во время компиляции!

Другие вопросы по теме