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” 类别
写入脚本名称,和被测试的 URL 地址,选择 “创建资源和库目录”(可选),然后点击“创建”按钮,即可在 nGrinder 上成功创建一个 Groovy 的 Maven 工程。
工程对应的 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);
}
}