Тестирование интеграции OSGI, тест Pax Exam выполняет тесты перед запуском пакетов контейнеров

В настоящее время я пытаюсь написать интеграционные тесты OSGI, используя PAX-EXAM+KARAF, и столкнулся с проблемой, когда pax exam пытается выполнить тестовые методы до того, как зависимые пакеты действительно будут запущены / инициализированы в контейнере. Что странно, иногда тестирование проходит успешно, и в этом случае все пакеты / контексты запускаются и регистрируются, но в большинстве случаев это не так. Задержки в методах не помогут:(Кто-нибудь может помочь с этой проблемой?

Я использую PAX-EXAM 2.6.0, org.apache.karaf.tooling.exam.container 2.3.0, apache-karaf 2.3.0.

Код:

@Inject
BundleContext bundleContext;

@Inject
    EntityManagerFactoryService entityManagerFactoryService;//Service exposed trough OSGI

    protected EntityManager entityManager;

    @Before
    public void init() throws InterruptedException {
        entityManager = entityManagerFactoryService.getEntityManagerFactory().createEntityManager();
    }

@Configuration
    public static Option[] configuration() throws Exception {

    return new Option[] {
            karafDistributionConfiguration().frameworkUrl(maven().groupId("org.apache.karaf").artifactId("apache-karaf").type("zip").versionAsInProject())
                    .karafVersion("2.3.0").name("Apache Karaf"),                
mavenBundle("com.google.guava", "guava", "13.0.1").startLevel(30),
mavenBundle("com.mysql.jdbc", "com.springsource.com.mysql.jdbc", "5.1.6").startLevel(30),
                mavenBundle("javax.persistence", "com.springsource.javax.persistence", "2.0.0").startLevel(30),
                mavenBundle("org.apache.commons", "com.springsource.org.apache.commons.lang", "2.6.0").startLevel(30),

...the rest of bundles  

junitBundles(), };

Метод испытания:

@Test
    public void contextNotNull() {
        Assert.assertNotNull(entityManagerFactoryService);
    }

Журнал:

java.lang.ClassNotFoundException: com.startjg.crp.core.dao.service.EntityManagerFactoryService not found by PAXEXAM-PROBE-749fa717-8bdc-4d9a-9803-bdaf6d4edac0 [144]
    at org.apache.felix.framework.BundleWiringImpl.findClassOrResourceByDelegation(BundleWiringImpl.java:1460)
    at org.apache.felix.framework.BundleWiringImpl.access$400(BundleWiringImpl.java:72)
    at org.apache.felix.framework.BundleWiringImpl$BundleClassLoader.loadClass(BundleWiringImpl.java:1843)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)

Полный журнал: https://www.dropbox.com/s/v12r15sbmtu9svp/log.txt

Тоже попробовал без удачи:

protected <T> Object getService(Class<T> serviceClass) {
    int maxCount = 5;
    int delay = 5000;
    for (int i = 0; i <= maxCount; i++) {
        if (bundleContext.getServiceReference(serviceClass) != null) {
            ServiceReference<T> serviceReference = bundleContext.getServiceReference(serviceClass);
            return bundleContext.getService(serviceReference);
        } else {
            try {
                Thread.sleep(delay);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
    return null;
}

@Before
public void init() throws InterruptedException {
    EntityManagerFactoryService emfs = (EntityManagerFactoryService) getService(EntityManagerFactoryService.class);
    entityManager = entityManagerFactoryService.getEntityManagerFactory().createEntityManager();
}

2 ответа

Вы уверены, что ваш EntityManager работает и доступен как Сервис? Скорее всего, вам не хватает некоторых зависимостей, поэтому ваш пакет, содержащий сервис, запущен не полностью.

Текущий экзамен pax 3.3.0 теперь полностью поддерживает karaf в качестве контейнера. Прежний код экзамена по карафу теперь полностью перенесен в экзамен pax.

Другие вопросы по тегам