[rfc][icedtea-web] policytool in itweb-settings
Andrew Azores
aazores at redhat.com
Tue Jan 21 07:06:40 PST 2014
On 01/21/2014 06:25 AM, Jiri Vanek wrote:
> On 01/20/2014 09:11 PM, Andrew Azores wrote:
>> On 01/20/2014 02:50 PM, Andrew Azores wrote:
>>> On 01/20/2014 07:27 AM, Jiri Vanek wrote:
>>>> On 01/17/2014 10:08 PM, Andrew Azores wrote:
>>>>> (snip)
>>>>
>>>> Ouch. See my reply to patch.
>>>
>>> Didn't see any mail, but we discussed on IRC. Here's a recap:
>>> - The reflection hack is horrible. It doesn't quite work, and it's
>>> super ugly.
>>> - The process not exiting is definitely a problem. We should not be
>>> playing around with reflection on the policytool like this.
>>> - Calling PolicyTool.main() directly breaks the automated build(?).
>>> We don't want to make it a build dep, and it's too minor to bother
>>> with a configure step/flag(?).
>>> - Solution: Runtime#exec() makes its return, with a fallback method
>>> of reflectively invoking PolicyTool.main() if for any reason the
>>> exec fails (non-POSIX system, executable not on PATH, etc)
>>>
>>> So here's a patch implementing this solution, with lots of extra
>>> added documentation.
>>>
>>
>> And this time with better respect for event dispatch thread, I hope.
>> (thanks omajid)
>>
>> Thanks,
>
> Only one *the* nit :)
>
>
>> /**
>> + * We do this so we can asynchronously monitor the exit status
>> of the policytool process.
>> + * If it fails immediately and we need to fall back to using
>> reflectivePolicyToolLaunch,
>> + * then the Thread spawned here is very short lived. However, if
>> the policytool process
>> + * successfully launches, then it takes some unknown amount of
>> time before it closes
>> + * again. We do not want to call waitFor() on the ptool process
>> in the main thread
>> + * because this will cause the itweb-settings window to lock up.
>> + * @param frame a {@link JFrame} to act as parent to warning
>> dialogs which may appear
>> + * @param filePath a {@link String} representing the path to the
>> file to be opened
>> + * @throws IOException if an IOException occurs during the exec
>> of the policytool process
>> + */
>> + private static void policyToolLaunchHelper(final JFrame frame,
>> final String filePath) {
>> + final String[] launchCommand = new String[] { "policytool",
>> "-file", filePath };
>> + new Thread(new Runnable() {
>> + @Override
>> + public void run() {
>> + try {
>> + final Process ptool =
>> Runtime.getRuntime().exec(launchCommand);
>> + if (ptool.waitFor() != 0) {
>> + reflectivePolicyToolLaunch(filePath);
>> + }
>> + } catch (Exception e) {
>> + OutputController.getLogger().log(e);
>> + showCouldNotOpenFileDialog(frame, filePath,
>> R("CPPolicyEditorNotFound"));
>> + }
>> + }
>> + }).start();
>> + }
>> +
>
>
> I would discourage you from this, By doing this you will lunch the
> main classed fallback even in case of failure in spawned jvm.
>
> I would go with:
>
> Integer lunched = null;
> ...
> if (lunched == null){
> final Process ptool = Runtime.getRuntime().exec("policytool --help");
> //it only prints somethig to stdou
> lunched = ptool.waitFor();
> }
> if (lunched == null){ throw/log Something human readable or run
> fallback or whatewer}
> if (lunched ==0){run async proces} else {run fallback}
>
>
> otherwise ok!
>
> J.
>
>
Well, the first null check seems useless if lunched isn't used anywhere
else. Then, policytool doesn't actually accept anything except '-file' -
it has no '-help' or '--help'-. So that process you're exec'ing always
fails just about immediately with a non-zero (1) exit status. lunched
will never be null after assigning ptool.waitFor() to it, unless some
exception is thrown and handling logic is added, so the lunched == null
case also seems useless. Then, lunched is always non-zero because there
is no --help, so we never run async process to launch policytool
properly with a -file, and always resort to fallback. *If* there was a
--help switch which could be used to run policytool headless with a zero
exit status, then this would all work nicely... :)
Thanks,
--
Andrew A
More information about the distro-pkg-dev
mailing list