问题
When using a Spock test, i have hardcoded some properties hardcoded into the spock test. The example is a JDBC url. I tried the @Value annotation together with a propertie file, but this seems not to work as my test has no stereotype. Are there any other solutions to inject property values?
@ContextConfiguration(locations = "classpath*:applicationContext-test.xml")
class RepositoryTest extends Specification {
@Shared sql = Sql.newInstance("jdbc:sqlserver:// - room - for - properties")
}
回答1:
@Shared properties cannot be injected, but something like this should work (with Spring 3):
@Value("#{databaseProperties.jdbcUrl}")
String jdbcUrl
Sql sql
def setup() {
if (!sql) {
sql = new Sql(jdbcUrl)
}
}
This assumes that you have defined "databaseProperties" in your bean definition file:
<util:properties id="databaseProperties" location="classpath:database.properties" />
回答2:
To use PropertySourcesPlaceholderConfigurer
, add a @Configuration
class:
@Configuration
@PropertySource("classpath:database.properties")
public class DatabaseConfig {
@Bean
public static PropertySourcesPlaceholderConfigurer propertySourcesPlaceholderConfigurer() {
return new PropertySourcesPlaceholderConfigurer();
}
}
Reference is here.
And then, in Spock:
@Value('${foo.bar}') //Use single quote.
String fooBar
The reason to use single quote is here.
And you probably need to add @ContextConfiguration
to your Spock class:
@ContextConfiguration(classes = DatabaseConfig .class)
class Test extends Specification {
...
}
回答3:
use jvm system properties "java -DdbUsername=bbbb"
来源:https://stackoverflow.com/questions/6536289/how-to-inject-property-values-into-a-spock-test