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

Test Failure: test_sstablelevelreset

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Open
    • Normal
    • Resolution: Unresolved
    • 5.x
    • CI, Test/dtest/python
    • None
    • Correctness - Test Failure
    • Normal
    • Normal
    • User Report
    • All
    • None

    Description

      self = <offline_tools_test.TestOfflineTools object at 0x7fa9e4fd94f0>
      
          def test_sstablelevelreset(self):
              """
              Insert data and call sstablelevelreset on a series of
              tables. Confirm level is reset to 0 using its output.
              Test a variety of possible errors and ensure response is resonable.
              @since 2.1.5
              @jira_ticket CASSANDRA-7614
              """
              cluster = self.cluster
              cluster.populate(1).start()
              node1 = cluster.nodelist()[0]
          
              # test by trying to run on nonexistent keyspace
              cluster.stop(gently=False)
              try:
                  node1.run_sstablelevelreset("keyspace1", "standard1")
              except ToolError as e:
                  assert re.search("ColumnFamily not found: keyspace1/standard1", str(e))
                  # this should return exit code 1
                  assert e.exit_status == 1, "Expected sstablelevelreset to have a return code of 1 == but instead return code was {}".format(
                      e.exit_status)
          
              # now test by generating keyspace but not flushing sstables
              cluster.start()
              node1.stress(['write', 'n=100', 'no-warmup', '-schema', 'replication(factor=1)',
                            '-rate', 'threads=8'])
              cluster.stop(gently=False)
          
              output, error, rc = node1.run_sstablelevelreset("keyspace1", "standard1")
              self._check_stderr_error(error)
              assert re.search("Found no sstables, did you give the correct keyspace", output)
              assert rc == 0, str(rc)
          
              # test by writing small amount of data and flushing (all sstables should be level 0)
              cluster.start()
              session = self.patient_cql_connection(node1)
      >       session.execute(
                  "ALTER TABLE keyspace1.standard1 with compaction={'class': 'LeveledCompactionStrategy', 'sstable_size_in_mb':1};")
      
      offline_tools_test.py:64: 
      _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
      ../env3.8/src/cassandra-driver/cassandra/cluster.py:2618: in execute
          return self.execute_async(query, parameters, trace, custom_payload, timeout, execution_profile, paging_state, host, execute_as).result()
      _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
      
      self = <ResponseFuture: query='<SimpleStatement query="ALTER TABLE keyspace1.standard1 with compaction={'class<span class="code-quote">': 'LeveledComp...9042': 'Client request timeout. See Session.execute[_async](timeout)'}, last_host=127.0.0.1:9042 coordinator_host=None>
      
          def result(self):
              """
              Return the final result or raise an Exception if errors were
              encountered.  If the final result or error has not been set
              yet, this method will block until it is set, or the timeout
              set for the request expires.
          
              Timeout is specified in the Session request execution functions.
              If the timeout is exceeded, an :exc:`cassandra.OperationTimedOut` will be raised.
              This is a client-side timeout. For more information
              about server-side coordinator timeouts, see :class:`.policies.RetryPolicy`.
          
              Example usage::
          
                  >>> future = session.execute_async("SELECT * FROM mycf")
                  >>> # do other stuff...
          
                  >>> try:
                  ...     rows = future.result()
                  ...     for row in rows:
                  ...         ... # process results
                  ... except Exception:
                  ...     log.exception("Operation failed:")
          
              """
              self._event.wait()
              if self._final_result is not _NOT_SET:
                  return ResultSet(self, self._final_result)
              else:
      >           raise self._final_exception
      E           cassandra.OperationTimedOut: errors={'127.0.0.1:9042': 'Client request timeout. See Session.execute[_async](timeout)'}, last_host=127.0.0.1:9042
      
      ../env3.8/src/cassandra-driver/cassandra/cluster.py:4894: OperationTimedOut
      test_sstableofflinerelevel
      
      FLAKY
      offline_tools_test.TestOfflineTools
      
      test_resumable_decommission
      

      https://app.circleci.com/pipelines/github/ekaterinadimitrova2/cassandra/2680/workflows/8b1c0d0a-7458-4b43-9bba-ac96b9bfe64f/jobs/58929/tests#failed-test-0

      The failure looks different in Jenkins:
      https://ci-cassandra.apache.org/job/Cassandra-trunk/1859/testReport/junit/dtest-latest.offline_tools_test/TestOfflineTools/Tests___dtest_latest_jdk11_35_64___test_sstablelevelreset/

      Attachments

        Issue Links

          Activity

            People

              Unassigned Unassigned
              e.dimitrova Ekaterina Dimitrova
              Votes:
              0 Vote for this issue
              Watchers:
              1 Start watching this issue

              Dates

                Created:
                Updated: