diff --git a/backend/pom.xml b/backend/pom.xml index c85ffa4cc2..19531f4b4f 100644 --- a/backend/pom.xml +++ b/backend/pom.xml @@ -497,6 +497,15 @@ src/main/resources/jmeter/lib/ext ApacheJMeter_functions.jar + + org.python + jython-standalone + 2.7.0 + jar + true + src/main/resources/jmeter/lib/ext + jython-standalone.jar + ${project.build.directory}/wars false diff --git a/backend/src/main/java/io/metersphere/api/jmeter/JMeterService.java b/backend/src/main/java/io/metersphere/api/jmeter/JMeterService.java index 1ceb8ae6bf..8a381e7d36 100644 --- a/backend/src/main/java/io/metersphere/api/jmeter/JMeterService.java +++ b/backend/src/main/java/io/metersphere/api/jmeter/JMeterService.java @@ -11,7 +11,7 @@ import org.apache.jmeter.save.SaveService; import org.apache.jmeter.util.JMeterUtils; import org.apache.jmeter.visualizers.backend.BackendListener; import org.apache.jorphan.collections.HashTree; -import org.python.core.Options; + import org.springframework.context.i18n.LocaleContextHolder; import org.springframework.stereotype.Service; @@ -34,10 +34,6 @@ public class JMeterService { JMeterUtils.setJMeterHome(JMETER_HOME); JMeterUtils.setLocale(LocaleContextHolder.getLocale()); - - //解决无法加载 PyScriptEngineFactory - Options.importSite = false; - try { Object scriptWrapper = SaveService.loadElement(is); HashTree testPlan = getHashTree(scriptWrapper); @@ -51,7 +47,7 @@ public class JMeterService { } } - private String getJmeterHome() { + public String getJmeterHome() { String home = getClass().getResource("/").getPath() + "jmeter"; try { File file = new File(home); diff --git a/backend/src/main/java/io/metersphere/listener/AppStartListener.java b/backend/src/main/java/io/metersphere/listener/AppStartListener.java index e2068d3768..6f25d0fd66 100644 --- a/backend/src/main/java/io/metersphere/listener/AppStartListener.java +++ b/backend/src/main/java/io/metersphere/listener/AppStartListener.java @@ -1,6 +1,10 @@ package io.metersphere.listener; +import io.metersphere.api.jmeter.JMeterService; +import io.metersphere.commons.utils.LogUtil; import io.metersphere.service.ScheduleService; +import org.python.core.Options; +import org.python.util.PythonInterpreter; import org.springframework.boot.context.event.ApplicationReadyEvent; import org.springframework.context.ApplicationListener; import org.springframework.stereotype.Component; @@ -12,12 +16,16 @@ public class AppStartListener implements ApplicationListener