awslabs / aws-cloudwatch-metrics-custom-spark-listener
Unit Size

The distribution of size of units (measured in lines of code).

Intro
  • Unit size measurements show the distribution of size of units of code (methods, functions...).
  • Units are classified in four categories based on their size (lines of code): 1-20 (small units), 20-50 (medium size units), 51-100 (long units), 101+ (very long units).
  • You should aim at keeping units small (< 20 lines). Long units may become "bloaters", code that have increased to such gargantuan proportions that they are hard to work with.
Learn more...
Unit Size Overall
  • There are 41 units with 382 lines of code in units (64.0% of code).
    • 0 very long units (0 lines of code)
    • 1 long units (65 lines of code)
    • 4 medium size units (128 lines of code)
    • 4 small units (68 lines of code)
    • 32 very small units (121 lines of code)
0% | 17% | 33% | 17% | 31%
Legend:
101+
51-100
21-50
11-20
1-10
Unit Size per Extension
101+
51-100
21-50
11-20
1-10
scala0% | 17% | 33% | 17% | 31%
Unit Size per Logical Component
primary logical decomposition
101+
51-100
21-50
11-20
1-10
src/main/scala/com/amazonaws/awslabs/kinesis-producer0% | 100% | 0% | 0% | 0%
src/main/scala/com/amazonaws/awslabs/sparkstreaming0% | 0% | 67% | 32% | 0%
src/main/scala/com/amazonaws/awslabs/utils0% | 0% | 51% | 0% | 48%
src/main/scala/com/amazonaws/awslabs/sparkstreaming/listener0% | 0% | 41% | 21% | 36%
src/main/scala/org/apache/spark/streaming/kinesis0% | 0% | 0% | 20% | 79%
Alternative Visuals
Longest Units
Top 20 longest units
Unit# linesMcCabe index# params
def main()
in src/main/scala/com/amazonaws/awslabs/kinesis-producer/ExampleKinesisProducer.scala
65 14 1
def main()
in src/main/scala/com/amazonaws/awslabs/sparkstreaming/SparkKinesisExampleWithPreferredLocation.scala
41 1 1
def main()
in src/main/scala/com/amazonaws/awslabs/sparkstreaming/SparkKinesisExample.scala
34 1 1
def pushMetric()
in src/main/scala/com/amazonaws/awslabs/utils/CloudWatchMetricsUtil.scala
28 3 5
def writeBatchStatsToCloudWatch()
in src/main/scala/com/amazonaws/awslabs/sparkstreaming/listener/CloudWatchSparkListener.scala
25 4 1
def main()
in src/main/scala/com/amazonaws/awslabs/sparkstreaming/SparkKafkaExample.scala
19 1 1
def customBuildWithMessageHandler[T: ClassTag]()
in src/main/scala/org/apache/spark/streaming/kinesis/CustomKinesisInputDStream.scala
19 1 1
def getCoreNodes()
in src/main/scala/com/amazonaws/awslabs/sparkstreaming/SparkKinesisExampleWithPreferredLocation.scala
17 1 0
def writeQueryStatsToCloudWatch()
in src/main/scala/com/amazonaws/awslabs/sparkstreaming/listener/CloudWatchQueryListener.scala
13 4 1
override def getReceiver()
in src/main/scala/org/apache/spark/streaming/kinesis/CustomKinesisInputDStream.scala
6 1 0
def parseJsonWithJackson()
in src/main/scala/com/amazonaws/awslabs/utils/CloudWatchMetricsUtil.scala
5 1 1
override def onQueryStarted()
in src/main/scala/com/amazonaws/awslabs/sparkstreaming/listener/CloudWatchQueryListener.scala
4 1 1
override def onQueryProgress()
in src/main/scala/com/amazonaws/awslabs/sparkstreaming/listener/CloudWatchQueryListener.scala
4 1 1
override def onBatchCompleted()
in src/main/scala/com/amazonaws/awslabs/sparkstreaming/listener/CloudWatchSparkListener.scala
4 1 1
override def onReceiverError()
in src/main/scala/com/amazonaws/awslabs/sparkstreaming/listener/CloudWatchSparkListener.scala
4 1 1
def withPreferredLocation()
in src/main/scala/org/apache/spark/streaming/kinesis/CustomKinesisInputDStream.scala
4 1 1
override def streamingContext()
in src/main/scala/org/apache/spark/streaming/kinesis/CustomKinesisInputDStream.scala
4 1 1
override def streamingContext()
in src/main/scala/org/apache/spark/streaming/kinesis/CustomKinesisInputDStream.scala
4 1 1
override def streamName()
in src/main/scala/org/apache/spark/streaming/kinesis/CustomKinesisInputDStream.scala
4 1 1
override def checkpointAppName()
in src/main/scala/org/apache/spark/streaming/kinesis/CustomKinesisInputDStream.scala
4 1 1