如何运行生成后生成的Maven项目的jar文件?

时间:2019-12-13 11:31:47

标签: java eclipse maven selenium testng.xml

我做了一个包含几个测试的简单项目,并且希望能够在其他计算机上启动测试。我在Eclipse中使用运行方式-> Maven构建... -> 目标:包构建了项目,并在其中找到了一个jar文件项目的目标文件夹。但是,当我尝试使用java -jar project.jar在cmd中运行它时,出现以下错误:

  

错误:在com.example.TestPurchase类中找不到主要方法,请将该主要方法定义为:      公共静态void main(String [] args)   或JavaFX应用程序类必须扩展javafx.application.Application

据我所知,由于注释,TestNG不需要任何Main方法。 这给我带来了一些问题:

  1. 我的项目构建方式有问题吗?
  2. 我了解通过jar文件执行测试的方法正确吗?
  3. 我什至必须使用该jar文件吗?因为我可以使用mvn test
  4. 从位于项目文件夹中的命令行运行测试

这是我的pom.xml文件:

<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.example</groupId>
<artifactId>Sightsy</artifactId>
<version>0.0.1-SNAPSHOT</version>
<properties>
    <java.version>1.8</java.version>
    <selenium.version>3.12.0</selenium.version>
    <testng.version>6.13.1</testng.version>
    <javafaker.version>0.14</javafaker.version>
    <guava.version>23.2-jre</guava.version>
    <extentreports.version>3.0.7</extentreports.version>
    <extenttestng.version>1.3.1</extenttestng.version>
    <assertj.version>3.8.0</assertj.version>
    <maven.compiler.version>3.7.0</maven.compiler.version>
    <commons.version>3.7</commons.version>
    <commons.io.version>2.6</commons.io.version>
</properties>

<dependencies>
    <dependency>
        <groupId>org.seleniumhq.selenium</groupId>
        <artifactId>selenium-java</artifactId>
        <version>${selenium.version}</version>
    </dependency>
    <dependency>
        <groupId>org.testng</groupId>
        <artifactId>testng</artifactId>
        <version>${testng.version}</version>
    </dependency>
    <dependency>
        <groupId>com.github.javafaker</groupId>
        <artifactId>javafaker</artifactId>
        <version>${javafaker.version}</version>
    </dependency>
    <dependency>
        <groupId>com.google.guava</groupId>
        <artifactId>guava</artifactId>
        <version>${guava.version}</version>
    </dependency>
    <dependency>
        <groupId>com.aventstack</groupId>
        <artifactId>extentreports</artifactId>
        <version>${extentreports.version}</version>
    </dependency>
    <dependency>
        <groupId>com.vimalselvam</groupId>
        <artifactId>testng-extentsreport</artifactId>
        <version>${extenttestng.version}</version>
    </dependency>
    <dependency>
        <groupId>org.assertj</groupId>
        <artifactId>assertj-core</artifactId>
        <version>${assertj.version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-lang3</artifactId>
        <version>${commons.version}</version>
    </dependency>
    <dependency>
        <groupId>commons-io</groupId>
        <artifactId>commons-io</artifactId>
        <version>${commons.io.version}</version>
    </dependency>
    <dependency>
        <groupId>com.opencsv</groupId>
        <artifactId>opencsv</artifactId>
        <version>3.4</version>
    </dependency>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi</artifactId>
        <version>3.12</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml</artifactId>
        <version>3.12</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>com.amazonaws</groupId>
        <artifactId>aws-lambda-java-core</artifactId>
        <version>1.2.0</version>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>${maven.compiler.version}</version>
            <configuration>
                <source>${java.version}</source>
                <target>${java.version}</target>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-shade-plugin</artifactId>
            <version>3.2.1</version>
            <executions>
                <execution>
                    <phase>package</phase>
                    <goals>
                        <goal>shade</goal>
                    </goals>
                    <configuration>
                        <transformers>
                            <transformer
                                implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                <mainClass>com.example.TestPurchase</mainClass>
                            </transformer>
                        </transformers>
                    </configuration>
                </execution>
            </executions>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-surefire-plugin</artifactId>
            <version>2.21.0</version>
            <configuration>
                <suiteXmlFiles>
                    <suiteXmlFile>src/main/resources/suites/testng.xml</suiteXmlFile>
                </suiteXmlFiles>
            </configuration>
        </plugin>
</plugins>
</build>

2 个答案:

答案 0 :(得分:1)

我对TestNG框架不熟悉,但是我的理解如下:

执行“ mvn软件包”时,将对您的项目进行“验证”,“编译”,然后“打包”。在编译期间,您的代码将更改为字节码,并且可以由Java虚拟机(JVM)解释(执行)。此编译的代码只有您的应用程序(我假设这是在Java服务器上执行的应用程序)。

在“打包”步骤中,这些已编译的类(不进行测试)一起放在jar文件中。这个jar文件应该只包含您的应用程序(同样,没有进行测试)-这是您想要的,因为您的jar文件较小并且仅包含实际需要的内容。

现在,当执行“ MVN测试”时,带有测试代码的类将被编译然后执行。 TestNG“自动”添加主要功能,因此JVM知道该怎么做。请注意,再次运行“ mvn软件包”仍不会将这些测试包含在jar文件中。

要直接解决您的问题: 广告1.否 广告2。是的,“ MVN测试”是正确的方法。 广告3.不,您不应在测试期间使用jar文件。稍后在部署期间使用它。

答案 1 :(得分:0)

首先,您必须使用“ main”方法创建一个单独的类,在其中指定xml套件文件。

package com.example;
import java.util.ArrayList;
import java.util.List;
import org.testng.TestNG;
public class MainClass {
public static void main(String[] args) {
TestNG testSuite = new TestNG();
List<String> suites = new ArrayList<String>();
suites.add("path_to_your_xml_suite_file_in_target_folder");
testSuite.setTestSuites(suites);
testSuite.run();
 }
}

然后,您需要在pom.xml中配置maven-shade-plugin时使用“ main”方法指定此类。

<plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-shade-plugin</artifactId>
        <version>3.2.1</version>
        <executions>
            <execution>
                <phase>package</phase>
                <goals>
                    <goal>shade</goal>
                </goals>
                <configuration>
                    <transformers>
                        <transformer
                            implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                            <mainClass>com.example.TestNGMainClass</mainClass>
                        </transformer>
                    </transformers>
                </configuration>
            </execution>
        </executions>
    </plugin>

然后,当您不执行测试而执行mvn build package时,您将在目标文件夹中拥有一个完全可用的可执行jar文件,您可以使用java -jar name_of_you_jar_file.jar在命令行中启动该文件。它将需要驱动程序和xml套件文件才能工作