awslabs / aws-central-log-aggregator
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 176 units with 1,727 lines of code in units (43.8% of code).
    • 2 very long units (259 lines of code)
    • 3 long units (189 lines of code)
    • 19 medium size units (572 lines of code)
    • 16 small units (224 lines of code)
    • 136 very small units (483 lines of code)
14% | 10% | 33% | 12% | 27%
Legend:
101+
51-100
21-50
11-20
1-10
Unit Size per Extension
101+
51-100
21-50
11-20
1-10
java9% | 13% | 36% | 8% | 31%
py39% | 0% | 16% | 30% | 12%
Unit Size per Logical Component
primary logical decomposition
101+
51-100
21-50
11-20
1-10
src/main/java/com/aws/logaggregator/logparser66% | 0% | 0% | 11% | 21%
automation/lambda/handlers39% | 0% | 16% | 30% | 12%
src/main/java/com/aws/logaggregator/connector0% | 42% | 41% | 0% | 15%
src/main/java/com/aws/logaggregator/processor0% | 30% | 47% | 6% | 15%
src/main/java/com/aws/logaggregator/security0% | 0% | 53% | 29% | 17%
src/main/java/com/aws/logaggregator/utils0% | 0% | 67% | 12% | 19%
src/main/java/com/aws/logaggregator/model0% | 0% | 24% | 0% | 75%
src/main/java/com/aws/logaggregator0% | 0% | 93% | 0% | 6%
src/main/java/com/aws/logaggregator/config0% | 0% | 25% | 23% | 50%
src/main/java/com/aws/logaggregator/factory0% | 0% | 0% | 0% | 100%
src/main/java/com/aws/logaggregator/exception0% | 0% | 0% | 0% | 100%
Alternative Visuals
Longest Units
Top 20 longest units
Unit# linesMcCabe index# params
public Row call()
in src/main/java/com/aws/logaggregator/logparser/BaseLogParser.java
131 51 1
def handler()
in automation/lambda/handlers/index.py
128 32 2
protected void writeOutput()
in src/main/java/com/aws/logaggregator/processor/stream/StreamLogProcessor.java
85 17 8
public Dataset readLogData()
in src/main/java/com/aws/logaggregator/connector/KafkaConnector.java
52 7 2
public Dataset readLogData()
in src/main/java/com/aws/logaggregator/connector/KinesisConnector.java
52 7 2
public void writeLogData()
in src/main/java/com/aws/logaggregator/connector/StorageConnector.java
47 16 3
protected Dataset flattendf()
in src/main/java/com/aws/logaggregator/processor/stream/StreamLogProcessor.java
46 11 1
private DataType getDataType()
in src/main/java/com/aws/logaggregator/model/LogAppInitializer.java
44 17 2
public void startProcessing()
in src/main/java/com/aws/logaggregator/LogAggregatorMainApplication.java
40 6 1
protected void processSinks()
in src/main/java/com/aws/logaggregator/processor/BaseLogProcessor.java
36 6 2
public Dataset readLogData()
in src/main/java/com/aws/logaggregator/connector/StorageStructuredStreamConnector.java
30 8 2
public void loadSecretParam()
in src/main/java/com/aws/logaggregator/security/AWSSecretParam.java
30 12 2
private String getSecrets()
in src/main/java/com/aws/logaggregator/security/AWSSecretManagerParam.java
30 6 3
def prepare_log_config()
in automation/lambda/handlers/index.py
30 3 1
public void loadLogConfigFiles()
in src/main/java/com/aws/logaggregator/config/DynamoDBConfigHolder.java
28 6 3
public void process()
in src/main/java/com/aws/logaggregator/processor/stream/StreamLogProcessor.java
28 5 2
public List getListofFiles()
in src/main/java/com/aws/logaggregator/utils/S3Utils.java
26 7 1
public Dataset readLogData()
in src/main/java/com/aws/logaggregator/connector/StorageConnector.java
24 5 2
public void process()
in src/main/java/com/aws/logaggregator/processor/batch/BatchLogProcessor.java
24 5 2
def send()
in automation/lambda/handlers/index.py
24 3 7