aws-samples / amazon-kinesis-timestream-grafana
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 67 units with 795 lines of code in units (56.7% of code).
    • 0 very long units (0 lines of code)
    • 3 long units (229 lines of code)
    • 4 medium size units (108 lines of code)
    • 17 small units (251 lines of code)
    • 43 very small units (207 lines of code)
0% | 28% | 13% | 31% | 26%
Legend:
101+
51-100
21-50
11-20
1-10
Unit Size per Extension
101+
51-100
21-50
11-20
1-10
py0% | 64% | 13% | 16% | 5%
java0% | 0% | 10% | 40% | 49%
kt0% | 0% | 21% | 51% | 27%
Unit Size per Logical Component
primary logical decomposition
101+
51-100
21-50
11-20
1-10
cdk/stacks/kinesis0% | 88% | 0% | 0% | 11%
cdk/stacks/grafana0% | 78% | 21% | 0% | 0%
analytics/src/main/java/com/amazonaws0% | 0% | 10% | 40% | 49%
analytics-kotlin/src/main/kotlin/services/kinesisanalytics0% | 0% | 42% | 43% | 13%
cdk/stacks0% | 0% | 84% | 0% | 16%
cdk/stacks/sample_kinesis_stream_producer/producer_lambda0% | 0% | 0% | 100% | 0%
analytics-kotlin/src/main/kotlin/services/timestream0% | 0% | 0% | 59% | 40%
cdk/stacks/sample_kinesis_stream_producer0% | 0% | 0% | 100% | 0%
Alternative Visuals
Longest Units
Top 20 longest units
Unit# linesMcCabe index# params
def __init__()
in cdk/stacks/grafana/grafana_stack.py
99 1 6
def __init__()
in cdk/stacks/kinesis/amazon_kinesis_analytics_stack.py
71 1 11
def __init__()
in cdk/stacks/kinesis/amazon_kinesis_analytics_source_stack.py
59 1 8
public Collection map()
in analytics/src/main/java/com/amazonaws/services/kinesisanalytics/operators/JsonToTimestreamPayloadFn.java
32 5 1
override fun map()
in analytics-kotlin/src/main/kotlin/services/kinesisanalytics/operators/JsonToTimestreamPayloadFn.kt
28 5 1
def grant_timestream_read()
in cdk/stacks/grafana/grafana_stack.py
27 1 4
def __init__()
in cdk/stacks/amazon_timestream_stack.py
21 1 4
private void writeBatch()
in analytics/src/main/java/com/amazonaws/services/timestream/TimestreamSink.java
20 4 1
public static DataStream createKinesisSource()
in analytics/src/main/java/com/amazonaws/services/kinesisanalytics/StreamingJob.java
20 2 2
public static void main()
in analytics/src/main/java/com/amazonaws/services/kinesisanalytics/StreamingJob.java
19 1 1
def write_records()
in cdk/stacks/sample_kinesis_stream_producer/producer_lambda/app.py
19 4 2
fun main()
in analytics-kotlin/src/main/kotlin/services/kinesisanalytics/StreamingJob.kt
17 1 1
public void createTable()
in analytics/src/main/java/com/amazonaws/services/timestream/TimestreamInitializer.java
16 2 2
fun createTable()
in analytics-kotlin/src/main/kotlin/services/timestream/TimestreamInitializer.kt
16 2 2
private Collection createRecords()
in analytics/src/main/java/com/amazonaws/services/timestream/TimestreamSink.java
15 1 1
def prepare_record()
in cdk/stacks/sample_kinesis_stream_producer/producer_lambda/app.py
15 4 3
def __init__()
in cdk/stacks/sample_kinesis_stream_producer/sample_kinesis_stream_producer_stack.py
14 1 5
public void open()
in analytics/src/main/java/com/amazonaws/services/timestream/TimestreamSink.java
12 1 1
override fun open()
in analytics-kotlin/src/main/kotlin/services/timestream/TimestreamSink.kt
12 1 1
override fun processElement()
in analytics-kotlin/src/main/kotlin/services/kinesisanalytics/operators/OffsetFutureTimestreamPoints.kt
12 1 3