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
}
Другие вопросы по тегам