[rfc][icedtea-web][policyeditor] Parsing enhancements and unit tests
Jiri Vanek
jvanek at redhat.com
Mon Mar 10 12:25:20 UTC 2014
On 03/08/2014 05:07 AM, Andrew Azores wrote:
> Well, I guess I could make one matcher, check if it matches, and then if not, make the other and check with it, but how much does it really matter... ? I think the intention is clearer, having the conjunction in the first if check. I doubt it will make much of a perfomance difference for most users,
> unless they end up with much more massive custom policy files than I'm expecting.
Well its not about the performance of this method, but about ITW as a whole. Consider such a redundant calls in each method. They will mutliply runtime later unbearable.
>
> And of course the CustomPermission and PolicyEditorPermissions fromString() methods are "suspiciously" similar
Then why they dont share an code?
> - they are both reading from the same source and attempting to parse into more or less the same end result. Why would they be really different? I guess the logic is mostly the same so they could be given a parent class or some utility method.
Please eleaborate on this two hunks a bit.
>
> Thanks,
>
> Andrew A
>
> ----- Original Message -----
> From: "Jiri Vanek"<jvanek at redhat.com>
> To: "Andrew Azores"<aazores at redhat.com>
> Cc: "IcedTea"<distro-pkg-dev at openjdk.java.net>
> Sent: Friday, March 7, 2014 8:24:09 AM
> Subject: Re: [rfc][icedtea-web][policyeditor] Parsing enhancements and unit tests
>
> The messages.properties changes are still not listed in changelog.
and dont forget^ O:)
>
> This is probably nit, but:
> + final Matcher targetMatcher = PolicyEditorPermissions.TARGET_PERMISSION.matcher(string);
> + final Matcher actionMatcher = PolicyEditorPermissions.ACTIONS_PERMISSION.matcher(string);
> + if (!targetMatcher.matches()&& !actionMatcher.matches()) {
> + return null;
> + }
> +
> + final String typeStr, targetStr, actionsStr;
> +
> + if (actionMatcher.matches()) {
> + typeStr = actionMatcher.group(1);
> + targetStr = actionMatcher.group(2);
> + actionsStr = actionMatcher.group(3);
> + } else {
> + typeStr = targetMatcher.group(1);
> + targetStr = targetMatcher.group(2);
> + actionsStr = "";
> }
>
> the first matcher is needed only when second one fails. Maybe would be nice to remove the
> unnecessary matching.
>
> similar for PolicyEditorPermissions which is still suspiciously similar:(
>
>
> The chnage [\\w.] -> [\\w\\.] looks enough :)
>
>
>
> Thanx!
> J.
> On 03/06/2014 09:18 PM, Andrew Azores wrote:
>> Thanks for review! Hopefully the new attached patch is nicer.
>>
>> Thanks,
>>
>> Andrew A
>>
>> ----- Original Message -----
>> From: "Jiri Vanek"<jvanek at redhat.com>
>> To: "Andrew Azores"<aazores at redhat.com>
>> Cc: "IcedTea"<distro-pkg-dev at openjdk.java.net>
>> Sent: Thursday, March 6, 2014 9:07:46 AM
>> Subject: Re: [rfc][icedtea-web][policyeditor] Parsing enhancements and unit tests
>>
>> On 03/05/2014 06:01 PM, Andrew Azores wrote:
>>> Hi,
>>>
>>> The previous thread was diverging into two quite different patches, so I'm splitting it.
>>>
>>> This patch improves parsing, especially handling of comments, and adds a lot of new unit testing for this. A few small bugs were found and fixed along the way.
>>>
>>
>> The Messages.properties changes are missing in in-pathc chagelog
>>
>> public static CustomPermission fromString - more more and more tests. Try to hack yourself. But generally ok.
>> Well the comment is poem-writer's masterpiece :) But better then nothing :)
>> The [\\w.] do not osund correct. The dot should be escaped to match dot, not any char. Or not? So this part will be:
>> [[\\w\\.]+\\w+] (nottested - to match [java.][io.][permissions] and nto eg dsgfgogfdsgjsfdghjsfd[hj as now :)
>> The content of quotes may be anything, ok? What about content to be qutes itself? (not jsut ${} eg?
>> The first quotes are mandatory, and the scond not? As far as I read from regex.
>> Why is compiled patter not global constant? It should be. It will not need recompile each launch time... Then there can be also some tests only to the regex itself.
>>
>>
>> Why is the CustomPermission.fromStirng copypasted to PolicyEditorPermissions ???
>>
>> Quick glance over tests is ook.
>>
>> Thanx!
>> J.
>>
>
More information about the distro-pkg-dev
mailing list