Danke für den Tipp. Hab' mir jetzt was interface mäßiges gebastelt, habe aber aber
noch ein Problem gefunden, dass ich jetzt umschifft habe aber noch nicht verstehe warum
es aufgetreten ist:
Das Interface ist ja ein TInterfacedObject und damit referenzgezählt.
Es wird auch nur eine Interface Referenz erzeugt die von der
Unit Test Klasse und von
der zu testenden Klasse benutzt wird (Constructor Injection).
Im TInterfacedObject wird eine Logging Klasse von mir über ein globales Singleton genutzt und
im Destructor dieser Klasse noch eine Logmeldung abgesetzt.
Wenn ich die Interface Referenz nicht im TearDown der UnitTest Klasse auf nil setze, dann kommt
das Finalization der Log-Klassen
Unit mit Freigabe des Log-Objektes vor der Freigabe des
Interfaces! Darin wird dann natürlich auf das Log Objekt zugegriffen welches inzwischen nil ist,
da die Freigabe mittels FreeAndNil erfolgte...
Warum in dem Fall diese ungewöhnliche Reihenfolge der Aufrufe?
Mit dem expliziten auf Nil setzen funktioniert es ja, möchte aber den Grund verstehen.