Недавно у нас возникла проблема с настройкой Java в моей компании: мы очистили некоторые зависимости и подумали, что все в порядке, потому что она все еще компилируется. Однако мы обнаружили, что зависимости, кэшированные в репозитории .m2, заставляли IntelliJ и Maven полагать, что у нас все еще есть отсутствующая зависимость. Это происходило как на наших локальных машинах, так и на производственной установке.
Проблема проявлялась в виде совершенно бесшумного исключения ClassNotFoundException. Ничего не было зарегистрировано, и нам пришлось отлаживать приложение построчно, чтобы найти точное место, где это произошло.
Он не был заключен в try-catch, который отбрасывал бы исключение, он просто молча провалил метод, который вызывался в цикле и переходил к следующей итерации.
Для меня уже загадка, как это могло произойти.
Если быть более конкретным, то это было зависимость org.apache.commons commons-lang3 3.9 отсутствовала, и в этой конкретной строке кода произошел сбой
Код: Выделить всё
if (SystemUtils.IS_OS_LINUX) {
Мы пытались удалить кеш .m2, но commons-lang3 является транзитивной зависимостью, поэтому она все равно загружается при сборке.
По моему мнению, невозможно скомпилировать проект с отсутствующими зависимостями в POM, даже если они кэшируются. Это должно привести к ошибке компиляции.
Есть ли способ добиться этого?
Подробнее здесь: https://stackoverflow.com/questions/786 ... -classpath