Gaetan Collaud created KAFKA-20693:
--------------------------------------
Summary: NPE in error handling in AbstractHerder
Key: KAFKA-20693
URL: https://issues.apache.org/jira/browse/KAFKA-20693
Project: Kafka
Issue Type: Bug
Components: connect
Affects Versions: 4.2.1
Reporter: Gaetan Collaud
When creating a connector using _PUT /connectors/abc/config_ and providing
wrong credentials for example for the Oracle database (when using
debezium-oracle) the REST endpoint returns something like this:
{code:java}
{
"error_code":500,
"message":"Cannot invoke
\"org.apache.kafka.connect.runtime.rest.entities.ConfigValueInfo.errors()\"
because the return value of
\"org.apache.kafka.connect.runtime.rest.entities.ConfigInfo.configValue()\" is
null"
} {code}
In the log, the full stack trace looks like this:
{code:java}
2026-06-15T16:05:28,860 ERROR || Uncaught exception in REST call to
/connectors/abc/config
[org.apache.kafka.connect.runtime.rest.errors.ConnectExceptionMapper]
java.lang.NullPointerException: Cannot invoke
"org.apache.kafka.connect.runtime.rest.entities.ConfigValueInfo.errors()"
because the return value of
"org.apache.kafka.connect.runtime.rest.entities.ConfigInfo.configValue()" is
null
at
org.apache.kafka.connect.runtime.AbstractHerder.maybeAddConfigErrors(AbstractHerder.java:1077)
at
org.apache.kafka.connect.runtime.distributed.DistributedHerder.lambda$doPutConnectorConfig$1(DistributedHerder.java:1144)
at
org.apache.kafka.connect.runtime.distributed.DistributedHerder.runRequest(DistributedHerder.java:2382)
at
org.apache.kafka.connect.runtime.distributed.DistributedHerder.tick(DistributedHerder.java:499)
at
org.apache.kafka.connect.runtime.distributed.DistributedHerder.run(DistributedHerder.java:384)
at
java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:572)
at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:317)
at
java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1144)
at
java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:642)
at java.base/java.lang.Thread.run(Thread.java:1583)
{code}
The actual error message (wrong credentials) can be found earlier in the log,
but the REST response is misleading and hides the root cause.
Source code causing issue:
[https://github.com/apache/kafka/blob/trunk/connect/runtime/src/main/java/org/apache/kafka/connect/runtime/AbstractHerder.java#L1077]
Apparently the configValue can be null.
Looking at github, apparently some clean-up was done in this area, maybe it's
related, maybe not: [https://github.com/apache/kafka/pull/20393]
h2. How to reproduce:
Try to create an OracleConnector with an oracle that is not reachable or with
wrong credentials.
_config-connector.json_
{code:java}
{
"connector.class": "io.debezium.connector.oracle.OracleConnector",
"tasks.max": "1",
"database.hostname": "do.not.exists",
"database.port": "3333",
"database.user": "dbz",
"database.password": "secret3",
"database.dbname": "abc",
"schema.include.list": "a",
"table.include.list": "b.c"
} {code}
{code:java}
curl -X PUT -H "Content-type: application/json" -d @config-connector.json
localhost:8083/connectors/abc/config {code}
--
This message was sent by Atlassian Jira
(v8.20.10#820010)