| synchronizeSecondaryDatabase(DBDatabase) |   | 78% |   | 72% | 5 | 10 | 16 | 64 | 0 | 1 |
| deadDatabase(DBDatabase, Throwable) |  | 0% |  | 0% | 5 | 5 | 14 | 14 | 1 | 1 |
| quarantineDatabase(DBDatabase, Throwable) |   | 36% |   | 33% | 6 | 7 | 12 | 22 | 0 | 1 |
| loadTrackedTables() |  | 0% |  | 0% | 4 | 4 | 15 | 15 | 1 | 1 |
| saveTrackedTables() |   | 8% |   | 16% | 3 | 4 | 14 | 16 | 0 | 1 |
| setAuthoritativeDatabase() |   | 8% |   | 12% | 4 | 5 | 10 | 12 | 0 | 1 |
| getAuthoritativeDatabaseConnectionSettings() |  | 0% |  | 0% | 4 | 4 | 14 | 14 | 1 | 1 |
| setTrackedTables(Collection) |  | 0% |  | 0% | 2 | 2 | 8 | 8 | 1 | 1 |
| getSavedTrackedTables() |  | 0% |  | 0% | 2 | 2 | 10 | 10 | 1 | 1 |
| waitUntilDatabaseHasSynchronised(DBDatabase, long) |   | 50% |   | 33% | 5 | 7 | 4 | 10 | 0 | 1 |
| getAuthoritativeDatabase() |  | 0% |  | 0% | 2 | 2 | 7 | 7 | 1 | 1 |
| awaitReadyDatabase() |  | 0% | | n/a | 1 | 1 | 6 | 6 | 1 | 1 |
| addAll(DBDatabase[]) |  | 0% |  | 0% | 2 | 2 | 3 | 3 | 1 | 1 |
| getRandomReadyDatabase() |   | 53% |   | 25% | 4 | 5 | 4 | 11 | 0 | 1 |
| dismantle() |   | 39% | | n/a | 0 | 1 | 8 | 17 | 0 | 1 |
| isSynchronized() |   | 62% |   | 50% | 2 | 4 | 1 | 4 | 0 | 1 |
| releaseTemplateDatabase(DBDatabase) |   | 37% |   | 75% | 1 | 3 | 2 | 6 | 0 | 1 |
| addTrackedTables(Collection) |  | 0% |  | 0% | 2 | 2 | 5 | 5 | 1 | 1 |
| removeTrackedTables(Collection) |  | 0% |  | 0% | 2 | 2 | 5 | 5 | 1 | 1 |
| getClusterHostsFromPrefs() |   | 77% |   | 87% | 1 | 5 | 5 | 21 | 0 | 1 |
| addAll(Collection) |  | 0% |  | 0% | 2 | 2 | 4 | 4 | 1 | 1 |
| synchronizeActions(DBDatabase) |   | 68% |   | 60% | 4 | 6 | 6 | 18 | 0 | 1 |
| getDatabasesForReconnecting() |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| synchronizeSecondaryDatabases() |   | 66% |   | 50% | 2 | 4 | 2 | 6 | 0 | 1 |
| getReadyDatabase() |   | 60% |   | 50% | 3 | 5 | 2 | 6 | 0 | 1 |
| waitUntilSynchronised() |   | 71% |   | 75% | 1 | 3 | 2 | 7 | 0 | 1 |
| add(DBDatabase) |   | 84% |   | 70% | 3 | 6 | 2 | 15 | 0 | 1 |
| hasAuthoritativeDatabase() |  | 0% |  | 0% | 2 | 2 | 1 | 1 | 1 | 1 |
| saveClusterSettingsToPrefs() |   | 77% |  | 100% | 0 | 2 | 2 | 9 | 0 | 1 |
| isEligibleForSynchronizing(DBDatabase) |   | 76% |   | 37% | 4 | 5 | 0 | 3 | 0 | 1 |
| getPausedDatabase(DBDatabase) |  | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 |
| setClusterLabel(String) |  | 0% | | n/a | 1 | 1 | 3 | 3 | 1 | 1 |
| addPropertyChangeListener(PropertyChangeListener) |  | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 |
| removePropertyChangeListener(PropertyChangeListener) |  | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 |
| printAllFormerDatabases() |  | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 |
| lambda$printAllFormerDatabases$0(String) |  | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 |
| getAutoRebuild() |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| setPreferredDatabaseRequired(boolean) |  | 0% | | n/a | 1 | 1 | 2 | 2 | 1 | 1 |
| getTemplateDatabase() |  | 90% |   | 75% | 2 | 5 | 1 | 5 | 0 | 1 |
| isPreferredDatabaseRequired() | | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| isShuttingDown() |  | 71% |   | 50% | 1 | 2 | 0 | 1 | 0 | 1 |
| getTrackedTablesSeparatedStringTemplate() | | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| quarantineDatabaseAutomatically(DBDatabase, Throwable) |  | 85% | | n/a | 0 | 1 | 1 | 4 | 0 | 1 |
| ClusterDetails(String) |  | 100% | | n/a | 0 | 1 | 0 | 20 | 0 | 1 |
| removeDatabase(DBDatabase) |  | 100% |   | 75% | 1 | 3 | 0 | 10 | 0 | 1 |
| checkSupportForDifferenceBetweenNullAndEmptyString() |  | 100% |  | 100% | 0 | 4 | 0 | 5 | 0 | 1 |
| getActionQueue(DBDatabase) |  | 100% |  | 100% | 0 | 2 | 0 | 6 | 0 | 1 |
| addTrackedTable(DBRow, boolean) |  | 100% |   | 50% | 1 | 2 | 0 | 7 | 0 | 1 |
| removeTrackedTable(DBRow, boolean) |  | 100% |   | 50% | 1 | 2 | 0 | 7 | 0 | 1 |
| getRequiredAndTrackedTables() |  | 100% | | n/a | 0 | 1 | 0 | 4 | 0 | 1 |
| copyTemplateActionQueueToSecondary(DBDatabase, DBDatabase) |  | 100% | | n/a | 0 | 1 | 0 | 5 | 0 | 1 |
| signalThatADatabaseHasBeenSynchronised() |  | 100% |  | 100% | 0 | 2 | 0 | 6 | 0 | 1 |
| getAllDatabases() |  | 100% | | n/a | 0 | 1 | 0 | 3 | 0 | 1 |
| readyDatabase(DBDatabase) |  | 100% | | n/a | 0 | 1 | 0 | 5 | 0 | 1 |
| signalSomeDatabasesNeedSynchronising() |  | 100% | | n/a | 0 | 1 | 0 | 4 | 0 | 1 |
| hasTooFewReadyDatabases() |  | 100% |  | 100% | 0 | 2 | 0 | 1 | 0 | 1 |
| getUnsynchronizedDatabases() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| signalReadyDatabaseIsAvailable() |  | 100% | | n/a | 0 | 1 | 0 | 4 | 0 | 1 |
| hasReadyDatabases() |  | 100% |  | 100% | 0 | 2 | 0 | 1 | 0 | 1 |
| getReadyDatabases() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| getQuarantinedDatabases() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| signalThatAllDatabasesHaveBeenSynchronised() |  | 100% | | n/a | 0 | 1 | 0 | 4 | 0 | 1 |
| addDatabaseAsUnsynchronized(DBDatabase) |  | 100% | | n/a | 0 | 1 | 0 | 3 | 0 | 1 |
| getPausedDatabase() |  | 100% | | n/a | 0 | 1 | 0 | 3 | 0 | 1 |
| static {...} |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| isNotSynchronized() |  | 100% |  | 100% | 0 | 2 | 0 | 1 | 0 | 1 |
| hasPreferredDatabase() |  | 100% |  | 100% | 0 | 2 | 0 | 1 | 0 | 1 |
| preferredDatabaseIsReady() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| removedTrackedTablesFromPrefs() |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| removeAuthoritativeDatabaseFromPrefs() |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| removeAddedDatabasesFromPrefs() |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| addTrackedTable(DBRow) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| removeTrackedTable(DBRow) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| clusterContains(DBDatabase) |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| getSupportsDifferenceBetweenNullAndEmptyString() |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| waitUntilDatabaseHasSynchronised(DBDatabase) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| getStatusOf(DBDatabase) |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| getTrackedTablesPrefsIdentifier() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| removeAllDatabases() |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| getAutoReconnect() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| setSupportsDifferenceBetweenNullAndEmptyString(boolean) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| setQuietExceptionsPreference(boolean) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| setConfiguration(DBDatabaseCluster.Configuration) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| getPrefsClusterSettingsKey() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |
| setClusterSettings(DatabaseConnectionSettings) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| setPreferredDatabase(DBDatabase) |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| shutdown() |  | 100% | | n/a | 0 | 1 | 0 | 2 | 0 | 1 |
| getClusterLabel() | | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |