nGrinder Maven工程使用

1:新建Maven groovy工程
2:SVN Checkout Maven工程
3:新建JUnit脚本,并运行,提示报错
java.lang.RuntimeException: Please add
-javaagent:/Users/xx/.m2/repository/net/sf/grinder/grinder-dcr-agent/3.9.1/grinder-dcr-agent-3.9.1.jar
in 'Run As JUnit' vm argument.
4:Edit Run Configuration
VM options添加

-ea -javaagent:/Users/xx/.m2/repository/net/sf/grinder/grinder-dcr-agent/3.9.1/grinder-dcr-agent-3.9.1.jar

5:Maven 工程目录结构

6:修改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>ngrinder</groupId>
    <artifactId>test</artifactId>
    <version>0.0.1</version>

    <properties>
        <ngrinder.version>3.4</ngrinder.version>
        <maven.compiler.source>1.7</maven.compiler.source>
        <maven.compiler.target>1.7</maven.compiler.target>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <repositories>
        <repository>
            <id>ngrinder.maven.repo</id>
            <url>https://github.com/naver/ngrinder/raw/ngrinder.maven.repo/releases</url>
        </repository>
    </repositories>
    <dependencies>
        <dependency>
            <groupId>org.ngrinder</groupId>
            <artifactId>ngrinder-groovy</artifactId>
            <version>${ngrinder.version}</version>
            <scope>provided</scope>
        </dependency>

        <!-- 添加依赖 -->
        <!--
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.0.1</version>
        </dependency>
         -->
        <!-- 添加你的私有库依赖 -->
        <!--
        <dependency>
            <groupId>your_lib</groupId>
            <artifactId>your_lib</artifactId>
            <version>your_lib_version</version>
            <scope>system</scope>
            <systemPath>${project.basedir}/lib/hello.jar</systemPath>
        </dependency>
        -->
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-eclipse-plugin</artifactId>
                <version>2.9</version>
                <configuration>
                    <additionalProjectnatures>
                        <projectnature>
                            org.eclipse.jdt.groovy.core.groovyNature
                        </projectnature>
                        <projectnature>
                            org.eclipse.m2e.core.maven2Nature
                        </projectnature>
                    </additionalProjectnatures>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

7:原理
当一个脚本在性能测试配置页被选中时,
controller 会自动监测此脚本是否在 ${name}/src/main/java 文件夹下,
同时监测 pom.xml 是否在基础文件夹(相对于当前 Groovy 工程)下。
如果 controller 检测到了它们,
在分发给代理之前 controller 将会递归的拷贝在 ${name}/src/main/resources 和 ${name}/src/main/java 目录下的文件到准备分发目录下。
下图说明了 SVN 中的每个文件夹是如何拷贝到准备分发目录的

在普通的 Jython 脚本和 Groovy 脚本中,
可以使用 “open(“./resources/resource1.txt”)” 或者 “new File(“./resources/resource1.txt”)加载资源文件。
然而在 Groovy 的 Maven 工程中将不可用。
我们不得不替换此路径到 classpath 的基础资源路径,确保可以在 IDE 中可以运行 Groovy 的 JUnit 测试用例,资源文件在分发拷贝时将会保持目录层次。
你可以使用下面的代码加载资源文件

import org.codehaus.groovy.reflection.ReflectionUtils;
....
class YourTest {
    String text;

    @BeforeThread
    public void beforeThread() {
       // In groovy, InputStream contains text field.
       text = loadResourceFromClassPath("/resource1.txt").text;
    }

    @Test
    public void doTest() {
       ....
    }

    // This is groovy way to load resource from classpath
    public loadResourceFromClassPath(String resourcePath) {
        return ReflectionUtils.getCallingClass(0).getResourceAsStream(resourcePath);
    }
}
posted @ 2018-01-25 10:57  xidianzxm  阅读(493)  评论(0编辑  收藏  举报