gpt4 book ai didi

karate - 从 Spock 运行 Karate(1.0.1) 测试时,在模拟中设置的系统属性最终在 karate.properties ['message' 中未定义]

转载 作者:行者123 更新时间:2023-12-04 07:43:45 27 4
gpt4 key购买 nike

在空手道版本 0.9.5 中,我能够在模拟调用期间使用 System.setProperty('message', message)。然后该属性在使用 karate.properties['message'] 的功能中可用。我已经升级到 1.0.1 版,现在 karate.properties['message'] 的结果是 undefined
Spock 测试代码

@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
class ApiTestRunnerSpec extends Specification {

@LocalServerPort
private int port

@SpringBean
MessageLogger messageLogger = Mock()

def "setup"() {
System.out.println("Running on port: " + port)
System.setProperty("server.port", "" + port)
}

def "Run Mock ApiTest"() {
given:
System.setProperty('foo', 'bar')

when:
Results results = Runner.path("classpath:").tags("~@ignore").parallel(5)

then:
results != null
1 * messageLogger.logMessage(_ as String) >> { String message ->
assert message != null
System.setProperty("message", message)
}
}
}
Controller
@RestController
public class MessageController {

@Autowired private MessageLogger messageLogger;

@GetMapping("/message")
public String message() {
String message = "Important Message";

messageLogger.logMessage(message);

return message;
}
}
消息记录器
@Component
public class MessageLogger {

public void logMessage(String message) {
System.out.println(message);
}
}
空手道-config.js
function fn() {
karate.configure('connectTimeout', 10000);
karate.configure('readTimeout', 10000);
karate.configure('ssl', true);

var config = {
localUrl: 'http://localhost:' + java.lang.System.getProperty('server.port'),
};
print('localUrl::::::::::', config.localUrl);
return config;
}
特征
@mockMessage
@parallel=true
Feature: Test Message

Background:
* url localUrl

Scenario: GET

Given path '/message'
When method get
Then status 200

* print 'foo value ' + karate.properties['foo']
* print 'message value ' + karate.properties['message']
0.9.5
2021-04-28 15:07:51.819 (...) [print] **foo value bar**
2021-04-28 15:07:51.826 (...) [print] **message value Important Message**
1.0.1
2021-04-28 14:36:58.566 (...) [print] **foo value bar** 
2021-04-28 14:36:58.580 (...) [print] **message value undefined**
Link to project on github

最佳答案

我克隆了你的项目并注意到一些过时的东西(Groovy、Spock 和 GMaven+ 版本)。升级它们并没有改变结果,我仍然可以重现您的问题。
A 还注意到,在您的两个分支中,POM 的不同不仅在于空手道版本号,而且依赖项也不同。如果我使用 1.0.1 分支中的那些,则测试不再在 0.9.5 下工作。所以我 fork 了你的项目并向你发送了每个分支的两个拉取请求,并且两个空手道版本的依赖设置都相同。现在分支实际上只是在空手道版本号上有所不同:
https://github.com/kriegaex/spock-karate-example/compare/karate-0.9.5...kriegaex:karate-1.0.1
顺便说一句,由于某种原因,我不得不编译运行 JDK 11 的代码,但 JDK 16 不起作用。 GMaven+ 提示 Java 16 groovy 类文件(字节码版本 60.0),尽管 GMaven+ 应该使用目标级别 11。不知道这是关于什么的。无论如何,在 Java 11 上,我可以重现您的问题。由于两个分支的 Spock 版本相同,我想问题出在空手道本身。我建议在那里打开一个问题,链接到你的 GitHub 项目(在你接受我的 PR 之后)。 Spock 肯定设置了系统属性,我在 stub 关闭命令中添加了更多日志输出以验证这一点。也许这是关于空手道如何以及何时与 Spock 交流的问题。

更新: Peter Thomas 在他的回答中建议将要传输到该功能的值存储在一个 Java 对象中,并在 Spock 测试设置它之后从该功能访问该值。我想,他的意思是这样的:
https://github.com/kriegaex/spock-karate-example/commit/ca88e3da

@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
class ApiTestRunnerSpec extends Specification {

@LocalServerPort
private int port

@SpringBean
MessageLogger messageLogger = Mock() {
1 * logMessage(_ as String) >> { String message ->
assert message != null
MessageHolder.INSTANCE.message = message
}
}

def "setup"() {
System.out.println("Running on port: " + port)
System.setProperty("server.port", "" + port)
}

def "Run Mock ApiTest"() {
given:
Results results = Runner
.path("classpath:")
.systemProperty("foo", "bar")
.tags("~@ignore")
.parallel(5)

expect:
results
}

static class MessageHolder {
public static final MessageHolder INSTANCE = new MessageHolder()
private String message

private MessageHolder() {}

String getMessage() {
return message
}

void setMessage(String message) {
this.message = message
}
}
}
@mockMessage
@parallel=true
Feature: Test Message

Background:
* url localUrl

Scenario: GET

Given path '/message'
When method get
Then status 200

* print 'foo value ' + karate.properties['foo']
* def getMessage =
"""
function() {
var MessageHolder = Java.type('com.example.spock.karate.ApiTestRunnerSpec.MessageHolder');
return MessageHolder.INSTANCE.getMessage();
}
"""
* def message = call getMessage {}
* print 'message value ' + message

更新 2:这是 Peter 的第二个想法的实现,即通过 JS 简单地访问 Java 系统属性。因此,我使用消息持有者单例简化了工作但不必要的复杂版本,再次将其消除:
https://github.com/kriegaex/spock-karate-example/commit/e235dd71
现在它看起来像这样(类似于最初的 Spock 规范,只是重构得不那么冗长):
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
class ApiTestRunnerSpec extends Specification {

@LocalServerPort
private int port

@SpringBean
MessageLogger messageLogger = Mock() {
1 * logMessage(_ as String) >> { String message ->
assert message != null
System.setProperty('message', message)
}
}

def "setup"() {
System.out.println("Running on port: " + port)
System.setProperty("server.port", "" + port)
}

def "Run Mock ApiTest"() {
expect:
Runner.path("classpath:").systemProperty("foo", "bar").tags("~@ignore").parallel(5)
}
}
唯一重要的变化是空手道功能:
@mockMessage
@parallel=true
Feature: Test Message

Background:
* url localUrl

Scenario: GET

Given path '/message'
When method get
Then status 200

* print 'foo value ' + karate.properties['foo']
* def getMessage = function() { return Java.type('java.lang.System').getProperty('message'); }
* print 'message value ' + getMessage()

关于karate - 从 Spock 运行 Karate(1.0.1) 测试时,在模拟中设置的系统属性最终在 karate.properties ['message' 中未定义],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67307301/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com