Eclipse中的RED编辑器在打开.robot套件文件时抛出异常

时间:2016-05-20 06:09:25

标签: java eclipse eclipse-plugin robotframework java-io

  1. 我正在使用java程序生成机器人套件文件,该程序使用UTF-8编码生成.robot文件
  2. 尝试使用Eclipse Mars中的RED Editor打开生成的Robot套件文件
  3. 第3。抛出异常,需要弄清楚为什么?和可能的灵魂。

    1. 请注意,可以打开使用RED Editor创建的其他机器人文件而不会出现此错误
    2. 另请注意,使用java程序生成的Robot文件使用notepad ++和vim
    3. 正确打开

      示例机器人套件文件:

      *** Settings ***
      Library     some.class.path.ClassName
      
      *** Keywords ***
      type val
          [Arguments]     ${xpathForLocale}       ${dataModifyRole}       ${strLocale}    
           some.class.path.ClassName.type     ${xpathForLocale}       ${dataModifyRole}       ${strLocale}
      

      例外:

      org.robotframework.ide.eclipse.main.plugin.tableeditor.RobotFormEditor$IllegalRobotEditorInputException: Unable to open editor: unrecognized input of class: org.eclipse.ui.ide.FileStoreEditorInput
          at org.robotframework.ide.eclipse.main.plugin.tableeditor.RobotFormEditor.setInput(RobotFormEditor.java:119)
          at org.eclipse.ui.forms.editor.FormEditor.init(FormEditor.java:128)
          at org.robotframework.ide.eclipse.main.plugin.tableeditor.RobotFormEditor.init(RobotFormEditor.java:86)
          at org.eclipse.ui.internal.EditorReference.initialize(EditorReference.java:361)
          at org.eclipse.ui.internal.e4.compatibility.CompatibilityPart.create(CompatibilityPart.java:319)
          at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
          at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
          at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
          at java.lang.reflect.Method.invoke(Unknown Source)
          at org.eclipse.e4.core.internal.di.MethodRequestor.execute(MethodRequestor.java:56)
          at org.eclipse.e4.core.internal.di.InjectorImpl.processAnnotated(InjectorImpl.java:898)
          at org.eclipse.e4.core.internal.di.InjectorImpl.processAnnotated(InjectorImpl.java:879)
          at org.eclipse.e4.core.internal.di.InjectorImpl.inject(InjectorImpl.java:121)
          at org.eclipse.e4.core.internal.di.InjectorImpl.internalMake(InjectorImpl.java:345)
          at org.eclipse.e4.core.internal.di.InjectorImpl.make(InjectorImpl.java:264)
          at org.eclipse.e4.core.contexts.ContextInjectionFactory.make(ContextInjectionFactory.java:162)
          at org.eclipse.e4.ui.internal.workbench.ReflectionContributionFactory.createFromBundle(ReflectionContributionFactory.java:104)
          at org.eclipse.e4.ui.internal.workbench.ReflectionContributionFactory.doCreate(ReflectionContributionFactory.java:73)
          at org.eclipse.e4.ui.internal.workbench.ReflectionContributionFactory.create(ReflectionContributionFactory.java:55)
          at org.eclipse.e4.ui.workbench.renderers.swt.ContributedPartRenderer.createWidget(ContributedPartRenderer.java:129)
          at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.createWidget(PartRenderingEngine.java:971)
          at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.safeCreateGui(PartRenderingEngine.java:640)
          at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.safeCreateGui(PartRenderingEngine.java:746)
          at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.access$0(PartRenderingEngine.java:717)
          at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$2.run(PartRenderingEngine.java:711)
          at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42)
          at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.createGui(PartRenderingEngine.java:695)
          at org.eclipse.e4.ui.workbench.renderers.swt.StackRenderer.showTab(StackRenderer.java:1306)
          at org.eclipse.e4.ui.workbench.renderers.swt.LazyStackRenderer$1.handleEvent(LazyStackRenderer.java:72)
          at org.eclipse.e4.ui.services.internal.events.UIEventHandler$1.run(UIEventHandler.java:40)
          at org.eclipse.swt.widgets.Synchronizer.syncExec(Synchronizer.java:186)
          at org.eclipse.ui.internal.UISynchronizer.syncExec(UISynchronizer.java:145)
          at org.eclipse.swt.widgets.Display.syncExec(Display.java:4761)
          at org.eclipse.e4.ui.internal.workbench.swt.E4Application$1.syncExec(E4Application.java:211)
          at org.eclipse.e4.ui.services.internal.events.UIEventHandler.handleEvent(UIEventHandler.java:36)
          at org.eclipse.equinox.internal.event.EventHandlerWrapper.handleEvent(EventHandlerWrapper.java:197)
          at org.eclipse.equinox.internal.event.EventHandlerTracker.dispatchEvent(EventHandlerTracker.java:197)
          at org.eclipse.equinox.internal.event.EventHandlerTracker.dispatchEvent(EventHandlerTracker.java:1)
          at org.eclipse.osgi.framework.eventmgr.EventManager.dispatchEvent(EventManager.java:230)
          at org.eclipse.osgi.framework.eventmgr.ListenerQueue.dispatchEventSynchronous(ListenerQueue.java:148)
          at org.eclipse.equinox.internal.event.EventAdminImpl.dispatchEvent(EventAdminImpl.java:135)
          at org.eclipse.equinox.internal.event.EventAdminImpl.sendEvent(EventAdminImpl.java:78)
          at org.eclipse.equinox.internal.event.EventComponent.sendEvent(EventComponent.java:39)
          at org.eclipse.e4.ui.services.internal.events.EventBroker.send(EventBroker.java:85)
          at org.eclipse.e4.ui.internal.workbench.UIEventPublisher.notifyChanged(UIEventPublisher.java:59)
          at org.eclipse.emf.common.notify.impl.BasicNotifierImpl.eNotify(BasicNotifierImpl.java:374)
          at org.eclipse.e4.ui.model.application.ui.impl.ElementContainerImpl.setSelectedElement(ElementContainerImpl.java:171)
          at org.eclipse.e4.ui.internal.workbench.ModelServiceImpl.showElementInWindow(ModelServiceImpl.java:494)
          at org.eclipse.e4.ui.internal.workbench.ModelServiceImpl.bringToTop(ModelServiceImpl.java:458)
          at org.eclipse.e4.ui.internal.workbench.PartServiceImpl.delegateBringToTop(PartServiceImpl.java:724)
          at org.eclipse.e4.ui.internal.workbench.PartServiceImpl.showPart(PartServiceImpl.java:1163)
          at org.eclipse.ui.internal.WorkbenchPage.busyOpenEditor(WorkbenchPage.java:3234)
          at org.eclipse.ui.internal.WorkbenchPage.access$25(WorkbenchPage.java:3149)
          at org.eclipse.ui.internal.WorkbenchPage$10.run(WorkbenchPage.java:3131)
          at org.eclipse.swt.custom.BusyIndicator.showWhile(BusyIndicator.java:70)
          at org.eclipse.ui.internal.WorkbenchPage.openEditor(WorkbenchPage.java:3126)
          at org.eclipse.ui.internal.WorkbenchPage.openEditor(WorkbenchPage.java:3090)
          at org.eclipse.ui.internal.WorkbenchPage.openEditor(WorkbenchPage.java:3071)
          at org.eclipse.ui.ide.IDE.openEditorOnFileStore(IDE.java:1139)
          at org.eclipse.ui.internal.ide.actions.OpenLocalFileAction.run(OpenLocalFileAction.java:97)
          at org.eclipse.ui.internal.ide.actions.OpenLocalFileAction.run(OpenLocalFileAction.java:70)
          at org.eclipse.ui.internal.PluginAction.runWithEvent(PluginAction.java:247)
          at org.eclipse.ui.internal.WWinPluginAction.runWithEvent(WWinPluginAction.java:228)
          at org.eclipse.jface.action.ActionContributionItem.handleWidgetSelection(ActionContributionItem.java:595)
          at org.eclipse.jface.action.ActionContributionItem.access$2(ActionContributionItem.java:511)
          at org.eclipse.jface.action.ActionContributionItem$5.handleEvent(ActionContributionItem.java:420)
          at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84)
          at org.eclipse.swt.widgets.Display.sendEvent(Display.java:4362)
          at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1113)
          at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:4180)
          at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3769)
          at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$4.run(PartRenderingEngine.java:1127)
          at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:337)
          at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.run(PartRenderingEngine.java:1018)
          at org.eclipse.e4.ui.internal.workbench.E4Workbench.createAndRunUI(E4Workbench.java:156)
          at org.eclipse.ui.internal.Workbench$5.run(Workbench.java:654)
          at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:337)
          at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:598)
          at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:150)
          at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:139)
          at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196)
          at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:134)
          at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:104)
          at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:380)
          at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:235)
          at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
          at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
          at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
          at java.lang.reflect.Method.invoke(Unknown Source)
          at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:669)
          at org.eclipse.equinox.launcher.Main.basicRun(Main.java:608)
          at org.eclipse.equinox.launcher.Main.run(Main.java:1515)
      

      迄今为止尝试过的选项 - 无效

      1. dos2unix转换
      2. 使用其他编码格式(如UTF-16和CP1252
      3. )生成的Robot文件
      4. 更改了Eclipse> Windows和GT;偏好>工作区>文本文件编码为UTF-8。

2 个答案:

答案 0 :(得分:0)

您的档案不正确。间距不规则(应为4个空格)。 它缺少测试用例部分。

以下是在RIDE中正确打开的更正文件:

*** Settings ***
Library        some.class.path.ClassName

*** Test Cases ***
Some Test
    No Operation

*** Keywords ***
type val
    [Arguments]    ${xpathForLocale}   ${dataModifyRole}    ${strLocale}    
    some.class.path.ClassName.type    ${xpathForLocale}    ${dataModifyRole}    ${strLocale}

答案 1 :(得分:0)

它是RED编辑器的一个错误:https://github.com/nokia/RED/issues/21 要在下一个可用版本中修复