Java 使用JBehave从URL加载故事时出错

Java 使用JBehave从URL加载故事时出错,java,bdd,jbehave,Java,Bdd,Jbehave,我是JBehave的新手,我试图从URL加载JBehave故事。为了做到这一点,我将我的故事托管到Tomcat服务器上 我的文件存在于桌面上的Stories文件夹中,我编辑了server.xml以承载静态文件并使用url访问它们。例如,我可以使用此URL查看divide.story 我的故事是 Feature: calculation divide Narrative: As a user I want to perform an action So that I can achieve a

我是JBehave的新手,我试图从URL加载JBehave故事。为了做到这一点,我将我的故事托管到Tomcat服务器上

我的文件存在于桌面上的Stories文件夹中,我编辑了server.xml以承载静态文件并使用url访问它们。例如,我可以使用此URL查看divide.story

我的故事是

Feature: calculation divide

Narrative:
As a user
I want to perform an action
So that I can achieve a business goal

Scenario: divide by 2
Given a variable x having value 2
When I divide x by 2
Then result should be 1

Scenario: divide by 3
Given a variable x is 3
When I add x with 3
Then result would be 6
我的配置文件是这样的

import static java.util.Arrays.asList;
import static org.jbehave.core.io.CodeLocations.codeLocationFromURL;
import static org.jbehave.core.reporters.Format.CONSOLE;
import static org.jbehave.core.reporters.Format.HTML;
import static org.jbehave.core.reporters.Format.TXT;
import static org.jbehave.core.reporters.Format.XML;

import java.text.SimpleDateFormat;
import java.util.List;

import org.jbehave.core.configuration.Configuration;
import org.jbehave.core.configuration.MostUsefulConfiguration;
import org.jbehave.core.failures.FailingUponPendingStep;
import org.jbehave.core.io.CodeLocations;
import org.jbehave.core.io.LoadFromRelativeFile;
import org.jbehave.core.io.LoadFromURL;
import org.jbehave.core.io.StoryLoader;
import org.jbehave.core.junit.JUnitStories;
import org.jbehave.core.parsers.gherkin.GherkinStoryParser;
import org.jbehave.core.reporters.CrossReference;
import org.jbehave.core.reporters.Format;
import org.jbehave.core.reporters.PrintStreamStepdocReporter;
import org.jbehave.core.reporters.StoryReporterBuilder;
import org.jbehave.core.steps.InjectableStepsFactory;
import org.jbehave.core.steps.ParameterConverters;
import org.jbehave.core.steps.SilentStepMonitor;
import org.jbehave.core.steps.spring.SpringStepsFactory;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.SpringApplicationConfiguration;
import org.springframework.context.ApplicationContext;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = { ApplicationToTest.class})
public class RemoteStory extends JUnitStories{

 @Autowired
    private ApplicationContext applicationContext;


 public RemoteStory(){
     doConfig();
 }

 public void doConfig(){
     Class<?> thisClass = this.getClass();
useConfiguration(new MostUsefulConfiguration()
               .useStoryLoader(new LoadFromURL())
               .usePendingStepStrategy(new FailingUponPendingStep())
               .useStepdocReporter(new PrintStreamStepdocReporter())
               .useStoryReporterBuilder(
                       new StoryReporterBuilder()  
                            .withCodeLocation(CodeLocations.codeLocationFromURL("http://localhost:8080/static/"))
                      // .withCodeLocation(CodeLocations.codeLocationFromClass(thisClass))
                           .withDefaultFormats()
                           .withFormats(Format.CONSOLE,Format.TXT, Format.HTML, Format.XML, Format.STATS)
                           .withCrossReference(new CrossReference())
                           .withFailureTrace(true))
                           .useParameterConverters(new ParameterConverters()
                           .addConverters(new ParameterConverters.DateConverter(new SimpleDateFormat("yyyy-MM-dd"))))
                           .useStoryParser(new GherkinStoryParser())
                           .useStepMonitor(new SilentStepMonitor()));
       }


@Override
public InjectableStepsFactory stepsFactory() {
    return new SpringStepsFactory(configuration(), applicationContext);
}

@Override
protected List<String> storyPaths() {
    // Specify story paths as remote URLs
    String codeLocation = CodeLocations.codeLocationFromURL("http://localhost:8080/static/").toString();

    return asList(codeLocation + "*.story");
}
导入静态java.util.Arrays.asList;
导入静态org.jbehave.core.io.CodeLocations.codeLocationFromURL;
导入静态org.jbehave.core.reporters.Format.CONSOLE;
导入静态org.jbehave.core.reporters.Format.HTML;
导入静态org.jbehave.core.reporters.Format.TXT;
导入静态org.jbehave.core.reporters.Format.XML;
导入java.text.simpleDataFormat;
导入java.util.List;
导入org.jbehave.core.configuration.configuration;
导入org.jbehave.core.configuration.mostuseveConfiguration;
导入org.jbehave.core.failures.FailingUponPendingStep;
导入org.jbehave.core.io.CodeLocations;
导入org.jbehave.core.io.LoadFromRelativeFile;
导入org.jbehave.core.io.LoadFromURL;
导入org.jbehave.core.io.StoryLoader;
导入org.jbehave.core.junit.JUnitStories;
导入org.jbehave.core.parsers.gherkin.GherkinStoryParser;
导入org.jbehave.core.reporters.CrossReference;
导入org.jbehave.core.reporters.Format;
导入org.jbehave.core.reporters.PrintStreamStepdocReporter;
导入org.jbehave.core.reporters.StoryReporterBuilder;
导入org.jbehave.core.steps.InjectableStepsFactory;
导入org.jbehave.core.steps.ParameterConverters;
导入org.jbehave.core.steps.SilentStepMonitor;
导入org.jbehave.core.steps.spring.SpringStepsFactory;
导入org.junit.runner.RunWith;
导入org.springframework.beans.factory.annotation.Autowired;
导入org.springframework.boot.test.SpringApplicationConfiguration;
导入org.springframework.context.ApplicationContext;
导入org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(类={ApplicationTest.class})
公共类RemoteStory扩展了JUnitStories{
@自动连线
私有应用程序上下文应用程序上下文;
公共故事(){
doConfig();
}
public void doConfig(){
Class thisClass=this.getClass();
useConfiguration(新的MOSTUSIVELConfiguration()
.useStoryLoader(新的LoadFromURL())
.usePendingStepStrategy(新的FailingUponPendingStep())
.useStepdocReporter(新的PrintStreamStepdocReporter())
.useStoryReporterBuilder(
新的StoryReporterBuilder()
.withCodeLocation(CodeLocations.codeLocationFromURL(“http://localhost:8080/static/"))
//.withCodeLocation(CodeLocations.codeLocationFromClass(thisClass))
.withDefaultFormats()
.withFormats(Format.CONSOLE、Format.TXT、Format.HTML、Format.XML、Format.STATS)
.withCrossReference(新的CrossReference())
.withFailureTrace(真))
.useParameterConverters(新的ParameterConverters()
.addConverters(新的参数转换器.DateConverter(新的SimpleDataFormat(“yyyy-MM-dd”))
.useStoryParser(新的GherkinStoryParser())
.useStepMonitor(新的SilentStepMonitor());
}
@凌驾
公共可注射步骤工厂步骤工厂(){
返回新的SpringStepFactory(配置(),applicationContext);
}
@凌驾
受保护的列表故事路径(){
//将故事路径指定为远程URL
字符串codeLocation=CodeLocations.codeLocationFromURL(“http://localhost:8080/static/).toString();
返回asList(代码定位+“*.story”);
}
执行后我得到的错误如下:

2016-02-12 14:57:30.106  INFO 5216 --- [           main]     com.atul.steps.RemoteStory               : Starting RemoteStory on     dluarai1350280 with PID 5216 (D:\Jbehave\Learn\TestGradle\bin started by     arai13 in D:\Jbehave\Learn\TestGradle)
2016-02-12 14:57:30.107  INFO 5216 --- [           main] com.atul.steps.RemoteStory               : No active profile set, falling back to default profiles: default
2016-02-12 14:57:30.156  INFO 5216 --- [           main] s.c.a.AnnotationConfigApplicationContext : Refreshing org.springframework.context.annotation.AnnotationConfigApplicationContext@7161d8d1: startup date [Fri Feb 12 14:57:30 IST 2016]; root of context hierarchy
2016-02-12 14:57:31.800  INFO 5216 --- [           main] org.eclipse.jetty.util.log               : Logging initialized @2654ms
2016-02-12 14:57:31.884  INFO 5216 --- [           main] com.atul.steps.RemoteStory               : Started RemoteStory in 2.066 seconds (JVM running for 2.741)
Processing system properties {}
Using controls     EmbedderControls[batch=false,skip=false,generateViewAfterStories=true,ignoreFailureInStories=false,ignoreFailureInView=false,verboseFailures=false,verboseFiltering=false,storyTimeoutInSecs=300,failOnStoryTimeout=false,threads=1]
Generating reports view to 'http:\localhost:8080\jbehave' using formats '[stats, console, txt, html, xml, stats]' and view properties '{navigator=ftl/jbehave-navigator.ftl, views=ftl/jbehave-views.ftl, reports=ftl/jbehave-reports-with-totals.ftl, nonDecorated=ftl/jbehave-report-non-decorated.ftl, decorated=ftl/jbehave-report-decorated.ftl, maps=ftl/jbehave-maps.ftl}'
Failed to generate reports view to 'http:\localhost:8080\jbehave' using formats '[stats, console, txt, html, xml, stats]' and view properties '{navigator=ftl/jbehave-navigator.ftl, views=ftl/jbehave-views.ftl, reports=ftl/jbehave-reports-with-totals.ftl, nonDecorated=ftl/jbehave-report-non-decorated.ftl, decorated=ftl/jbehave-report-decorated.ftl, maps=ftl/jbehave-maps.ftl}'
2016-02-12 14:57:31.951  INFO 5216 --- [       Thread-1]     s.c.a.AnnotationConfigApplicationContext : Closing org.springframework.context.annotation.AnnotationConfigApplicationContext@7161d8d1: startup date [Fri Feb 12 14:57:30 IST 2016]; root of context hierarchy

java.io.FileNotFoundException:        http:\localhost:8080\jbehave\storyDurations.props (The filename, directory     name, or volume label syntax is incorrect)
at java.io.FileInputStream.open0(Native Method)
at java.io.FileInputStream.open(FileInputStream.java:195)
at java.io.FileInputStream.<init>(FileInputStream.java:138)
at java.io.FileReader.<init>(FileReader.java:72)
at     org.jbehave.core.reporters.TemplateableViewGenerator.storyDurations(TemplateableViewGenerator.java:123)
at     org.jbehave.core.reporters.TemplateableViewGenerator.generateReportsView(Temp  lateableViewGenerator.java:115)
at org.jbehave.core.embedder.Embedder.generateReportsView(Embedder.java:249)
at org.jbehave.core.embedder.Embedder.generateReportsView(Embedder.java:237)
at    org.jbehave.core.embedder.Embedder.runStoriesAsPaths(Embedder.java:213)
at org.jbehave.core.junit.JUnitStories.run(JUnitStories.java:20)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at   sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:75)
at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86)
at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:254)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:89)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70)
at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:193)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)
2016-02-12 14:57:30.106信息5216---[main]com.atul.steps.RemoteStory:在dluarai1350280上启动RemoteStory,PID 5216(D:\Jbehave\Learn\TestGradle\bin由arai13在D:\Jbehave\Learn\TestGradle中启动)
2016-02-12 14:57:30.107信息5216---[main]com.atul.steps.RemoteStory:未设置活动配置文件,返回默认配置文件:默认
2016-02-12 14:57:30.156信息5216---[main]s.c.a.AnnotationConfigApplicationContext:刷新org.springframework.context.annotation。AnnotationConfigApplicationContext@7161d8d1:启动日期[Fri Feb 12 14:57:30 IST 2016];上下文层次结构的根
2016-02-12 14:57:31.800信息5216---[main]org.eclipse.jetty.util.log:日志已初始化@2654ms
2016-02-12 14:57:31.884信息5216---[main]com.atul.steps.RemoteStory:在2.066秒内启动了RemoteStory(JVM运行2.741)
处理系统属性{}
使用控件EmbedderControls[batch=false,skip=false,generateViewAfterStories=true,ignoreFailureInStories=false,ignoreFailureInView=false,verboseFailures=false,verboseFiltering=false,StoryTimeoutingSecs=300,FailOnToryTimeout=false,threads=1]
使用格式“[stats,console,txt,html,xml,stats]”和视图属性生成“http:\localhost:8080\jbehave”的报告视图{navigator=ftl/jbehave-navigator.ftl,views=ftl/jbehave-views.ftl,reports=ftl/jbehave-reports-with-totals.ftl,nonDecorated=ftl/jbehave-report-non-decorated.ftl,decorated=ftl/jbehave-report-decorated.ftl,maps=ftl/jbehave-maps.ftl}'
无法使用格式“[stats,console,txt,html,xml,stats]”和视图属性生成“http:\localhost:8080\jbehave”的报告视图{navigator=ftl/jbehave-navigator.ftl,views=ftl/jbehave-views.ftl,reports=ftl/jbehave-reports-with-totals.ftl,nonDecorated=ftl/jbehave-report-non-decorated.ftl,decorated=ftl/jbehave-report-decorated.ftl,maps=ftl/jbehave-maps.ftl}'
2016-02-12 14:57:31.951信息5216--[