microsoft / elastic-db-tools-for-java
Conditional Complexity

The distribution of complexity of units (measured with McCabe index).

Intro
  • Conditional complexity (also called cyclomatic complexity) is a term used to measure the complexity of software. The term refers to the number of possible paths through a program function. A higher value ofter means higher maintenance and testing costs (infosecinstitute.com).
  • Conditional complexity is calculated by counting all conditions in the program that can affect the execution path (e.g. if statement, loops, switches, and/or operators, try and catch blocks...).
  • Conditional complexity is measured at the unit level (methods, functions...).
  • Units are classified in four categories based on the measured McCabe index: 1-5 (simple units), 6-10 (medium complex units), 11-25 (complex units), 26+ (very complex units).
Learn more...
Conditional Complexity Overall
  • There are 1,760 units with 12,102 lines of code in units (71.2% of code).
    • 0 very complex units (0 lines of code)
    • 1 complex units (39 lines of code)
    • 16 medium complex units (899 lines of code)
    • 53 simple units (1,326 lines of code)
    • 1,690 very simple units (9,838 lines of code)
0% | <1% | 7% | 10% | 81%
Legend:
51+
26-50
11-25
6-10
1-5
Alternative Visuals
Conditional Complexity per Extension
51+
26-50
11-25
6-10
1-5
java0% | <1% | 7% | 10% | 81%
Conditional Complexity per Logical Component
primary logical decomposition
51+
26-50
11-25
6-10
1-5
shard/storeops0% | 1% | 6% | 11% | 80%
shard/recovery0% | 0% | 38% | 9% | 52%
shard/base0% | 0% | 6% | 12% | 81%
shard/sqlstore0% | 0% | 14% | 26% | 58%
shard/mapper0% | 0% | 9% | 20% | 70%
shard/store0% | 0% | 8% | 3% | 87%
core/commons0% | 0% | 5% | 9% | 84%
shard/utils0% | 0% | 4% | 13% | 82%
query/multishard0% | 0% | 0% | 10% | 89%
shard/map0% | 0% | 0% | 5% | 94%
shard/schema0% | 0% | 0% | 7% | 92%
shard/mapmanager0% | 0% | 0% | 2% | 97%
query/exception0% | 0% | 0% | 0% | 100%
query/logging0% | 0% | 0% | 0% | 100%
Most Complex Units
Top 20 most complex units
Unit# linesMcCabe index# params
public ShardManagementException onStoreException()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/storeops/base/StoreOperation.java
39 31 2
public List detectMappingDifferences()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/recovery/RecoveryManager.java
154 24 2
public static StoreResults newInstance()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/sqlstore/SqlResults.java
66 19 1
public boolean isTransient()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/core/commons/transientfaulthandling/SqlDatabaseTransientErrorDetectionStrategy.java
28 18 1
private static StoreOperationState undoStateForDoState()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/storeops/base/StoreOperation.java
27 18 1
protected final Connection openConnectionForKey()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/mapper/BaseShardMapper.java
61 16 5
public static ArrayList compareRangeMappings()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/recovery/MappingComparisonUtils.java
172 15 3
public static String operationNameFromStoreOperationCode()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/storeops/base/StoreOperationErrorHandler.java
34 15 1
public static ShardManagementException onShardMapperErrorGlobal()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/storeops/base/StoreOperationErrorHandler.java
46 14 6
public IStoreOperation fromLogEntry()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/storeops/base/StoreOperationFactory.java
32 14 2
public static boolean isFirstGreaterThan()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/store/Version.java
32 13 2
public int compareTo()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/base/ShardKey.java
48 12 1
public ShardKey getNextKey()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/base/ShardKey.java
46 12 0
public Object getItem()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/sqlstore/SqlConnectionStringBuilder.java
20 12 1
public final StoreResults doGlobal()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/storeops/base/StoreOperationGlobal.java
50 11 0
private List getMappingsToPurge()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/storeops/recovery/ReplaceMappingsGlobalOperation.java
67 11 1
public static List filterUpgradeCommands()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/utils/SqlUtils.java
16 11 3
public boolean next()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/query/multishard/MultiShardResultSet.java
31 10 0
private MultiShardException validateResultSet()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/query/multishard/MultiShardStatement.java
47 10 2
private Object deNormalize()
in elastic-db-tools/src/main/java/com/microsoft/azure/elasticdb/shard/base/ShardKey.java
30 10 2