awslabs / scale-out-computing-on-aws
Components & Dependencies

An overview of source code logical components.

Intro

Logical decomposition is a representation of the organization of the main source code, where every and each file is put in exactly one logical component.

  • A software system can have one or more logical decompositions.
  • A logical decomposition can be defined in two ways in Sokrates.
  • First approach is based on the folders structure. Components are mapped to folders at defined folder depth relative to the source code root.
  • Second approach is based on explicit definition of each component. In such explicit definitions, components are explicitly named and their files are selected based on explicitly defined path and content filters.
  • A logical decomposition is considered invalid if a file is selected into two or more components.This constraint is introduced in order to facilitate measuring of dependencies among components.
  • Files not assigned to any component are put into a special "Unclassified" component.
Learn more...
Logical Decompositions Overview

Analyzed system has 1 logical decomposition:

  • primary (23 components)

Logical Decomposition #1: PRIMARY

The decompositions is based on the folder structure (relative to the source code root), with automatically defined folder depth to have at least 10 components.

Bubble Chart | Tree Map
Components
The "primary" logical decomposition has 23 components.
  • 149 files, 33,017 lines of code (100.0% vs. main code).
  • "source/soca/cluster_web_ui/static" is biggest, containing 43.76% of code.
  • "source/soca/cluster_manager/settings" is smallest, containing 0.03% of code.


source/soca/cluster_web_ui/static14449 LOC (43%) 6 files
source/soca/cluster_web_ui/templates5306 LOC (16%) 30 files
source/soca/cluster_web_ui/api3349 LOC (10%) 42 files
source/soca/cluster_manager2850 LOC (8%) 8 files
installer/resources/src2005 LOC (6%) 5 files
source/soca/cluster_web_ui/views1891 LOC (5%) 18 files
source/soca/cluster_web_ui874 LOC (2%) 10 files
source/soca/cluster_web_ui/scheduled_tasks467 LOC (1%) 4 files
source/soca/cluster_analytics422 LOC (1%) 3 files
source/soca/cluster_hooks/queuejob343 LOC (1%) 6 files
source/scripts262 LOC (<1%) 1 files
installer153 LOC (<1%) 1 files
source/soca/cluster_hooks114 LOC (<1%) 1 files
source/soca/cluster_manager/utilities104 LOC (<1%) 1 files
installer/resources/functions/SolutionMetricsLambda98 LOC (<1%) 2 files
installer/resources/functions/GetESPrivateIPLambda72 LOC (<1%) 2 files
installer/resources/functions/CreateELBSSLCertificate71 LOC (<1%) 2 files
installer/resources/functions/TagEC2ResourceLambda56 LOC (<1%) 2 files
ROOT35 LOC (<1%) 1 files
installer/resources/functions/EFSThroughputLambda34 LOC (<1%) 1 files
source/soca/cluster_analytics/metricbeat29 LOC (<1%) 1 files
installer/resources/functions/ResetDSPassword24 LOC (<1%) 1 files
source/soca/cluster_manager/settings9 LOC (<1%) 1 files
Dependencies
Dependencies among components are static code dependencies among files in different components.

No component dependencies found.



2022-01-31 19:15