Gradle определяет политику безопасности для тестов
Я хочу передать менеджер безопасности для использования в тестах Junit Gradle. Я пробовал jvmargs(не работает), и теперь я использую это:
apply plugin: 'java'
test {
systemProperties << ['java.security.policy': file("$projectDir/security.policy").absolutePath]
}
...
Класс Java
package hello;
import java.io.*;
import java.lang.*;
public class MyClass {
public void method() {
try {
File file = new File("/etc/passwd");
FileReader fr = new FileReader(file);
char [] a = new char[50];
fr.read(a);
for(char c : a)
System.out.print(c);
fr.close();
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
Моя политика:
grant {
permission java.io.FilePermission "/home/-", "read";
};
Поэтому я ожидаю получить исключение безопасности при попытке прочитать /etc/passwd
но я не
1 ответ
В разделе 46.2.3 Руководства пользователя Gradle приведен пример настройки системного свойства для теста, который отличается от вашего:
test {
systemProperties 'property': 'value'
}
Возможно, вы можете попробовать с этим синтаксисом, который будет
test {
systemProperties 'java.security.policy': file("$projectDir/security.policy").absolutePath
}