This is an automated email from the ASF dual-hosted git repository.
dcapwell pushed a commit to branch trunk
in repository https://gitbox.apache.org/repos/asf/cassandra.git
The following commit(s) were added to refs/heads/trunk by this push:
new 86e024b416 NPE when trying to use CAS on local system tables
86e024b416 is described below
commit 86e024b416fd28357b082eda6b5652f54d8e64d2
Author: David Capwell <[email protected]>
AuthorDate: Fri Jan 9 16:13:01 2026 -0800
NPE when trying to use CAS on local system tables
patch by David Capwell; reviewed by Ariel Weisberg for CASSANDRA-21112
---
.../migration/ConsensusRequestRouter.java | 2 +-
.../org/apache/cassandra/cql3/SimpleCASTest.java | 41 ++++++++++++++++++++++
2 files changed, 42 insertions(+), 1 deletion(-)
diff --git
a/src/java/org/apache/cassandra/service/consensus/migration/ConsensusRequestRouter.java
b/src/java/org/apache/cassandra/service/consensus/migration/ConsensusRequestRouter.java
index c447c7ebd9..b64f677f44 100644
---
a/src/java/org/apache/cassandra/service/consensus/migration/ConsensusRequestRouter.java
+++
b/src/java/org/apache/cassandra/service/consensus/migration/ConsensusRequestRouter.java
@@ -191,7 +191,7 @@ public class ConsensusRequestRouter
TableMetadata metadata = getTableMetadata(cm, tableId);
// Non-distributed tables always take the Paxos path
if (metadata == null)
- pickPaxos();
+ return pickPaxos();
return routeAndMaybeMigrate(cm, metadata, key, consistencyLevel,
requestTime, timeoutNanos, isForWrite);
}
diff --git a/test/unit/org/apache/cassandra/cql3/SimpleCASTest.java
b/test/unit/org/apache/cassandra/cql3/SimpleCASTest.java
new file mode 100644
index 0000000000..18e01250b9
--- /dev/null
+++ b/test/unit/org/apache/cassandra/cql3/SimpleCASTest.java
@@ -0,0 +1,41 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.apache.cassandra.cql3;
+
+import org.junit.BeforeClass;
+import org.junit.Test;
+
+public class SimpleCASTest extends CQLTester
+{
+ @BeforeClass
+ public static void setup()
+ {
+ requireNetwork();
+ }
+
+ @Test
+ public void casOnSystemTable()
+ {
+ // in CASSANDRA-21112 there was a NPE caused by a missing return.
This happened when you tried to do
+ // CAS on a local system table, the logic to figure out the protocol
is expected to choose paxos but lacked
+ // the return and instead tried to infer from TCM, but local system
tables are not in TCM and not allowed
+ // to be used in accord, so failed with a NPE.
+ executeNet("insert into system.peers(peer, data_center)
values('0.0.0.0', 'moo') if not exists");
+ }
+}
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]