Совместное использование тестового кода в Maven


183

Как вы можете зависеть от тестового кода из другого модуля в Maven?

Например, у меня есть 2 модуля:

  • Основание
  • Основной

Я хотел бы, чтобы контрольный пример в Main расширял базовый тестовый класс в Base. Это возможно?

Обновление: нашел приемлемый ответ , который предполагает создание тестовой банки.


1
Кажется, что ответ, эквивалентный сочетанию принятого ответа ниже, который на самом деле является примечанием к более крупному ответу ниже, теперь находится на сайте Maven: Как создать банку с тестовыми классами
Дэвид Тонхофер

Ответы:


189

Я рекомендую использовать тип вместо классификатора (см. Также: классификатор ). Он рассказывает Maven немного более четко, что вы делаете (и я обнаружил, что m2eclipse и q4e оба нравятся больше).

<dependency>
  <groupId>com.myco.app</groupId>
  <artifactId>foo</artifactId>
  <version>1.0-SNAPSHOT</version>
  <type>test-jar</type>
  <scope>test</scope>
</dependency>

5
Должна ли быть отдельная запись зависимости для com.myco.app специально для типа test-jar?
Ноа Уоткинс

20
Также не забудьте добавить test-jar в конфигурацию maven-jar-plugin: maven.apache.org/guides/mini/guide-attached-tests.html
user1338062

11
Я был в замешательстве, когда впервые прочитал этот ответ ... Это на самом деле, потому что сам по себе он не имеет смысла, сначала вы должны прочитать следующий ответ: stackoverflow.com/questions/174560/…
TanguyP

179

Спасибо за предложение базового модуля. Однако я бы не стал создавать новый модуль именно для этой цели.

Нашел приемлемый ответ в документации Surefire Maven и в блоге . Смотрите также « Как создать банку с тестовыми классами ».

Это создает файл кода jar с src/test/javaиспользованием плагина jar, чтобы модули с тестами могли совместно использовать код.

<project>
  <build>
    <plugins>
     <plugin>
       <groupId>org.apache.maven.plugins</groupId>
       <artifactId>maven-jar-plugin</artifactId>
       <version>2.4</version>
       <executions>
         <execution>
           <goals>
             <goal>test-jar</goal>
           </goals>
         </execution>
       </executions>
     </plugin>
    </plugins>
  </build>
</project>

Чтобы использовать прикрепленный тестовый JAR, созданный выше, вы просто указываете зависимость от основного артефакта с указанным классификатором тестов:

<project>
  ...
  <dependencies>
    <dependency>
      <groupId>com.myco.app</groupId>
      <artifactId>foo</artifactId>
      <version>1.0-SNAPSHOT</version>
      <type>test-jar</type>
      <scope>test</scope>
    </dependency>
  </dependencies>
  ...
</project> 

14
Обратите внимание, что могут быть проблемы с использованием <classifier> tests </ classifier в зависимости. Вместо этого используйте <type> test-jar </ type>. Вот одна проблема в Maven: jira.codehaus.org/browse/MNG-2045 и другая, связанная с IntelliJ youtrack.jetbrains.net/issue/IDEA-54254
Эмиль Сит

Это было очень полезно для меня, но я обнаружил проблему: когда я выполняю «install -Dmaven.test.skip = true», требуется также тестовый jar зависимостей и сбой процесса
Javi Pedrera

@JaviPedrera это работает для меня, даже если я сделаю 'mvn clean install -DskipTests = true' и тестовый jar будет создан. нет ошибок
Karussell

1
@ Аллен, вы убедились, что используете ServiceResultTransformer при упаковке банки? В противном случае вы можете получить служебные файлы, перезаписывающие друг друга.
Jontejj

1
maven.apache.org/plugins/maven-shade-plugin/examples/… там вы можете узнать больше об этом.
Jontejj

12

Мы решили эту проблему, создав проект maven с тестовым кодом в качестве src / main / java и добавив следующую зависимость к проектам:

    <dependency>
        <groupId>foo</groupId>
        <artifactId>test-base</artifactId>
        <version>1</version>
        <scope>test</scope>
    </dependency>

Да, это сработает, спасибо! Смотрите мой комментарий ниже для альтернативного ответа, который я предпочитаю.
flicken

1
Мы также используем этот подход, немного глупо, что вас заставляют переходить на классификаторы или типы (которые вряд ли являются основами в Maven для большинства пользователей), и что вам приходится создавать JAR с некоторыми усилиями, когда вам действительно не нужно это или - как в этом случае - у вас де-факто не тестовый код в качестве основы только для тестового кода.
virgo47

-3

Да ... просто включите базовый модуль в качестве зависимости в Main. Если вы наследуете только тестовый код, то вы можете использовать тег scope, чтобы Maven не включал код в ваш артефакт при развертывании. Примерно так должно работать:

<dependency>
    <groupId>BaseGroup</groupId>
    <artifactId>Base</artifactId>
    <version>0.1.0-SNAPSHOT</version>
    <scope>test</scope>
</dependency>
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.