nGrinder 架构简介 nGrinder 的 Groovy 脚本使用指南(Groovy 脚本结构) nGrinder 的 Groovy 脚本使用指南(Groovy maven 结构) nGrinder 的 Groovy 脚本使用指南(导入 Groovy Maven 工程到 IntelliJ)

当你创建脚本时,如果你选择使用 Groovy 脚本,除了 JUnit 方式测试外,它将类似于 Jython 脚本那样执行。如果你不仅想使用 Groovy 而且还要在 IDE 中执行 JUnit,同时又能简单的配置依赖,你可以选择先创建一个 Groovy 的 Maven 项目。

当你第一次运行 Groovy 的 Maven 项目时,可能需要一些时间运行测试。
这是因为 Maven 项目需要从 Maven仓库下载相关的库。请耐心等待。::)。

登陆到 nGrinder, 点击 “脚本” ==> “新建脚本”,选择 “Groovy Maven Project” 类别

groovy脚本语法与java语法_groovy


写入脚本名称,和被测试的 URL 地址,选择 “创建资源和库目录”(可选),然后点击“创建”按钮,即可在 nGrinder 上成功创建一个 Groovy 的 Maven 工程。

groovy脚本语法与java语法_groovy脚本语法与java语法_02

工程对应的 SVN 地址如图中所示,“http://xxxx:xxx/svn/admin/test” ,“admin” 使用用户名,“test”是工程名,工程目录结构如下:

目录

描述

${name}/pom.xml

Maven 的工程文件

${name}/src/main/java/TestRunner.groovy

默认的 Groovy 脚本文件

${name}/src/main/java/resources1.txt

默认的资源文件

${name}/lib

存放私有库

你可以使用 SVN 的方式将项目导入到你的 IDE
参考:nGrinder 的 Groovy 脚本使用指南(导入 Groovy Maven 工程到 IntelliJ)

在 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>

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

- from svn foler + pom.xml
                 + src/main/java/Test1.groovy
                                /package_names/the_other_groovyscripts
                 + src/main/resources/resources1.txt
                                     /subfolder_names/the_other_resources
                 + lib (private libraries)


- to dist folder + Test1.groovy 
                 + resources1.txt 
                 + package_names/the_other_groovy_scripts 
                 + subfolder_names/the_other_resources 
                 + lib (copied from maven dependencies and files in lib folder existing subversion)

在普通的 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);
    }
}