Uploaded image for project: 'Apache Cassandra'
  1. Apache Cassandra
  2. CASSANDRA-2571

Check for null super column for SC CF in ThriftValidation (and always validate the sc key)

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Resolved
    • Normal
    • Resolution: Fixed
    • 0.7.6, 0.8.0 beta 2
    • None
    • None
    • Normal

    Description

      Run the following via cli:

      [default@test] use test;
      Authenticated to keyspace: test
      [default@test] create column family super with column_type=Super and default_validation_class=CounterColumnType;
      d41df8e0-7055-11e0-0000-242d50cf1fbf
      Waiting for schema agreement...
      ... schemas agree across the cluster
      [default@test] incr super['0']['0'];
      Value incremented.
      [default@test] incr super['0']['0']['0'];
      null
      

      Obviously the first incr call is invalid, even though it reports otherwise, as well as generates this exception:

      ERROR 17:38:05,871 Fatal exception in thread Thread[COMMIT-LOG-WRITER,5,main]
      java.lang.RuntimeException: java.lang.ClassCastException: org.apache.cassandra.db.CounterColumn cannot be cast to org.apache.cassandra.db.SuperColumn
              at org.apache.cassandra.utils.WrappedRunnable.run(WrappedRunnable.java:34)
              at java.lang.Thread.run(Thread.java:636)
      Caused by: java.lang.ClassCastException: org.apache.cassandra.db.CounterColumn cannot be cast to org.apache.cassandra.db.SuperColumn
              at org.apache.cassandra.db.SuperColumnSerializer.serialize(SuperColumn.java:353)
              at org.apache.cassandra.db.SuperColumnSerializer.serialize(SuperColumn.java:337)
              at org.apache.cassandra.db.ColumnFamilySerializer.serializeForSSTable(ColumnFamilySerializer.java:88)
              at org.apache.cassandra.db.ColumnFamilySerializer.serialize(ColumnFamilySerializer.java:74)
              at org.apache.cassandra.db.RowMutation$RowMutationSerializer.serialize(RowMutation.java:353)
              at org.apache.cassandra.db.RowMutation.getSerializedBuffer(RowMutation.java:236)
              at org.apache.cassandra.db.commitlog.CommitLogSegment.write(CommitLogSegment.java:111)
              at org.apache.cassandra.db.commitlog.CommitLog$LogRecordAdder.run(CommitLog.java:480)
              at org.apache.cassandra.db.commitlog.PeriodicCommitLogExecutorService$1.runMayThrow(PeriodicCommitLogExecutorService.java:49)
              at org.apache.cassandra.utils.WrappedRunnable.run(WrappedRunnable.java:30)
              ... 1 more
      

      But the second, proper incr call results in a bunch of exceptions and not a real increment.

      Attachments

        1. 2571.txt
          5 kB
          Jonathan Ellis
        2. 0001-Improve-ThriftValidation.patch
          8 kB
          Sylvain Lebresne

        Activity

          People

            slebresne Sylvain Lebresne
            mbulman Mike Bulman
            Sylvain Lebresne
            Jonathan Ellis
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: