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

Add ability for jvm-dtest to grep instance logs

    XMLWordPrintableJSON

Details

    Description

      One of the main gaps between python dtest and jvm dtest is python dtest supports the ability to grep the logs of an instance; we need this capability as some tests require validating logs were triggered.

      Pydocs for common log methods

      |  grep_log(self, expr, filename='system.log', from_mark=None)
      |      Returns a list of lines matching the regular expression in parameter
      |      in the Cassandra log of this node
      |
      |  grep_log_for_errors(self, filename='system.log')
      |      Returns a list of errors with stack traces
      |      in the Cassandra log of this node
      |
      |  grep_log_for_errors_from(self, filename='system.log', seek_start=0)
      
      |  watch_log_for(self, exprs, from_mark=None, timeout=600, process=None, verbose=False, filename='system.log')
      |      Watch the log until one or more (regular) expression are found.
      |      This methods when all the expressions have been found or the method
      |      timeouts (a TimeoutError is then raised). On successful completion,
      |      a list of pair (line matched, match object) is returned.
      

      Below is a POC showing a way to do such logic

      package org.apache.cassandra.distributed.test;
      import java.io.BufferedReader;
      import java.io.FileInputStream;
      import java.io.IOException;
      import java.io.InputStreamReader;
      import java.io.UncheckedIOException;
      import java.nio.charset.StandardCharsets;
      import java.util.Iterator;
      import java.util.Spliterator;
      import java.util.Spliterators;
      import java.util.regex.Matcher;
      import java.util.regex.Pattern;
      import java.util.stream.Stream;
      import java.util.stream.StreamSupport;
      import com.google.common.io.Closeables;
      import org.junit.Test;
      import org.apache.cassandra.distributed.Cluster;
      import org.apache.cassandra.utils.AbstractIterator;
      public class AllTheLogs extends TestBaseImpl
      {
         @Test
         public void test() throws IOException
         {
             try (final Cluster cluster = init(Cluster.build(1).start()))
             {
                 String tag = System.getProperty("cassandra.testtag", "cassandra.testtag_IS_UNDEFINED");
                 String suite = System.getProperty("suitename", "suitename_IS_UNDEFINED");
                 String log = String.format("build/test/logs/%s/TEST-%s.log", tag, suite);
                 grep(log, "Enqueuing flush of tables").forEach(l -> System.out.println("I found the thing: " + l));
             }
         }
         private static Stream<String> grep(String file, String regex) throws IOException
         {
             return grep(file, Pattern.compile(regex));
         }
         private static Stream<String> grep(String file, Pattern regex) throws IOException
         {
             BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(file), StandardCharsets.UTF_8));
             Iterator<String> it = new AbstractIterator<String>()
             {
                 protected String computeNext()
                 {
                     try
                     {
                         String s;
                         while ((s = reader.readLine()) != null)
                         {
                             Matcher m = regex.matcher(s);
                             if (m.find())
                                 return s;
                         }
                         reader.close();
                         return endOfData();
                     }
                     catch (IOException e)
                     {
                         Closeables.closeQuietly(reader);
                         throw new UncheckedIOException(e);
                     }
                 }
             };
             return StreamSupport.stream(Spliterators.spliteratorUnknownSize(it, Spliterator.ORDERED), false);
         }
      }
      

      And

      @Test
         public void test() throws IOException
         {
             try (final Cluster cluster = init(Cluster.build(1).start()))
             {
                 String tag = System.getProperty("cassandra.testtag", "cassandra.testtag_IS_UNDEFINED");
                 String suite = System.getProperty("suitename", "suitename_IS_UNDEFINED");
                 //TODO missing way to get node id
      //            cluster.get(1);
                 String log = String.format("build/test/logs/%s/TEST-%s-node%d.log", tag, suite, 1);
                 grep(log, "Enqueuing flush of tables").forEach(l -> System.out.println("I found the thing: " + l));
             }
         }
      

      Attachments

        Activity

          People

            dcapwell David Capwell
            dcapwell David Capwell
            David Capwell
            Alex Petrov, Jordan West, Yifan Cai
            Votes:
            0 Vote for this issue
            Watchers:
            5 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved:

              Time Tracking

                Estimated:
                Original Estimate - Not Specified
                Not Specified
                Remaining:
                Remaining Estimate - 0h
                0h
                Logged:
                Time Spent - 3h 50m
                3h 50m