aws-samples / getting-started-with-amazon-redshift-data-api
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 44 units with 938 lines of code in units (20.8% of code).
    • 0 very long units (0 lines of code)
    • 4 long units (230 lines of code)
    • 13 medium size units (446 lines of code)
    • 12 small units (177 lines of code)
    • 15 very small units (85 lines of code)
0% | 24% | 47% | 18% | 9%
Legend:
101+
51-100
21-50
11-20
1-10
Unit Size per Extension
101+
51-100
21-50
11-20
1-10
py0% | 22% | 38% | 25% | 13%
go0% | 52% | 42% | 0% | 4%
java0% | 59% | 40% | 0% | 0%
js0% | 0% | 77% | 18% | 3%
Unit Size per Logical Component
primary logical decomposition
101+
51-100
21-50
11-20
1-10
use-cases/lambda-chaining-with-redshift-data-api0% | 28% | 29% | 35% | 6%
use-cases/aws-lambda-redshift-event-driven-etl0% | 42% | 19% | 33% | 4%
quick-start/go0% | 52% | 42% | 0% | 4%
quick-start/java0% | 59% | 40% | 0% | 0%
quick-start/typescript0% | 0% | 77% | 18% | 3%
quick-start/python0% | 0% | 100% | 0% | 0%
use-cases/etl-orchestration-with-lambda-and-step-functions0% | 0% | 54% | 0% | 45%
use-cases/ec2-redshift-access0% | 0% | 33% | 23% | 43%
Alternative Visuals
Longest Units
Top 20 longest units
Unit# linesMcCabe index# params
def handler()
in use-cases/lambda-chaining-with-redshift-data-api/scripts/LambdaRedshiftSetupObjects.py
62 2 2
def handler()
in use-cases/aws-lambda-redshift-event-driven-etl/LambdaSetupRedshiftObjects.py
58 2 2
func execute_sql_data_api()
in quick-start/go/main.go
55 14 6
private String executeSqlDataApi()
in quick-start/java/RedshiftDataAPI.java
55 11 8
var handler = function()
in quick-start/typescript/RedshiftDataAPI.js
50 17 1
var executeSynchronousWait = function()
in quick-start/typescript/RedshiftDataAPI.js
48 16 4
func HandleRequest()
in quick-start/go/main.go
45 6 2
public String handleRequest()
in quick-start/java/RedshiftDataAPI.java
38 5 2
def execute_sql_data_api()
in quick-start/python/RedShiftDataAPI.py
36 12 7
var executeSqlDataApi = function()
in quick-start/typescript/RedshiftDataAPI.js
34 7 7
def lambda_handler()
in quick-start/python/RedShiftDataAPI.py
33 9 2
def handler()
in use-cases/lambda-chaining-with-redshift-data-api/scripts/LambdaRedshiftDataApiUnload.py
32 10 2
def handler()
in use-cases/lambda-chaining-with-redshift-data-api/scripts/LambdaRedshiftDataApiETL.py
32 10 2
def handler()
in use-cases/aws-lambda-redshift-event-driven-etl/LambdaRedshiftDataApiETL.py
26 10 2
def handler()
in use-cases/etl-orchestration-with-lambda-and-step-functions/code/redshift_batch_data_api.py
26 1 2
def run_sql()
in use-cases/ec2-redshift-access/scripts/redshift-data.py
24 8 1
function step()
in quick-start/typescript/RedshiftDataAPI.js
22 32 1
def invoke_redshift_data_api_lambda()
in use-cases/aws-lambda-redshift-event-driven-etl/LambdaSetupRedshiftObjects.py
18 1 6
def invoke_redshift_data_api_lambda()
in use-cases/lambda-chaining-with-redshift-data-api/scripts/LambdaRedshiftSetupObjects.py
18 1 6
def run_concurrency_test()
in use-cases/ec2-redshift-access/scripts/redshift-concurrency-test.py
17 4 1