3

嗨,我是 AngularJS 和测试 JS 的新手。我需要用 Maven 运行我的测试。我为一个小应用程序创建了一个控制器和一个服务,它们正在工作。现在我想为我拥有的 JS 代码编写测试(是的,在开发时打破了编写测试的规则)。到目前为止,我已经设法用 Maven 调用测试。

我正在使用 jasmine-maven-plugin。

<plugin>
    <groupId>com.github.searls</groupId>
    <artifactId>jasmine-maven-plugin</artifactId>
    <version>1.3.1.3</version>
    <executions>
        <execution>
            <goals>
                <goal>test</goal>
            </goals>
        </execution>
    </executions>
    <configuration>
        <jsSrcDir>src/main/webapp/js</jsSrcDir>
        <jsTestSrcDir>src/test/webapp/js</jsTestSrcDir>
        <specIncludes>
            <include>*Spec.js</include>
        </specIncludes>
    </configuration>
</plugin>

运行mvn test时,我看到以下内容

[INFO] --- jasmine-maven-plugin:1.3.1.3:test (default) @ pod-manager-web-ang --- 2013-10-14 14:57:34.322:INFO:oejs.Server:jetty- 8.1.13.v20130916 2013-10-14 14:57:34.378:INFO:oejs.AbstractConnector:Started SelectChannelConnector@0.0.0.0:56475 [INFO] 执行 Jasmine 规范

然后失败并显示以下消息

[ERROR] Caused by: net.sourceforge.htmlunit.corejs.javascript.EcmaError: ReferenceError: "angular" is not defined. (http://localhost:56475/src/controllers/controller.js#3)
[ERROR] at net.sourceforge.htmlunit.corejs.javascript.ScriptRuntime.constructError(ScriptRuntime.java:3603)
[ERROR] at net.sourceforge.htmlunit.corejs.javascript.ScriptRuntime.constructError(ScriptRuntime.java:3587)
[ERROR] at net.sourceforge.htmlunit.corejs.javascript.ScriptRuntime.notFoundError(ScriptRuntime.java:3657)
[ERROR] at net.sourceforge.htmlunit.corejs.javascript.ScriptRuntime.name(ScriptRuntime.java:1685)

问题是我应该将 angular.js 和其他 angular JS 文件放在哪里才能运行这些测试?

4

1 回答 1

7

使用 preloadSources 加载 Angular、jQuery 和其他需要的库。

<configuration>
    <preloadSources>
        <source>${project.basedir}/src/main/webapp/vendor/jquery/1.10.2/jquery.js</source>
        <source>${project.basedir}/src/main/webapp/vendor/angular/1.0.5/angular.js</source>
    </preloadSources>
    <jsSrcDir>src/main/webapp/js</jsSrcDir>
    <jsTestSrcDir>src/test/webapp/js</jsTestSrcDir>
    <specIncludes>
        <include>*Spec.js</include>
    </specIncludes>
</configuration>
于 2013-10-14T19:32:23.040 回答