Home » 2020

Archiv für das Jahr: 2020

Criteria API – Tutorials

Basics: https://www.baeldung.com/hibernate-criteria-queries

Overview: https://www.baeldung.com/learn-jpa-hibernate

Alternativ: https://www.objectdb.com/java/jpa/query/criteria

Speziell:

Oder man nimmt JPQL:

https://thorben-janssen.com/jpql/

Criteria API: Join mit Filter auf beiden joined Tables

Der Knackpunkt is dieser:

Mit

Root<TabelleA> root = query.from(TabelleA.class)

wird die Ausgangstabelle (root) bezeichnet.

Mit

Join<TabelleA, TablleB> join = root.join(TabelleA.bRef);

wir TabelleB hinzu ge-joined.

Wichig Referenzen (z.B. der Filter auf das Feld feldXY) müssen nun von join aus gehen:

join.get(TablleB.feldXY)

Oder die ganze Where-Clause:

.where(criteriaBuilder.equal(root.get(TabelleA.id), "id000001"),
 criteriaBuilder.like( join.get(TablleB.feldXY), "%gesuchterInhalt%"))

 

Ganze Beispiel

CriteriaBuilder criteriaBuilder = ippDaoProvider.getEntityManager().getCriteriaBuilder();
CriteriaQuery<TabelleA> query = criteriaBuilder.createQuery(TabelleA.class);
Root<TabelleA> root = query.from(TabelleA.class);
Join<TabelleA, TablleB> join = root.join(TabelleA.bRef);

query.select(root).where(criteriaBuilder.equal(root.get(TabelleA.id), "id000001"),
        criteriaBuilder.like( join.get(TablleB.feldXY), "%gesuchterInhalt%"));

List<TabelleA> aList =  daoProvider.getTableADao().find(query);

 

 

Eclipse RCP JUnit tests with SWT checks

The basing question:
How to do JUnit tests for RCP classes that create SWT GUI?

Vorgehen/Hinweise:

  • The „Run As“ dialog of Eclipse offers a „Run as Plugin“ option which must be used if OSGI features are used in the test.
  • If OSGI features are needed (e.g. an OSGI service is part of the game) than OSGI a BundleContext  has to be set up. Read OSGI Component Testing (Integration testing / “black-box-testing”) and perhaps OSGI BundleContext.java.
    If this is done, then a Bundle can be invoked/setup by FrameworkUtil.getBundle(AnyClassInTheTestPlugin.java)

To read:

OSGI Component Testing

OSGI BundleContext.java    –> siehe Mindmap unten!

Eclipse-test-plugin

Testing OSGI Based Applications –> PDF Version

Bundle Context

 

Setting up Eclipse like context for dependency injection:

If the class A has an annotation like

@Inject
C c;

Then a class A can be retrieved that has an object of C already injected like that:

IEclipseContext context = EclipseContextFactory.create("test context");
context.set(C.class, new C(...));
A a = ContextInjectionFactory.make(A.class, context);

 

Problem while running on Linux Jenkins

org.eclipse.swt.SWTError: No more handles [gtk_init_check() failed]

 

xxx

MS Access – Not in Query

In Oracle würde man schreiben:

select feldA
from Table1
where feldA not in (select feldB from Table2);

Pendent in MS Access:

SELECT feldA
FROM Table1
LEFT JOIN Table2
ON Table1.[feldA]=Table2.[feldB];

Eclipse RCP – Minimize/Maximized/Restored status abfragen

Expansionsstatus kann wie folgt abgefragt werden.

MUIElement partStack = modelService.find("my.part.stack", application);
partStack.getTags().add(IPresentationEngine.MINIMIZED);
partStack.setVisible(false);

Abgesrieben aus -> link

Eclipse RCP – Lifecycle Hooks

Was sind die verschiedenen Möglichkeiten zu einem bestimmten Zeitpunkt in den Lauf einer Eclipse RCP Applikation einzugreifen?

  1.  Zu beginn der Bundle-Aktivierung: Im Bundle Activator.
  2. AddOn, Methode mit UIEventTipic markieren, z.B.
  3. Lifecycle-Klasse registieren
  4. Innerhalb des Model Processors
    Der Model Processor ist jedoch eigentlich für das Anpassen des Application Models gedacht.
    –> Siehe auch Model Processor (2)

In welchem Plugin is meine Eclipse RCP Klasse

Funktioniert nur für von Eclipse bereitgestellte Bundles:

https://download.eclipse.org/ → Da kann man nach einer Klasse suchen

Oder ein listing der Eclipse Bundles: https://git.eclipse.org/c/platform/eclipse.platform.ui.git/plain/bundles

Eclipse Plugin manuell installieren

Situation: Die Firewall blockert die Update Site von Eclipse. Man ist sich aber sicher, dass das Plugin, das man installieren möchte unbedenklich ist, z.B. weil es vom der vertrauenswürdeigen Site download.eclipse.org kommt.

Löungsansätze:

How to Download Eclipse Update Site for Offline Use

How can I download an Eclipse plugin as a zip archive using an update site?

How to install plugin for Eclipse from .zip

Eclipse: How to install a plugin manually?

 

Eclipse RCP OSGI – Readings

Sehr schön:

https://www.ibm.com/developerworks/library/os-ecl-osgi/index.html

 

Allenfalls:

https://www.vogella.com/tutorials/OSGi/article.html

https://www.vogella.com/tutorials/EclipseTycho/article.html

 

OSGI – Dependency Visualisierung

Dependency Visualization

Cool Views to control Plug-ins (IDE)

Im übrigen legt der maven build auch irgendwo ein repository an mit einem content.xml file, welches in konzentrierter Form über die Interdependenzen auskunft gibt. Aber leider nicht über die aktuell zusammengewobenen Artifacte sonder über die requirements aller Artifacte. Irgenwo auf einem Pfad, der etwa so aussehen könnte:

repository\target\targetPlatformRepository\content.xml