我的项目是标准的maven java项目。我正在尝试将jasmine-maven插件包含在我的CI中。但是当我运行命令mvn clean install
时,它会正确运行测试。但是,如果我运行mvn jasmine:bdd
并从浏览器运行测试。我的html灯具没有加载。
这是我的项目结构。
project
|
|-src
|-main
|-test
|-java
|-javascript
|-jasmine
|-spec
|-spec.js
|-javascripts
| |-fixtures
| |-all_the_fixtures.html
|-lib
|-jasmine-jquery-1.3.1.js
这是我的pom.xml
<plugin>
<groupId>com.github.searls</groupId>
<artifactId>jasmine-maven-plugin</artifactId>
<version>1.2.0.0</version>
<extensions>true</extensions>
<executions>
<execution>
<goals>
<goal>
test
</goal>
</goals>
</execution>
</executions>
<configuration>
<skipTests>false</skipTests>
<jsSrcDir>${basedir}/src/main/webapp/static/js</jsSrcDir>
<jsTestSrcDir>${basedir}/src/test/java/javascript/jasmine/spec</jsTestSrcDir>
<sourceIncludes>
<include>jquery/jquery-min.js</include>
<include>src/source.js</include>
<include>src/source1.js</include>
</sourceIncludes>
<specIncludes>
<include>lib/*.js</include>
<include>**/*.js</include>
</specIncludes>
</configuration>
</plugin>
当我从浏览器运行测试时。所有的html灯具都是404.有没有办法让两种方式都有效?
这就是我加载灯具的方式
it("should get content group with one breadcrumb", function() {
loadFixtures("all_the_fixtures.html");
});
这是我的jasmine-jquery路径配置
this.fixturesPath = 'spec/javascripts/fixtures/';
答案 0 :(得分:1)
我意识到这是一个老问题,只想在这里记录我的发现。我正在努力让自己完成一些同样的事情。我发现的是路径是在运行bdd目标时相对于项目的基础,而不是您创建的jasmine文件夹。这种结构可能适用于OP的环境。
project
|
|-spec
| |-javascripts
| |-fixtrues
| |-all_the_fixtures.html
|-src
|-main
|-test
|-java
|-javascript
|-jasmine
|-spec
|-spec.js
|-javascripts
|-lib
|-jasmine-jquery-1.3.1.js
就我所知,这是known issue。
Here's a post about how to work around it using profiles.基本上,您为Jasmine插件的每个目标创建一个配置文件。希望这有助于某人...