1

我想通过一个安全管理器,以便在 gradle 的 Junit 测试中使用。我尝试了 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但我没有。

4

1 回答 1

1

Gradle 用户指南第46.2.3 节有一个关于为不同于您的测试设置系统属性的示例:

test {
    systemProperties 'property': 'value'
}

也许您可以尝试使用该语法,即

test {
    systemProperties 'java.security.policy': file("$projectDir/security.policy").absolutePath
}
于 2017-10-10T07:30:16.263 回答