aws-samples / aws-glue-data-catalog-replication-utility
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 98 units with 1,655 lines of code in units (68.4% of code).
    • 0 very long units (0 lines of code)
    • 7 long units (506 lines of code)
    • 27 medium size units (788 lines of code)
    • 11 small units (170 lines of code)
    • 53 very small units (191 lines of code)
0% | 30% | 47% | 10% | 11%
Legend:
101+
51-100
21-50
11-20
1-10
Unit Size per Extension
101+
51-100
21-50
11-20
1-10
java0% | 30% | 47% | 10% | 11%
Unit Size per Logical Component
primary logical decomposition
101+
51-100
21-50
11-20
1-10
src/main/java/com/amazonaws/gdcreplication/lambda0% | 52% | 33% | 7% | 6%
src/main/java/com/amazonaws/gdcreplication/util0% | 18% | 55% | 12% | 14%
Alternative Visuals
Longest Units
Top 20 longest units
Unit# linesMcCabe index# params
public static void processSNSEvent()
in src/main/java/com/amazonaws/gdcreplication/lambda/ExportDatabaseWithTables.java
97 10 11
public String handleRequest()
in src/main/java/com/amazonaws/gdcreplication/lambda/ExportLargeTable.java
85 13 2
public TableReplicationStatus createOrUpdateTable()
in src/main/java/com/amazonaws/gdcreplication/util/GlueUtil.java
79 10 4
public boolean processsRecord()
in src/main/java/com/amazonaws/gdcreplication/lambda/ImportLargeTable.java
76 14 10
public void processTableSchema()
in src/main/java/com/amazonaws/gdcreplication/util/GDCUtil.java
66 12 10
public boolean addPartitions()
in src/main/java/com/amazonaws/gdcreplication/util/GlueUtil.java
52 9 5
public void processSNSEvent()
in src/main/java/com/amazonaws/gdcreplication/lambda/ImportDatabaseOrTable.java
51 9 11
public boolean deletePartitions()
in src/main/java/com/amazonaws/gdcreplication/util/GlueUtil.java
45 8 5
public String handleRequest()
in src/main/java/com/amazonaws/gdcreplication/lambda/DLQImportDatabaseOrTable.java
44 7 2
public String handleRequest()
in src/main/java/com/amazonaws/gdcreplication/lambda/ImportLargeTable.java
42 8 2
public void processsRecord()
in src/main/java/com/amazonaws/gdcreplication/lambda/DLQImportDatabaseOrTable.java
37 6 12
public int publishDatabaseSchemasToSNS()
in src/main/java/com/amazonaws/gdcreplication/util/SNSUtil.java
36 3 6
public void getObject()
in src/main/java/com/amazonaws/gdcreplication/util/S3Util.java
36 6 3
public boolean trackTableImportStatus()
in src/main/java/com/amazonaws/gdcreplication/util/DDBUtil.java
35 3 6
public boolean trackTableExportStatus()
in src/main/java/com/amazonaws/gdcreplication/util/DDBUtil.java
35 9 12
public String handleRequest()
in src/main/java/com/amazonaws/gdcreplication/lambda/GDCReplicationPlanner.java
32 2 2
public boolean sendTableSchemaToSQSQueue()
in src/main/java/com/amazonaws/gdcreplication/util/SQSUtil.java
30 3 5
public List getPartitionsFromS3()
in src/main/java/com/amazonaws/gdcreplication/util/S3Util.java
30 4 3
public boolean trackDatabaseExportStatus()
in src/main/java/com/amazonaws/gdcreplication/util/DDBUtil.java
29 3 8
public void processDatabseSchema()
in src/main/java/com/amazonaws/gdcreplication/util/GDCUtil.java
27 3 9