[icedtea-web] RFC: add unit tests for the jnlp parser
Omair Majid
omajid at redhat.com
Wed Mar 30 17:08:13 PDT 2011
On 03/30/2011 06:08 PM, Dr Andrew John Hughes wrote:
> On 14:20 Wed 30 Mar , Omair Majid wrote:
>> > Ah, ok. I thought we wanted to only include code which is GPL-friendly
>> > in IcedTea. If we are ok with adding independent code under other
>> > license, it certainly makes this a non-issue.
>> >
> It has to be FOSS. I don't see a reason for GPL compatibility in
> completely independent chunks of code; that's quite a strong
> requirement OpenJDK itself is a hodge-podge of stuff, allowed by the
> ASSEMBLY_EXCEPTION.
>
Ok, that's great.
>>> > > What JUnit code is included? Is it marked?
>>> > >
>> >
>> > Please see the attached patch. I havent marked it, but almost all the
>> > code in CommandLine.java is based on JUnit code. The
>> > LessVerboseTextListener.java implements JUnit interfaces, but it is
>> > written from scratch.
>> >
> There does need to be something in there such as:
>
> // Based on code from X (C) Y
>
Sure, except I dont know the copyright owners. So I have left it as:
// Based on code from JUnit
> You're also lacking license headers.
That was a quick example I had put together. I have fixed it in the
actual patch
> snip...
>
>> >
>>>>> > >> > I would like to see less things in-tree (/me is looking at NanoXML), not
>>>>> > >> > more.
>>>>> > >> >
>>> > > How is the NanoXML issue progressing? It would be good to have a status update
>>> > > on things and the progress towards the various releases of IcedTea-Web now 1.0
>>> > > is done.
>>> > >
>> >
>> > Sorry, I must have forgotten to make a note of this. Generally I try and
>> > keephttp://icedtea.classpath.org/wiki/IcedTea-Web#Release_Plans
>> > updated.
> I don't check the wiki regularly anyway. I'd expect stuff to be discussed on the
> mailing list then documented on the wiki.
>
>> > Anyway, it's mostly done. I wrote these parser unit tests to
>> > test that my NanoXML changes did not break anything. I will clean up
>> > that patch and post it after these unit tests are committed (so we can
>> > see any regressions). Assuming Deepak is fine with it, it can go in
>> > before 1.1 is released.
>> >
> Yeah I think we (mainly Deepak as maintainer) need to define clearly where we draw
> a line under 1.1.
>
> snip..
>> >
>> > I should have elaborated more. JUnit/TestNG (and possibly others) are
>> > just fine for developers. The problem here is that we want to generate
>> > buildbot-readable test results. We can do that by writing a custom
>> > junit-output formatter (like in the attached patch), by transforming
>> > testng's xml output or by transforming junit's xml output. Unfortunately
>> > the only way of getting junit to create xml output is through ant. Junit
>> > itself has no option (at least nothing that I could see) that generates
>> > output in xml format. If it is okay to use the custom junit output
>> > formatter, than we dont need ant. Actually, if we dont care about the
>> > buildbot, then we dont need the custom output formatter or any xml
>> > processing at all.
>> >
> Ok, so whoever wrote the JUnit XML outputter introduced some odd Ant dependency
> that's unnecessary. Got you.
>
Actually, not quite. JUnit has no xml outputter. Only ant (thought it's
junit task) does.
>>> > > Ant massively overcomplicates things, but I have no idea of the availability
>>> > > of the various dependencies for testng or their licenses.
>>> > >
>>> > > Can you provide some of this info?
>>> > >
>> >
>> > Sure. TestNG is licensed under Apache 2.0. Its dependencies are QDox
>> > (Apache 2.0) and Bean Shell (Sun Public License or LGPL).
>> >
>> > TestNG (and its dependencies) are available in a number of Linux
>> > distributions, including Debian (squeeze, wheezy and sid), Fedora (>=
>> > 13), Gentoo (java-experimental overlay), Mageia, Mandriva (, openSUSE
>> > (>= 11.2), and Ubuntu (>= 9.10). It's not available in Arch Linux, and
>> > Slackware (and possibly other distributions).
>> >
> It's in Gentoo's java-overlay tree (the same place I develop IcedTea ebuilds
> and have commit access to),
Ah, sorry. I dont have Gentoo. I did a quick search and saw that package
in the java-experimental overlay.
> and this is the hideous dependency tree it has:
> [ebuild N ] dev-java/commons-logging-1.1.1 USE="-avalon-framework -avalon-logkit -doc -log4j -servletapi -source -test" 187 kB [0]
> [ebuild N ] dev-java/ant-apache-log4j-1.8.1 0 kB [0]
> [ebuild N ] dev-java/ant-swing-1.8.1 0 kB [0]
> [ebuild N ] dev-java/ant-apache-bcel-1.8.1 0 kB [0]
> [ebuild N ] dev-java/ant-apache-resolver-1.8.1 0 kB [0]
> [ebuild N ] dev-java/ant-apache-oro-1.8.1 0 kB [0]
> [ebuild N ] dev-java/jdepend-2.9-r4 USE="-doc -source" 296 kB [0]
> [ebuild N ] dev-java/jzlib-1.0.7-r1 USE="-doc -source" 50 kB [0]
> [ebuild N ] dev-java/commons-net-1.4.1-r1 USE="-doc -examples -source" 224 kB [0]
> [ebuild N ] dev-java/jakarta-regexp-1.4-r1 USE="-doc -source" 135 kB [0]
> [ebuild N ] dev-java/sun-jaf-1.1.1 USE="-doc -source" 123 kB [0]
> [ebuild N ] java-virtuals/jaf-1.1-r1 0 kB [0]
> [ebuild N ] dev-java/ant-commons-logging-1.8.1 0 kB [0]
> [ebuild N ] dev-java/ant-apache-regexp-1.8.1 0 kB [0]
> [ebuild N ] dev-java/ant-commons-net-1.8.1 0 kB [0]
> [ebuild N ] dev-java/ant-jdepend-1.8.1 0 kB [0]
> [ebuild N ] dev-java/jsch-0.1.44 USE="zlib -doc -examples -source" 278 kB [0]
> [ebuild N ] dev-java/bsf-2.4.0-r1 USE="javascript python -doc -examples -source -tcl" 293 kB [0]
> [ebuild N ] dev-java/sun-javamail-1.4.3 USE="-doc -source" 1,148 kB [0]
> [ebuild N ] dev-java/ant-apache-bsf-1.8.1 USE="javascript python -tcl" 0 kB [0]
> [ebuild N ] dev-java/ant-jsch-1.8.1 0 kB [0]
> [ebuild N ] java-virtuals/javamail-1.0-r1 0 kB [0]
> [ebuild N ] dev-java/ant-javamail-1.8.1 0 kB [0]
> [ebuild N ] dev-java/ant-1.8.1 USE="X antlr bcel bsf commonslogging commonsnet javamail jdepend jsch log4j oro regexp resolver -jai -jmf -testutil" 0 kB [0]
> [ebuild N ] dev-java/testng-5.2 USE="-doc -source" 2,605 kB [1]
>
> I think most of that is due to a bad dependency on the whole of Ant though. Not sure how much
> of Ant it actually needs.
>
I think it's a build-time dependency, not a run-time dependency. But you
are correct - the tree is quite big.
>> > JUnit is licensed under Common Public License v.10.
>> >
>> > JUnit is available in all the distributions listed above - including
>> > Arch Linux and Slackware.
>> >
>>>>> > >> > My custom runner:
>>>>> > >> > Passed: net.sourceforge.jnlp.ParserBasic.testResourcesJar
>>>>> > >> > Passed: net.sourceforge.jnlp.ParserBasic.testResourcesExtensions
>>>>> > >> > Passed: net.sourceforge.jnlp.ParserBasic.testResourcesProperty
>>>>> > >> > [snip]
>>>>> > >> > FAILED: testUnquotedAttributes(net.sourceforge.jnlp.ParserMalformedXml)
>>>>> > >> > Invalid XML document syntax.
>>>>> > >> > Test results: passed: 23; failed: 4; ignored: 0
>>>>> > >> >
>>>>> > >> > I suppose using plain JUnit is fine; it just wont have pretty output
>>>>> > >> > suitable for buildbot.
>>>>> > >> >
>>> > > The custom runner looks fine. What's the problem?
>>> > >
>> >
>> > Other than my licensing concerns (CPL in a GPL-friendly repository),
>> > nothing.
>> >
> Great.
>
> I await the new patch.
>
Updated patch attached. Any thoughts or comments?
Cheers,
Omair
-------------- next part --------------
A non-text attachment was scrubbed...
Name: add-junit-unit-tests-01.patch
Type: text/x-patch
Size: 30658 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20110330/a9a0f5e4/add-junit-unit-tests-01.patch
More information about the distro-pkg-dev
mailing list